Completed
Branch FET-Wait-List (2b1ad0)
by
unknown
128:56 queued 117:50
created
modules/messages/EED_Messages.module.php 1 patch
Indentation   +1090 added lines, -1090 removed lines patch added patch discarded remove patch
@@ -16,1105 +16,1105 @@
 block discarded – undo
16 16
 class EED_Messages extends EED_Module
17 17
 {
18 18
 
19
-    /**
20
-     * This holds the EE_messages controller
21
-     *
22
-     * @deprecated 4.9.0
23
-     * @var EE_messages $_EEMSG
24
-     */
25
-    protected static $_EEMSG;
26
-
27
-    /**
28
-     * @type EE_Message_Resource_Manager $_message_resource_manager
29
-     */
30
-    protected static $_message_resource_manager;
31
-
32
-    /**
33
-     * This holds the EE_Messages_Processor business class.
34
-     *
35
-     * @type EE_Messages_Processor
36
-     */
37
-    protected static $_MSG_PROCESSOR;
38
-
39
-    /**
40
-     * holds all the paths for various messages components.
41
-     * Utilized by autoloader registry
42
-     *
43
-     * @var array
44
-     */
45
-    protected static $_MSG_PATHS;
46
-
47
-
48
-    /**
49
-     * This will hold an array of messages template packs that are registered in the messages system.
50
-     * Format is:
51
-     * array(
52
-     *    'template_pack_dbref' => EE_Messages_Template_Pack (instance)
53
-     * )
54
-     *
55
-     * @var EE_Messages_Template_Pack[]
56
-     */
57
-    protected static $_TMP_PACKS = array();
58
-
59
-
60
-    /**
61
-     * @return EED_Messages
62
-     */
63
-    public static function instance()
64
-    {
65
-        return parent::get_instance(__CLASS__);
66
-    }
67
-
68
-
69
-    /**
70
-     *  set_hooks - for hooking into EE Core, other modules, etc
71
-     *
72
-     * @since 4.5.0
73
-     * @return    void
74
-     */
75
-    public static function set_hooks()
76
-    {
77
-        //actions
78
-        add_action('AHEE__EE_Payment_Processor__update_txn_based_on_payment', array('EED_Messages', 'payment'), 10, 2);
79
-        add_action('AHEE__EE_Registration_Processor__trigger_registration_update_notifications',
80
-            array('EED_Messages', 'maybe_registration'), 10, 2);
81
-        //filters
82
-        add_filter('FHEE__EE_Registration__receipt_url__receipt_url',
83
-            array('EED_Messages', 'registration_message_trigger_url'), 10, 4);
84
-        add_filter('FHEE__EE_Registration__invoice_url__invoice_url',
85
-            array('EED_Messages', 'registration_message_trigger_url'), 10, 4);
86
-        //register routes
87
-        self::_register_routes();
88
-    }
89
-
90
-    /**
91
-     *    set_hooks_admin - for hooking into EE Admin Core, other modules, etc
92
-     *
93
-     * @access    public
94
-     * @return    void
95
-     */
96
-    public static function set_hooks_admin()
97
-    {
98
-        //actions
99
-        add_action('AHEE__EE_Payment_Processor__update_txn_based_on_payment', array('EED_Messages', 'payment'), 10, 2);
100
-        add_action('AHEE__Transactions_Admin_Page___send_payment_reminder__process_admin_payment_reminder',
101
-            array('EED_Messages', 'payment_reminder'), 10);
102
-        add_action('AHEE__EE_Registration_Processor__trigger_registration_update_notifications',
103
-            array('EED_Messages', 'maybe_registration'), 10, 3);
104
-        add_action('AHEE__Extend_Registrations_Admin_Page___newsletter_selected_send__with_registrations',
105
-            array('EED_Messages', 'send_newsletter_message'), 10, 2);
106
-        add_action('AHEE__EES_Espresso_Cancelled__process_shortcode__transaction',
107
-            array('EED_Messages', 'cancelled_registration'), 10);
108
-        add_action('AHEE__EE_Admin_Page___process_admin_payment_notification',
109
-            array('EED_Messages', 'process_admin_payment'), 10, 1);
110
-        //filters
111
-        add_filter('FHEE__EE_Admin_Page___process_resend_registration__success',
112
-            array('EED_Messages', 'process_resend'), 10, 2);
113
-        add_filter('FHEE__EE_Registration__receipt_url__receipt_url',
114
-            array('EED_Messages', 'registration_message_trigger_url'), 10, 4);
115
-        add_filter('FHEE__EE_Registration__invoice_url__invoice_url',
116
-            array('EED_Messages', 'registration_message_trigger_url'), 10, 4);
117
-    }
118
-
119
-
120
-    /**
121
-     * All the message triggers done by route go in here.
122
-     *
123
-     * @since 4.5.0
124
-     * @return void
125
-     */
126
-    protected static function _register_routes()
127
-    {
128
-        EE_Config::register_route('msg_url_trigger', 'Messages', 'run');
129
-        EE_Config::register_route('msg_cron_trigger', 'Messages', 'execute_batch_request');
130
-        EE_Config::register_route('msg_browser_trigger', 'Messages', 'browser_trigger');
131
-        EE_Config::register_route('msg_browser_error_trigger', 'Messages', 'browser_error_trigger');
132
-        do_action('AHEE__EED_Messages___register_routes');
133
-    }
134
-
135
-
136
-    /**
137
-     * This is called when a browser display trigger is executed.
138
-     * The browser display trigger is typically used when a already generated message is displayed directly in the
139
-     * browser.
140
-     *
141
-     * @since 4.9.0
142
-     * @param WP $WP
143
-     */
144
-    public function browser_trigger($WP)
145
-    {
146
-        //ensure controller is loaded
147
-        self::_load_controller();
148
-        $token = EE_Registry::instance()->REQ->get('token');
149
-        try {
150
-            $mtg = new EE_Message_Generated_From_Token($token, 'html', self::$_message_resource_manager);
151
-            self::$_MSG_PROCESSOR->generate_and_send_now($mtg);
152
-        } catch (EE_Error $e) {
153
-            $error_msg = __('Please note that a system message failed to send due to a technical issue.',
154
-                'event_espresso');
155
-            // add specific message for developers if WP_DEBUG in on
156
-            $error_msg .= '||' . $e->getMessage();
157
-            EE_Error::add_error($error_msg, __FILE__, __FUNCTION__, __LINE__);
158
-        }
159
-    }
160
-
161
-
162
-    /**
163
-     * This is called when a browser error trigger is executed.
164
-     * When triggered this will grab the EE_Message matching the token in the request and use that to get the error
165
-     * message and display it.
166
-     *
167
-     * @since 4.9.0
168
-     * @param $WP
169
-     */
170
-    public function browser_error_trigger($WP)
171
-    {
172
-        $token = EE_Registry::instance()->REQ->get('token');
173
-        if ($token) {
174
-            $message = EEM_Message::instance()->get_one_by_token($token);
175
-            if ($message instanceof EE_Message) {
176
-                header('HTTP/1.1 200 OK');
177
-                $error_msg = nl2br($message->error_message());
178
-                ?>
19
+	/**
20
+	 * This holds the EE_messages controller
21
+	 *
22
+	 * @deprecated 4.9.0
23
+	 * @var EE_messages $_EEMSG
24
+	 */
25
+	protected static $_EEMSG;
26
+
27
+	/**
28
+	 * @type EE_Message_Resource_Manager $_message_resource_manager
29
+	 */
30
+	protected static $_message_resource_manager;
31
+
32
+	/**
33
+	 * This holds the EE_Messages_Processor business class.
34
+	 *
35
+	 * @type EE_Messages_Processor
36
+	 */
37
+	protected static $_MSG_PROCESSOR;
38
+
39
+	/**
40
+	 * holds all the paths for various messages components.
41
+	 * Utilized by autoloader registry
42
+	 *
43
+	 * @var array
44
+	 */
45
+	protected static $_MSG_PATHS;
46
+
47
+
48
+	/**
49
+	 * This will hold an array of messages template packs that are registered in the messages system.
50
+	 * Format is:
51
+	 * array(
52
+	 *    'template_pack_dbref' => EE_Messages_Template_Pack (instance)
53
+	 * )
54
+	 *
55
+	 * @var EE_Messages_Template_Pack[]
56
+	 */
57
+	protected static $_TMP_PACKS = array();
58
+
59
+
60
+	/**
61
+	 * @return EED_Messages
62
+	 */
63
+	public static function instance()
64
+	{
65
+		return parent::get_instance(__CLASS__);
66
+	}
67
+
68
+
69
+	/**
70
+	 *  set_hooks - for hooking into EE Core, other modules, etc
71
+	 *
72
+	 * @since 4.5.0
73
+	 * @return    void
74
+	 */
75
+	public static function set_hooks()
76
+	{
77
+		//actions
78
+		add_action('AHEE__EE_Payment_Processor__update_txn_based_on_payment', array('EED_Messages', 'payment'), 10, 2);
79
+		add_action('AHEE__EE_Registration_Processor__trigger_registration_update_notifications',
80
+			array('EED_Messages', 'maybe_registration'), 10, 2);
81
+		//filters
82
+		add_filter('FHEE__EE_Registration__receipt_url__receipt_url',
83
+			array('EED_Messages', 'registration_message_trigger_url'), 10, 4);
84
+		add_filter('FHEE__EE_Registration__invoice_url__invoice_url',
85
+			array('EED_Messages', 'registration_message_trigger_url'), 10, 4);
86
+		//register routes
87
+		self::_register_routes();
88
+	}
89
+
90
+	/**
91
+	 *    set_hooks_admin - for hooking into EE Admin Core, other modules, etc
92
+	 *
93
+	 * @access    public
94
+	 * @return    void
95
+	 */
96
+	public static function set_hooks_admin()
97
+	{
98
+		//actions
99
+		add_action('AHEE__EE_Payment_Processor__update_txn_based_on_payment', array('EED_Messages', 'payment'), 10, 2);
100
+		add_action('AHEE__Transactions_Admin_Page___send_payment_reminder__process_admin_payment_reminder',
101
+			array('EED_Messages', 'payment_reminder'), 10);
102
+		add_action('AHEE__EE_Registration_Processor__trigger_registration_update_notifications',
103
+			array('EED_Messages', 'maybe_registration'), 10, 3);
104
+		add_action('AHEE__Extend_Registrations_Admin_Page___newsletter_selected_send__with_registrations',
105
+			array('EED_Messages', 'send_newsletter_message'), 10, 2);
106
+		add_action('AHEE__EES_Espresso_Cancelled__process_shortcode__transaction',
107
+			array('EED_Messages', 'cancelled_registration'), 10);
108
+		add_action('AHEE__EE_Admin_Page___process_admin_payment_notification',
109
+			array('EED_Messages', 'process_admin_payment'), 10, 1);
110
+		//filters
111
+		add_filter('FHEE__EE_Admin_Page___process_resend_registration__success',
112
+			array('EED_Messages', 'process_resend'), 10, 2);
113
+		add_filter('FHEE__EE_Registration__receipt_url__receipt_url',
114
+			array('EED_Messages', 'registration_message_trigger_url'), 10, 4);
115
+		add_filter('FHEE__EE_Registration__invoice_url__invoice_url',
116
+			array('EED_Messages', 'registration_message_trigger_url'), 10, 4);
117
+	}
118
+
119
+
120
+	/**
121
+	 * All the message triggers done by route go in here.
122
+	 *
123
+	 * @since 4.5.0
124
+	 * @return void
125
+	 */
126
+	protected static function _register_routes()
127
+	{
128
+		EE_Config::register_route('msg_url_trigger', 'Messages', 'run');
129
+		EE_Config::register_route('msg_cron_trigger', 'Messages', 'execute_batch_request');
130
+		EE_Config::register_route('msg_browser_trigger', 'Messages', 'browser_trigger');
131
+		EE_Config::register_route('msg_browser_error_trigger', 'Messages', 'browser_error_trigger');
132
+		do_action('AHEE__EED_Messages___register_routes');
133
+	}
134
+
135
+
136
+	/**
137
+	 * This is called when a browser display trigger is executed.
138
+	 * The browser display trigger is typically used when a already generated message is displayed directly in the
139
+	 * browser.
140
+	 *
141
+	 * @since 4.9.0
142
+	 * @param WP $WP
143
+	 */
144
+	public function browser_trigger($WP)
145
+	{
146
+		//ensure controller is loaded
147
+		self::_load_controller();
148
+		$token = EE_Registry::instance()->REQ->get('token');
149
+		try {
150
+			$mtg = new EE_Message_Generated_From_Token($token, 'html', self::$_message_resource_manager);
151
+			self::$_MSG_PROCESSOR->generate_and_send_now($mtg);
152
+		} catch (EE_Error $e) {
153
+			$error_msg = __('Please note that a system message failed to send due to a technical issue.',
154
+				'event_espresso');
155
+			// add specific message for developers if WP_DEBUG in on
156
+			$error_msg .= '||' . $e->getMessage();
157
+			EE_Error::add_error($error_msg, __FILE__, __FUNCTION__, __LINE__);
158
+		}
159
+	}
160
+
161
+
162
+	/**
163
+	 * This is called when a browser error trigger is executed.
164
+	 * When triggered this will grab the EE_Message matching the token in the request and use that to get the error
165
+	 * message and display it.
166
+	 *
167
+	 * @since 4.9.0
168
+	 * @param $WP
169
+	 */
170
+	public function browser_error_trigger($WP)
171
+	{
172
+		$token = EE_Registry::instance()->REQ->get('token');
173
+		if ($token) {
174
+			$message = EEM_Message::instance()->get_one_by_token($token);
175
+			if ($message instanceof EE_Message) {
176
+				header('HTTP/1.1 200 OK');
177
+				$error_msg = nl2br($message->error_message());
178
+				?>
179 179
                 <!DOCTYPE html>
180 180
                 <html>
181 181
                 <head></head>
182 182
                 <body>
183 183
                 <?php echo empty($error_msg)
184
-                    ? esc_html__('Unfortunately, we were unable to capture the error message for this message.',
185
-                        'event_espresso')
186
-                    : wp_kses(
187
-                        $error_msg,
188
-                        array(
189
-                            'a'      => array(
190
-                                'href'  => array(),
191
-                                'title' => array(),
192
-                            ),
193
-                            'span'   => array(),
194
-                            'div'    => array(),
195
-                            'p'      => array(),
196
-                            'strong' => array(),
197
-                            'em'     => array(),
198
-                            'br'     => array(),
199
-                        )
200
-                    ); ?>
184
+					? esc_html__('Unfortunately, we were unable to capture the error message for this message.',
185
+						'event_espresso')
186
+					: wp_kses(
187
+						$error_msg,
188
+						array(
189
+							'a'      => array(
190
+								'href'  => array(),
191
+								'title' => array(),
192
+							),
193
+							'span'   => array(),
194
+							'div'    => array(),
195
+							'p'      => array(),
196
+							'strong' => array(),
197
+							'em'     => array(),
198
+							'br'     => array(),
199
+						)
200
+					); ?>
201 201
                 </body>
202 202
                 </html>
203 203
                 <?php
204
-                exit;
205
-            }
206
-        }
207
-        return;
208
-    }
209
-
210
-
211
-    /**
212
-     *  This runs when the msg_url_trigger route has initiated.
213
-     *
214
-     * @since 4.5.0
215
-     * @param WP $WP
216
-     * @throws EE_Error
217
-     * @return    void
218
-     */
219
-    public function run($WP)
220
-    {
221
-        //ensure controller is loaded
222
-        self::_load_controller();
223
-        // attempt to process message
224
-        try {
225
-            /** @type EE_Message_To_Generate_From_Request $message_to_generate */
226
-            $message_to_generate = EE_Registry::instance()->load_lib('Message_To_Generate_From_Request');
227
-            self::$_MSG_PROCESSOR->generate_and_send_now($message_to_generate);
228
-        } catch (EE_Error $e) {
229
-            $error_msg = __('Please note that a system message failed to send due to a technical issue.',
230
-                'event_espresso');
231
-            // add specific message for developers if WP_DEBUG in on
232
-            $error_msg .= '||' . $e->getMessage();
233
-            EE_Error::add_error($error_msg, __FILE__, __FUNCTION__, __LINE__);
234
-        }
235
-    }
236
-
237
-
238
-    /**
239
-     * This is triggered by the 'msg_cron_trigger' route.
240
-     *
241
-     * @param WP $WP
242
-     */
243
-    public function execute_batch_request($WP)
244
-    {
245
-        $this->run_cron();
246
-        header('HTTP/1.1 200 OK');
247
-        exit();
248
-    }
249
-
250
-
251
-    /**
252
-     * This gets executed on wp_cron jobs or when a batch request is initiated on its own separate non regular wp
253
-     * request.
254
-     */
255
-    public function run_cron()
256
-    {
257
-        self::_load_controller();
258
-        //get required vars
259
-        $cron_type     = EE_Registry::instance()->REQ->get('type');
260
-        $transient_key = EE_Registry::instance()->REQ->get('key');
261
-
262
-        //now let's verify transient, if not valid exit immediately
263
-        if (! get_transient($transient_key)) {
264
-            /**
265
-             * trigger error so this gets in the error logs.  This is important because it happens on a non-user request.
266
-             */
267
-            trigger_error(esc_attr__('Invalid Request (Transient does not exist)', 'event_espresso'));
268
-        }
269
-
270
-        //if made it here, lets' delete the transient to keep the db clean
271
-        delete_transient($transient_key);
272
-
273
-        if (apply_filters('FHEE__EED_Messages__run_cron__use_wp_cron', true)) {
274
-
275
-            $method = 'batch_' . $cron_type . '_from_queue';
276
-            if (method_exists(self::$_MSG_PROCESSOR, $method)) {
277
-                self::$_MSG_PROCESSOR->$method();
278
-            } else {
279
-                //no matching task
280
-                /**
281
-                 * trigger error so this gets in the error logs.  This is important because it happens on a non user request.
282
-                 */
283
-                trigger_error(esc_attr(sprintf(__('There is no task corresponding to this route %s', 'event_espresso'),
284
-                    $cron_type)));
285
-            }
286
-        }
287
-
288
-        do_action('FHEE__EED_Messages__run_cron__end');
289
-    }
290
-
291
-
292
-    /**
293
-     * This is used to retrieve the template pack for the given name.
294
-     * Retrieved packs are cached on the static $_TMP_PACKS array.  If there is no class matching the given name then
295
-     * the default template pack is returned.
296
-     *
297
-     * @deprecated 4.9.0  @see EEH_MSG_Template::get_template_pack()
298
-     * @param string $template_pack_name This should correspond to the dbref of the template pack (which is also used
299
-     *                                   in generating the Pack class name).
300
-     * @return EE_Messages_Template_Pack
301
-     */
302
-    public static function get_template_pack($template_pack_name)
303
-    {
304
-        EE_Registry::instance()->load_helper('MSG_Template');
305
-        return EEH_MSG_Template::get_template_pack($template_pack_name);
306
-    }
307
-
308
-
309
-    /**
310
-     * Retrieves an array of all template packs.
311
-     * Array is in the format array( 'dbref' => EE_Messages_Template_Pack )
312
-     *
313
-     * @deprecated 4.9.0  @see EEH_MSG_Template_Pack::get_template_pack_collection
314
-     * @return EE_Messages_Template_Pack[]
315
-     */
316
-    public static function get_template_packs()
317
-    {
318
-        EE_Registry::instance()->load_helper('MSG_Template');
319
-
320
-        //for backward compat, let's make sure this returns in the same format as originally.
321
-        $template_pack_collection = EEH_MSG_Template::get_template_pack_collection();
322
-        $template_pack_collection->rewind();
323
-        $template_packs = array();
324
-        while ($template_pack_collection->valid()) {
325
-            $template_packs[$template_pack_collection->current()->dbref] = $template_pack_collection->current();
326
-            $template_pack_collection->next();
327
-        }
328
-        return $template_packs;
329
-    }
330
-
331
-
332
-    /**
333
-     * This simply makes sure the autoloaders are registered for the EE_messages system.
334
-     *
335
-     * @since 4.5.0
336
-     * @return void
337
-     */
338
-    public static function set_autoloaders()
339
-    {
340
-        if (empty(self::$_MSG_PATHS)) {
341
-            self::_set_messages_paths();
342
-            foreach (self::$_MSG_PATHS as $path) {
343
-                EEH_Autoloader::register_autoloaders_for_each_file_in_folder($path);
344
-            }
345
-            // add aliases
346
-            EEH_Autoloader::add_alias('EE_messages', 'EE_messages');
347
-            EEH_Autoloader::add_alias('EE_messenger', 'EE_messenger');
348
-        }
349
-    }
350
-
351
-
352
-    /**
353
-     * Take care of adding all the paths for the messages components to the $_MSG_PATHS property
354
-     * for use by the Messages Autoloaders
355
-     *
356
-     * @since 4.5.0
357
-     * @return void.
358
-     */
359
-    protected static function _set_messages_paths()
360
-    {
361
-        $dir_ref = array(
362
-            'messages/message_type',
363
-            'messages/messenger',
364
-            'messages/defaults',
365
-            'messages/defaults/email',
366
-            'messages/data_class',
367
-            'messages/validators',
368
-            'messages/validators/email',
369
-            'messages/validators/html',
370
-            'shortcodes',
371
-        );
372
-        $paths   = array();
373
-        foreach ($dir_ref as $index => $dir) {
374
-            $paths[$index] = EE_LIBRARIES . $dir;
375
-        }
376
-        self::$_MSG_PATHS = apply_filters('FHEE__EED_Messages___set_messages_paths___MSG_PATHS', $paths);
377
-    }
378
-
379
-
380
-    /**
381
-     * Takes care of loading dependencies
382
-     *
383
-     * @since 4.5.0
384
-     * @return void
385
-     */
386
-    protected static function _load_controller()
387
-    {
388
-        if (! self::$_MSG_PROCESSOR instanceof EE_Messages_Processor) {
389
-            EE_Registry::instance()->load_core('Request_Handler');
390
-            self::set_autoloaders();
391
-            self::$_EEMSG                    = EE_Registry::instance()->load_lib('messages');
392
-            self::$_MSG_PROCESSOR            = EE_Registry::instance()->load_lib('Messages_Processor');
393
-            self::$_message_resource_manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
394
-        }
395
-    }
396
-
397
-
398
-    /**
399
-     * @param EE_Transaction $transaction
400
-     */
401
-    public static function payment_reminder(EE_Transaction $transaction)
402
-    {
403
-        self::_load_controller();
404
-        $data = array($transaction, null);
405
-        self::$_MSG_PROCESSOR->generate_for_all_active_messengers('payment_reminder', $data);
406
-    }
407
-
408
-
409
-    /**
410
-     * Any messages triggers for after successful gateway payments should go in here.
411
-     *
412
-     * @param  EE_Transaction object
413
-     * @param  EE_Payment     object
414
-     * @return void
415
-     */
416
-    public static function payment(EE_Transaction $transaction, EE_Payment $payment)
417
-    {
418
-        self::_load_controller();
419
-        $data = array($transaction, $payment);
420
-        EE_Registry::instance()->load_helper('MSG_Template');
421
-        $message_type = EEH_MSG_Template::convert_payment_status_to_message_type($payment->STS_ID());
422
-        //if payment amount is less than 0 then switch to payment_refund message type.
423
-        $message_type = $payment->amount() < 0 ? 'payment_refund' : $message_type;
424
-        self::$_MSG_PROCESSOR->generate_for_all_active_messengers($message_type, $data);
425
-    }
426
-
427
-
428
-    /**
429
-     * @param EE_Transaction $transaction
430
-     */
431
-    public static function cancelled_registration(EE_Transaction $transaction)
432
-    {
433
-        self::_load_controller();
434
-        $data = array($transaction, null);
435
-        self::$_MSG_PROCESSOR->generate_for_all_active_messengers('cancelled_registration', $data);
436
-    }
437
-
438
-
439
-
440
-    /**
441
-     * Trigger for Registration messages
442
-     * Note that what registration message type is sent depends on what the reg status is for the registrations on the
443
-     * incoming transaction.
444
-     *
445
-     * @param EE_Registration $registration
446
-     * @param array           $extra_details
447
-     * @return void
448
-     * @throws EE_Error
449
-     * @throws EntityNotFoundException
450
-     */
451
-    public static function maybe_registration(EE_Registration $registration, $extra_details = array())
452
-    {
453
-
454
-        if (! self::_verify_registration_notification_send($registration, $extra_details)) {
455
-            //no messages please
456
-            return;
457
-        }
458
-
459
-        // get all non-trashed registrations so we make sure we send messages for the right status.
460
-        $all_registrations = $registration->transaction()->registrations(
461
-            array(
462
-                array('REG_deleted' => false),
463
-                'order_by' => array(
464
-                    'Event.EVT_name'     => 'ASC',
465
-                    'Attendee.ATT_lname' => 'ASC',
466
-                    'Attendee.ATT_fname' => 'ASC'
467
-                )
468
-            )
469
-        );
470
-        //cached array of statuses so we only trigger messages once per status.
471
-        $statuses_sent = array();
472
-        self::_load_controller();
473
-        $mtgs = array();
474
-
475
-        //loop through registrations and trigger messages once per status.
476
-        foreach ($all_registrations as $reg) {
477
-
478
-            //already triggered?
479
-            if (in_array($reg->status_ID(), $statuses_sent)) {
480
-                continue;
481
-            }
482
-
483
-            $message_type    = EEH_MSG_Template::convert_reg_status_to_message_type($reg->status_ID());
484
-            $mtgs            = array_merge(
485
-                    $mtgs,
486
-                    self::$_MSG_PROCESSOR->setup_mtgs_for_all_active_messengers(
487
-                            $message_type,
488
-                            array($registration->transaction(), null, $reg->status_ID())
489
-                    )
490
-            );
491
-            $statuses_sent[] = $reg->status_ID();
492
-        }
493
-
494
-        if (count($statuses_sent) > 1) {
495
-            $mtgs = array_merge(
496
-                $mtgs,
497
-                self::$_MSG_PROCESSOR->setup_mtgs_for_all_active_messengers(
498
-                    'registration_summary',
499
-                    array($registration->transaction(), null)
500
-                )
501
-            );
502
-        }
503
-
504
-        //batch queue and initiate request
505
-        self::$_MSG_PROCESSOR->batch_queue_for_generation_and_persist($mtgs);
506
-        self::$_MSG_PROCESSOR->get_queue()->initiate_request_by_priority();
507
-    }
508
-
509
-
510
-    /**
511
-     * This is a helper method used to very whether a registration notification should be sent or
512
-     * not.  Prevents duplicate notifications going out for registration context notifications.
513
-     *
514
-     * @param EE_Registration $registration  [description]
515
-     * @param array           $extra_details [description]
516
-     * @return bool          true = send away, false = nope halt the presses.
517
-     */
518
-    protected static function _verify_registration_notification_send(
519
-        EE_Registration $registration,
520
-        $extra_details = array()
521
-    ) {
522
-        //self::log(
523
-        //	__CLASS__, __FUNCTION__, __LINE__,
524
-        //	$registration->transaction(),
525
-        //	array( '$extra_details' => $extra_details )
526
-        //);
527
-        // currently only using this to send messages for the primary registrant
528
-        if (! $registration->is_primary_registrant()) {
529
-            return false;
530
-        }
531
-        // first we check if we're in admin and not doing front ajax
532
-        if (is_admin() && ! EE_FRONT_AJAX) {
533
-            //make sure appropriate admin params are set for sending messages
534
-            if (empty($_REQUEST['txn_reg_status_change']['send_notifications']) || ! absint($_REQUEST['txn_reg_status_change']['send_notifications'])) {
535
-                //no messages sent please.
536
-                return false;
537
-            }
538
-        } else {
539
-            // frontend request (either regular or via AJAX)
540
-            // TXN is NOT finalized ?
541
-            if (! isset($extra_details['finalized']) || $extra_details['finalized'] === false) {
542
-                return false;
543
-            }
544
-            // return visit but nothing changed ???
545
-            if (
546
-                isset($extra_details['revisit'], $extra_details['status_updates']) &&
547
-                $extra_details['revisit'] && ! $extra_details['status_updates']
548
-            ) {
549
-                return false;
550
-            }
551
-            // NOT sending messages && reg status is something other than "Not-Approved"
552
-            if (
553
-                ! apply_filters('FHEE__EED_Messages___maybe_registration__deliver_notifications', false) &&
554
-                $registration->status_ID() !== EEM_Registration::status_id_not_approved
555
-            ) {
556
-                return false;
557
-            }
558
-        }
559
-        // release the kraken
560
-        return true;
561
-    }
562
-
563
-
564
-    /**
565
-     * Simply returns an array indexed by Registration Status ID and the related message_type name associated with that
566
-     * status id.
567
-     *
568
-     * @deprecated 4.9.0  Use EEH_MSG_Template::reg_status_to_message_type_array()
569
-     *                    or EEH_MSG_Template::convert_reg_status_to_message_type
570
-     * @param string $reg_status
571
-     * @return array
572
-     */
573
-    protected static function _get_reg_status_array($reg_status = '')
574
-    {
575
-        EE_Registry::instance()->load_helper('MSG_Template');
576
-        return EEH_MSG_Template::convert_reg_status_to_message_type($reg_status)
577
-            ? EEH_MSG_Template::convert_reg_status_to_message_type($reg_status)
578
-            : EEH_MSG_Template::reg_status_to_message_type_array();
579
-    }
580
-
581
-
582
-    /**
583
-     * Simply returns the payment message type for the given payment status.
584
-     *
585
-     * @deprecated 4.9.0 Use EEH_MSG_Template::payment_status_to_message_type_array
586
-     *                   or EEH_MSG_Template::convert_payment_status_to_message_type
587
-     * @param string $payment_status The payment status being matched.
588
-     * @return string|bool The payment message type slug matching the status or false if no match.
589
-     */
590
-    protected static function _get_payment_message_type($payment_status)
591
-    {
592
-        EE_Registry::instance()->load_helper('MSG_Template');
593
-        return EEH_MSG_Template::convert_payment_status_to_message_type($payment_status)
594
-            ? EEH_MSG_Template::convert_payment_status_to_message_type($payment_status)
595
-            : false;
596
-    }
597
-
598
-
599
-    /**
600
-     * Message triggers for a resending already sent message(s) (via EE_Message list table)
601
-     *
602
-     * @access public
603
-     * @param array $req_data This is the $_POST & $_GET data sent from EE_Admin Pages
604
-     * @return bool          success/fail
605
-     */
606
-    public static function process_resend($req_data)
607
-    {
608
-        self::_load_controller();
609
-
610
-        //if $msgID in this request then skip to the new resend_message
611
-        if (EE_Registry::instance()->REQ->get('MSG_ID')) {
612
-            return self::resend_message();
613
-        }
614
-
615
-        //make sure any incoming request data is set on the REQ so that it gets picked up later.
616
-        $req_data = (array)$req_data;
617
-        foreach ($req_data as $request_key => $request_value) {
618
-            EE_Registry::instance()->REQ->set($request_key, $request_value);
619
-        }
620
-
621
-        if (! $messages_to_send = self::$_MSG_PROCESSOR->setup_messages_to_generate_from_registration_ids_in_request()) {
622
-            return false;
623
-        }
624
-
625
-        try {
626
-            self::$_MSG_PROCESSOR->batch_queue_for_generation_and_persist($messages_to_send);
627
-            self::$_MSG_PROCESSOR->get_queue()->initiate_request_by_priority();
628
-        } catch (EE_Error $e) {
629
-            EE_Error::add_error($e->getMessage(), __FILE__, __FUNCTION__, __LINE__);
630
-            return false;
631
-        }
632
-        EE_Error::add_success(
633
-            __('Messages have been successfully queued for generation and sending.', 'event_espresso')
634
-        );
635
-        return true; //everything got queued.
636
-    }
637
-
638
-
639
-    /**
640
-     * Message triggers for a resending already sent message(s) (via EE_Message list table)
641
-     *
642
-     * @return bool
643
-     */
644
-    public static function resend_message()
645
-    {
646
-        self::_load_controller();
647
-
648
-        $msgID = EE_Registry::instance()->REQ->get('MSG_ID');
649
-        if (! $msgID) {
650
-            EE_Error::add_error(__('Something went wrong because there is no "MSG_ID" value in the request',
651
-                'event_espresso'), __FILE__, __FUNCTION__, __LINE__);
652
-            return false;
653
-        }
654
-
655
-        self::$_MSG_PROCESSOR->setup_messages_from_ids_and_send((array)$msgID);
656
-
657
-        //setup success message.
658
-        $count_ready_for_resend = self::$_MSG_PROCESSOR->get_queue()->count_STS_in_queue(EEM_Message::status_resend);
659
-        EE_Error::add_success(sprintf(
660
-            _n(
661
-                'There was %d message queued for resending.',
662
-                'There were %d messages queued for resending.',
663
-                $count_ready_for_resend,
664
-                'event_espresso'
665
-            ),
666
-            $count_ready_for_resend
667
-        ));
668
-        return true;
669
-    }
670
-
671
-
672
-    /**
673
-     * Message triggers for manual payment applied by admin
674
-     *
675
-     * @param  EE_Payment $payment EE_payment object
676
-     * @return bool              success/fail
677
-     */
678
-    public static function process_admin_payment(EE_Payment $payment)
679
-    {
680
-        EE_Registry::instance()->load_helper('MSG_Template');
681
-        //we need to get the transaction object
682
-        $transaction = $payment->transaction();
683
-        if ($transaction instanceof EE_Transaction) {
684
-            $data         = array($transaction, $payment);
685
-            $message_type = EEH_MSG_Template::convert_payment_status_to_message_type($payment->STS_ID());
686
-
687
-            //if payment amount is less than 0 then switch to payment_refund message type.
688
-            $message_type = $payment->amount() < 0 ? 'payment_refund' : $message_type;
689
-
690
-            //if payment_refund is selected, but the status is NOT accepted.  Then change message type to false so NO message notification goes out.
691
-            $message_type = $message_type == 'payment_refund' && $payment->STS_ID() != EEM_Payment::status_id_approved ? false : $message_type;
692
-
693
-            self::_load_controller();
694
-
695
-            self::$_MSG_PROCESSOR->generate_for_all_active_messengers($message_type, $data);
696
-
697
-            //get count of queued for generation
698
-            $count_to_generate = self::$_MSG_PROCESSOR->get_queue()->count_STS_in_queue(array(
699
-                EEM_Message::status_incomplete,
700
-                EEM_Message::status_idle,
701
-            ));
702
-
703
-            if ($count_to_generate > 0 && self::$_MSG_PROCESSOR->get_queue()->get_message_repository()->count() !== 0) {
704
-                add_filter('FHEE__EE_Admin_Page___process_admin_payment_notification__success', '__return_true');
705
-                return true;
706
-            } else {
707
-                $count_failed = self::$_MSG_PROCESSOR->get_queue()->count_STS_in_queue(EEM_Message::instance()->stati_indicating_failed_sending());
708
-                /**
709
-                 * Verify that there are actually errors.  If not then we return a success message because the queue might have been emptied due to successful
710
-                 * IMMEDIATE generation.
711
-                 */
712
-                if ($count_failed > 0) {
713
-                    EE_Error::add_error(sprintf(
714
-                        _n(
715
-                            'The payment notification generation failed.',
716
-                            '%d payment notifications failed being sent.',
717
-                            $count_failed,
718
-                            'event_espresso'
719
-                        ),
720
-                        $count_failed
721
-                    ), __FILE__, __FUNCTION__, __LINE__);
722
-
723
-                    return false;
724
-                } else {
725
-                    add_filter('FHEE__EE_Admin_Page___process_admin_payment_notification__success', '__return_true');
726
-                    return true;
727
-                }
728
-            }
729
-        } else {
730
-            EE_Error::add_error(
731
-                'Unable to generate the payment notification because the given value for the transaction is invalid.',
732
-                'event_espresso'
733
-            );
734
-            return false;
735
-        }
736
-    }
737
-
738
-
739
-    /**
740
-     * Callback for AHEE__Extend_Registrations_Admin_Page___newsletter_selected_send_with_registrations trigger
741
-     *
742
-     * @since   4.3.0
743
-     * @param  EE_Registration[] $registrations an array of EE_Registration objects
744
-     * @param  int               $grp_id        a specific message template group id.
745
-     * @return void
746
-     */
747
-    public static function send_newsletter_message($registrations, $grp_id)
748
-    {
749
-        //make sure mtp is id and set it in the EE_Request Handler later messages setup.
750
-        EE_Registry::instance()->REQ->set('GRP_ID', (int)$grp_id);
751
-        self::_load_controller();
752
-        self::$_MSG_PROCESSOR->generate_for_all_active_messengers('newsletter', $registrations);
753
-    }
754
-
755
-
756
-    /**
757
-     * Callback for FHEE__EE_Registration__invoice_url__invoice_url or FHEE__EE_Registration__receipt_url__receipt_url
758
-     *
759
-     * @since   4.3.0
760
-     * @param    string          $registration_message_trigger_url
761
-     * @param    EE_Registration $registration
762
-     * @param string             $messenger
763
-     * @param string             $message_type
764
-     * @return    string
765
-     */
766
-    public static function registration_message_trigger_url(
767
-        $registration_message_trigger_url,
768
-        EE_Registration $registration,
769
-        $messenger = 'html',
770
-        $message_type = 'invoice'
771
-    ) {
772
-        // whitelist $messenger
773
-        switch ($messenger) {
774
-            case 'pdf' :
775
-                $sending_messenger    = 'pdf';
776
-                $generating_messenger = 'html';
777
-                break;
778
-            case 'html' :
779
-            default :
780
-                $sending_messenger    = 'html';
781
-                $generating_messenger = 'html';
782
-                break;
783
-        }
784
-        // whitelist $message_type
785
-        switch ($message_type) {
786
-            case 'receipt' :
787
-                $message_type = 'receipt';
788
-                break;
789
-            case 'invoice' :
790
-            default :
791
-                $message_type = 'invoice';
792
-                break;
793
-        }
794
-        // verify that both the messenger AND the message type are active
795
-        if (EEH_MSG_Template::is_messenger_active($sending_messenger) && EEH_MSG_Template::is_mt_active($message_type)) {
796
-            //need to get the correct message template group for this (i.e. is there a custom invoice for the event this registration is registered for?)
797
-            $template_query_params = array(
798
-                'MTP_is_active'    => true,
799
-                'MTP_messenger'    => $generating_messenger,
800
-                'MTP_message_type' => $message_type,
801
-                'Event.EVT_ID'     => $registration->event_ID(),
802
-            );
803
-            //get the message template group.
804
-            $msg_template_group = EEM_Message_Template_Group::instance()->get_one(array($template_query_params));
805
-            //if we don't have an EE_Message_Template_Group then return
806
-            if (! $msg_template_group instanceof EE_Message_Template_Group) {
807
-                // remove EVT_ID from query params so that global templates get picked up
808
-                unset($template_query_params['Event.EVT_ID']);
809
-                //get global template as the fallback
810
-                $msg_template_group = EEM_Message_Template_Group::instance()->get_one(array($template_query_params));
811
-            }
812
-            //if we don't have an EE_Message_Template_Group then return
813
-            if (! $msg_template_group instanceof EE_Message_Template_Group) {
814
-                return '';
815
-            }
816
-            // generate the URL
817
-            $registration_message_trigger_url = EEH_MSG_Template::generate_url_trigger(
818
-                $sending_messenger,
819
-                $generating_messenger,
820
-                'purchaser',
821
-                $message_type,
822
-                $registration,
823
-                $msg_template_group->ID(),
824
-                $registration->transaction_ID()
825
-            );
826
-
827
-        }
828
-        return $registration_message_trigger_url;
829
-    }
830
-
831
-
832
-    /**
833
-     * Use to generate and return a message preview!
834
-     *
835
-     * @param  string $type      This should correspond with a valid message type
836
-     * @param  string $context   This should correspond with a valid context for the message type
837
-     * @param  string $messenger This should correspond with a valid messenger.
838
-     * @param bool    $send      true we will do a test send using the messenger delivery, false we just do a regular
839
-     *                           preview
840
-     * @return bool|string The body of the message or if send is requested, sends.
841
-     * @throws EE_Error
842
-     */
843
-    public static function preview_message($type, $context, $messenger, $send = false)
844
-    {
845
-        self::_load_controller();
846
-        $mtg                     = new EE_Message_To_Generate(
847
-            $messenger,
848
-            $type,
849
-            array(),
850
-            $context,
851
-            true
852
-        );
853
-        $generated_preview_queue = self::$_MSG_PROCESSOR->generate_for_preview($mtg, $send);
854
-        if ($generated_preview_queue instanceof EE_Messages_Queue) {
855
-            //loop through all content for the preview and remove any persisted records.
856
-            $content = '';
857
-            foreach ($generated_preview_queue->get_message_repository() as $message) {
858
-                $content = $message->content();
859
-                if ($message->ID() > 0 && $message->STS_ID() !== EEM_Message::status_failed) {
860
-                    $message->delete();
861
-                }
862
-            }
863
-            return $content;
864
-        } else {
865
-            return $generated_preview_queue;
866
-        }
867
-    }
868
-
869
-
870
-    /**
871
-     * This is a method that allows for sending a message using a messenger matching the string given and the provided
872
-     * EE_Message_Queue object.  The EE_Message_Queue object is used to create a single aggregate EE_Message via the
873
-     * content found in the EE_Message objects in the queue.
874
-     *
875
-     * @since 4.9.0
876
-     * @param string            $messenger            a string matching a valid active messenger in the system
877
-     * @param string            $message_type         Although it seems contrary to the name of the method, a message
878
-     *                                                type name is still required to send along the message type to the
879
-     *                                                messenger because this is used for determining what specific
880
-     *                                                variations might be loaded for the generated message.
881
-     * @param EE_Messages_Queue $queue
882
-     * @param string            $custom_subject       Can be used to set what the custom subject string will be on the
883
-     *                                                aggregate EE_Message object.
884
-     * @return bool          success or fail.
885
-     */
886
-    public static function send_message_with_messenger_only(
887
-        $messenger,
888
-        $message_type,
889
-        EE_Messages_Queue $queue,
890
-        $custom_subject = ''
891
-    ) {
892
-        self::_load_controller();
893
-        /** @type EE_Message_To_Generate_From_Queue $message_to_generate */
894
-        $message_to_generate = EE_Registry::instance()->load_lib(
895
-            'Message_To_Generate_From_Queue',
896
-            array(
897
-                $messenger,
898
-                $message_type,
899
-                $queue,
900
-                $custom_subject,
901
-            )
902
-        );
903
-        return self::$_MSG_PROCESSOR->queue_for_sending($message_to_generate);
904
-    }
905
-
906
-
907
-    /**
908
-     * Generates Messages immediately for EE_Message IDs (but only for the correct status for generation)
909
-     *
910
-     * @since 4.9.0
911
-     * @param array $message_ids An array of message ids
912
-     * @return bool | EE_Messages_Queue     false if nothing was generated, EE_Messages_Queue containing generated
913
-     *              messages.
914
-     */
915
-    public static function generate_now($message_ids)
916
-    {
917
-        self::_load_controller();
918
-        $messages        = EEM_Message::instance()->get_all(
919
-            array(
920
-                0 => array(
921
-                    'MSG_ID' => array('IN', $message_ids),
922
-                    'STS_ID' => EEM_Message::status_incomplete,
923
-                ),
924
-            )
925
-        );
926
-        $generated_queue = false;
927
-        if ($messages) {
928
-            $generated_queue = self::$_MSG_PROCESSOR->batch_generate_from_queue($messages);
929
-        }
930
-
931
-        if (! $generated_queue instanceof EE_Messages_Queue) {
932
-            EE_Error::add_error(
933
-                __('The messages were not generated. This could mean there is already a batch being generated on a separate request, or because the selected messages are not ready for generation. Please wait a minute or two and try again.',
934
-                    'event_espresso'),
935
-                __FILE__, __FUNCTION__, __LINE__
936
-            );
937
-        }
938
-        return $generated_queue;
939
-    }
940
-
941
-
942
-    /**
943
-     * Sends messages immediately for the incoming message_ids that have the status of EEM_Message::status_resend or,
944
-     * EEM_Message::status_idle
945
-     *
946
-     * @since 4.9.0
947
-     * @param $message_ids
948
-     * @return bool | EE_Messages_Queue  false if no messages sent.
949
-     */
950
-    public static function send_now($message_ids)
951
-    {
952
-        self::_load_controller();
953
-        $messages   = EEM_Message::instance()->get_all(
954
-            array(
955
-                0 => array(
956
-                    'MSG_ID' => array('IN', $message_ids),
957
-                    'STS_ID' => array(
958
-                        'IN',
959
-                        array(EEM_Message::status_idle, EEM_Message::status_resend, EEM_Message::status_retry),
960
-                    ),
961
-                ),
962
-            )
963
-        );
964
-        $sent_queue = false;
965
-        if ($messages) {
966
-            $sent_queue = self::$_MSG_PROCESSOR->batch_send_from_queue($messages);
967
-        }
968
-
969
-        if (! $sent_queue instanceof EE_Messages_Queue) {
970
-            EE_Error::add_error(
971
-                __('The messages were not sent. This could mean there is already a batch being sent on a separate request, or because the selected messages are not sendable. Please wait a minute or two and try again.',
972
-                    'event_espresso'),
973
-                __FILE__, __FUNCTION__, __LINE__
974
-            );
975
-        } else {
976
-            //can count how many sent by using the messages in the queue
977
-            $sent_count = $sent_queue->count_STS_in_queue(EEM_Message::instance()->stati_indicating_sent());
978
-            if ($sent_count > 0) {
979
-                EE_Error::add_success(
980
-                    sprintf(
981
-                        _n(
982
-                            'There was %d message successfully sent.',
983
-                            'There were %d messages successfully sent.',
984
-                            $sent_count,
985
-                            'event_espresso'
986
-                        ),
987
-                        $sent_count
988
-                    )
989
-                );
990
-            } else {
991
-                EE_Error::overwrite_errors();
992
-                EE_Error::add_error(
993
-                    __('No message was sent because of problems with sending. Either all the messages you selected were not a sendable message, they were ALREADY sent on a different scheduled task, or there was an error.
204
+				exit;
205
+			}
206
+		}
207
+		return;
208
+	}
209
+
210
+
211
+	/**
212
+	 *  This runs when the msg_url_trigger route has initiated.
213
+	 *
214
+	 * @since 4.5.0
215
+	 * @param WP $WP
216
+	 * @throws EE_Error
217
+	 * @return    void
218
+	 */
219
+	public function run($WP)
220
+	{
221
+		//ensure controller is loaded
222
+		self::_load_controller();
223
+		// attempt to process message
224
+		try {
225
+			/** @type EE_Message_To_Generate_From_Request $message_to_generate */
226
+			$message_to_generate = EE_Registry::instance()->load_lib('Message_To_Generate_From_Request');
227
+			self::$_MSG_PROCESSOR->generate_and_send_now($message_to_generate);
228
+		} catch (EE_Error $e) {
229
+			$error_msg = __('Please note that a system message failed to send due to a technical issue.',
230
+				'event_espresso');
231
+			// add specific message for developers if WP_DEBUG in on
232
+			$error_msg .= '||' . $e->getMessage();
233
+			EE_Error::add_error($error_msg, __FILE__, __FUNCTION__, __LINE__);
234
+		}
235
+	}
236
+
237
+
238
+	/**
239
+	 * This is triggered by the 'msg_cron_trigger' route.
240
+	 *
241
+	 * @param WP $WP
242
+	 */
243
+	public function execute_batch_request($WP)
244
+	{
245
+		$this->run_cron();
246
+		header('HTTP/1.1 200 OK');
247
+		exit();
248
+	}
249
+
250
+
251
+	/**
252
+	 * This gets executed on wp_cron jobs or when a batch request is initiated on its own separate non regular wp
253
+	 * request.
254
+	 */
255
+	public function run_cron()
256
+	{
257
+		self::_load_controller();
258
+		//get required vars
259
+		$cron_type     = EE_Registry::instance()->REQ->get('type');
260
+		$transient_key = EE_Registry::instance()->REQ->get('key');
261
+
262
+		//now let's verify transient, if not valid exit immediately
263
+		if (! get_transient($transient_key)) {
264
+			/**
265
+			 * trigger error so this gets in the error logs.  This is important because it happens on a non-user request.
266
+			 */
267
+			trigger_error(esc_attr__('Invalid Request (Transient does not exist)', 'event_espresso'));
268
+		}
269
+
270
+		//if made it here, lets' delete the transient to keep the db clean
271
+		delete_transient($transient_key);
272
+
273
+		if (apply_filters('FHEE__EED_Messages__run_cron__use_wp_cron', true)) {
274
+
275
+			$method = 'batch_' . $cron_type . '_from_queue';
276
+			if (method_exists(self::$_MSG_PROCESSOR, $method)) {
277
+				self::$_MSG_PROCESSOR->$method();
278
+			} else {
279
+				//no matching task
280
+				/**
281
+				 * trigger error so this gets in the error logs.  This is important because it happens on a non user request.
282
+				 */
283
+				trigger_error(esc_attr(sprintf(__('There is no task corresponding to this route %s', 'event_espresso'),
284
+					$cron_type)));
285
+			}
286
+		}
287
+
288
+		do_action('FHEE__EED_Messages__run_cron__end');
289
+	}
290
+
291
+
292
+	/**
293
+	 * This is used to retrieve the template pack for the given name.
294
+	 * Retrieved packs are cached on the static $_TMP_PACKS array.  If there is no class matching the given name then
295
+	 * the default template pack is returned.
296
+	 *
297
+	 * @deprecated 4.9.0  @see EEH_MSG_Template::get_template_pack()
298
+	 * @param string $template_pack_name This should correspond to the dbref of the template pack (which is also used
299
+	 *                                   in generating the Pack class name).
300
+	 * @return EE_Messages_Template_Pack
301
+	 */
302
+	public static function get_template_pack($template_pack_name)
303
+	{
304
+		EE_Registry::instance()->load_helper('MSG_Template');
305
+		return EEH_MSG_Template::get_template_pack($template_pack_name);
306
+	}
307
+
308
+
309
+	/**
310
+	 * Retrieves an array of all template packs.
311
+	 * Array is in the format array( 'dbref' => EE_Messages_Template_Pack )
312
+	 *
313
+	 * @deprecated 4.9.0  @see EEH_MSG_Template_Pack::get_template_pack_collection
314
+	 * @return EE_Messages_Template_Pack[]
315
+	 */
316
+	public static function get_template_packs()
317
+	{
318
+		EE_Registry::instance()->load_helper('MSG_Template');
319
+
320
+		//for backward compat, let's make sure this returns in the same format as originally.
321
+		$template_pack_collection = EEH_MSG_Template::get_template_pack_collection();
322
+		$template_pack_collection->rewind();
323
+		$template_packs = array();
324
+		while ($template_pack_collection->valid()) {
325
+			$template_packs[$template_pack_collection->current()->dbref] = $template_pack_collection->current();
326
+			$template_pack_collection->next();
327
+		}
328
+		return $template_packs;
329
+	}
330
+
331
+
332
+	/**
333
+	 * This simply makes sure the autoloaders are registered for the EE_messages system.
334
+	 *
335
+	 * @since 4.5.0
336
+	 * @return void
337
+	 */
338
+	public static function set_autoloaders()
339
+	{
340
+		if (empty(self::$_MSG_PATHS)) {
341
+			self::_set_messages_paths();
342
+			foreach (self::$_MSG_PATHS as $path) {
343
+				EEH_Autoloader::register_autoloaders_for_each_file_in_folder($path);
344
+			}
345
+			// add aliases
346
+			EEH_Autoloader::add_alias('EE_messages', 'EE_messages');
347
+			EEH_Autoloader::add_alias('EE_messenger', 'EE_messenger');
348
+		}
349
+	}
350
+
351
+
352
+	/**
353
+	 * Take care of adding all the paths for the messages components to the $_MSG_PATHS property
354
+	 * for use by the Messages Autoloaders
355
+	 *
356
+	 * @since 4.5.0
357
+	 * @return void.
358
+	 */
359
+	protected static function _set_messages_paths()
360
+	{
361
+		$dir_ref = array(
362
+			'messages/message_type',
363
+			'messages/messenger',
364
+			'messages/defaults',
365
+			'messages/defaults/email',
366
+			'messages/data_class',
367
+			'messages/validators',
368
+			'messages/validators/email',
369
+			'messages/validators/html',
370
+			'shortcodes',
371
+		);
372
+		$paths   = array();
373
+		foreach ($dir_ref as $index => $dir) {
374
+			$paths[$index] = EE_LIBRARIES . $dir;
375
+		}
376
+		self::$_MSG_PATHS = apply_filters('FHEE__EED_Messages___set_messages_paths___MSG_PATHS', $paths);
377
+	}
378
+
379
+
380
+	/**
381
+	 * Takes care of loading dependencies
382
+	 *
383
+	 * @since 4.5.0
384
+	 * @return void
385
+	 */
386
+	protected static function _load_controller()
387
+	{
388
+		if (! self::$_MSG_PROCESSOR instanceof EE_Messages_Processor) {
389
+			EE_Registry::instance()->load_core('Request_Handler');
390
+			self::set_autoloaders();
391
+			self::$_EEMSG                    = EE_Registry::instance()->load_lib('messages');
392
+			self::$_MSG_PROCESSOR            = EE_Registry::instance()->load_lib('Messages_Processor');
393
+			self::$_message_resource_manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
394
+		}
395
+	}
396
+
397
+
398
+	/**
399
+	 * @param EE_Transaction $transaction
400
+	 */
401
+	public static function payment_reminder(EE_Transaction $transaction)
402
+	{
403
+		self::_load_controller();
404
+		$data = array($transaction, null);
405
+		self::$_MSG_PROCESSOR->generate_for_all_active_messengers('payment_reminder', $data);
406
+	}
407
+
408
+
409
+	/**
410
+	 * Any messages triggers for after successful gateway payments should go in here.
411
+	 *
412
+	 * @param  EE_Transaction object
413
+	 * @param  EE_Payment     object
414
+	 * @return void
415
+	 */
416
+	public static function payment(EE_Transaction $transaction, EE_Payment $payment)
417
+	{
418
+		self::_load_controller();
419
+		$data = array($transaction, $payment);
420
+		EE_Registry::instance()->load_helper('MSG_Template');
421
+		$message_type = EEH_MSG_Template::convert_payment_status_to_message_type($payment->STS_ID());
422
+		//if payment amount is less than 0 then switch to payment_refund message type.
423
+		$message_type = $payment->amount() < 0 ? 'payment_refund' : $message_type;
424
+		self::$_MSG_PROCESSOR->generate_for_all_active_messengers($message_type, $data);
425
+	}
426
+
427
+
428
+	/**
429
+	 * @param EE_Transaction $transaction
430
+	 */
431
+	public static function cancelled_registration(EE_Transaction $transaction)
432
+	{
433
+		self::_load_controller();
434
+		$data = array($transaction, null);
435
+		self::$_MSG_PROCESSOR->generate_for_all_active_messengers('cancelled_registration', $data);
436
+	}
437
+
438
+
439
+
440
+	/**
441
+	 * Trigger for Registration messages
442
+	 * Note that what registration message type is sent depends on what the reg status is for the registrations on the
443
+	 * incoming transaction.
444
+	 *
445
+	 * @param EE_Registration $registration
446
+	 * @param array           $extra_details
447
+	 * @return void
448
+	 * @throws EE_Error
449
+	 * @throws EntityNotFoundException
450
+	 */
451
+	public static function maybe_registration(EE_Registration $registration, $extra_details = array())
452
+	{
453
+
454
+		if (! self::_verify_registration_notification_send($registration, $extra_details)) {
455
+			//no messages please
456
+			return;
457
+		}
458
+
459
+		// get all non-trashed registrations so we make sure we send messages for the right status.
460
+		$all_registrations = $registration->transaction()->registrations(
461
+			array(
462
+				array('REG_deleted' => false),
463
+				'order_by' => array(
464
+					'Event.EVT_name'     => 'ASC',
465
+					'Attendee.ATT_lname' => 'ASC',
466
+					'Attendee.ATT_fname' => 'ASC'
467
+				)
468
+			)
469
+		);
470
+		//cached array of statuses so we only trigger messages once per status.
471
+		$statuses_sent = array();
472
+		self::_load_controller();
473
+		$mtgs = array();
474
+
475
+		//loop through registrations and trigger messages once per status.
476
+		foreach ($all_registrations as $reg) {
477
+
478
+			//already triggered?
479
+			if (in_array($reg->status_ID(), $statuses_sent)) {
480
+				continue;
481
+			}
482
+
483
+			$message_type    = EEH_MSG_Template::convert_reg_status_to_message_type($reg->status_ID());
484
+			$mtgs            = array_merge(
485
+					$mtgs,
486
+					self::$_MSG_PROCESSOR->setup_mtgs_for_all_active_messengers(
487
+							$message_type,
488
+							array($registration->transaction(), null, $reg->status_ID())
489
+					)
490
+			);
491
+			$statuses_sent[] = $reg->status_ID();
492
+		}
493
+
494
+		if (count($statuses_sent) > 1) {
495
+			$mtgs = array_merge(
496
+				$mtgs,
497
+				self::$_MSG_PROCESSOR->setup_mtgs_for_all_active_messengers(
498
+					'registration_summary',
499
+					array($registration->transaction(), null)
500
+				)
501
+			);
502
+		}
503
+
504
+		//batch queue and initiate request
505
+		self::$_MSG_PROCESSOR->batch_queue_for_generation_and_persist($mtgs);
506
+		self::$_MSG_PROCESSOR->get_queue()->initiate_request_by_priority();
507
+	}
508
+
509
+
510
+	/**
511
+	 * This is a helper method used to very whether a registration notification should be sent or
512
+	 * not.  Prevents duplicate notifications going out for registration context notifications.
513
+	 *
514
+	 * @param EE_Registration $registration  [description]
515
+	 * @param array           $extra_details [description]
516
+	 * @return bool          true = send away, false = nope halt the presses.
517
+	 */
518
+	protected static function _verify_registration_notification_send(
519
+		EE_Registration $registration,
520
+		$extra_details = array()
521
+	) {
522
+		//self::log(
523
+		//	__CLASS__, __FUNCTION__, __LINE__,
524
+		//	$registration->transaction(),
525
+		//	array( '$extra_details' => $extra_details )
526
+		//);
527
+		// currently only using this to send messages for the primary registrant
528
+		if (! $registration->is_primary_registrant()) {
529
+			return false;
530
+		}
531
+		// first we check if we're in admin and not doing front ajax
532
+		if (is_admin() && ! EE_FRONT_AJAX) {
533
+			//make sure appropriate admin params are set for sending messages
534
+			if (empty($_REQUEST['txn_reg_status_change']['send_notifications']) || ! absint($_REQUEST['txn_reg_status_change']['send_notifications'])) {
535
+				//no messages sent please.
536
+				return false;
537
+			}
538
+		} else {
539
+			// frontend request (either regular or via AJAX)
540
+			// TXN is NOT finalized ?
541
+			if (! isset($extra_details['finalized']) || $extra_details['finalized'] === false) {
542
+				return false;
543
+			}
544
+			// return visit but nothing changed ???
545
+			if (
546
+				isset($extra_details['revisit'], $extra_details['status_updates']) &&
547
+				$extra_details['revisit'] && ! $extra_details['status_updates']
548
+			) {
549
+				return false;
550
+			}
551
+			// NOT sending messages && reg status is something other than "Not-Approved"
552
+			if (
553
+				! apply_filters('FHEE__EED_Messages___maybe_registration__deliver_notifications', false) &&
554
+				$registration->status_ID() !== EEM_Registration::status_id_not_approved
555
+			) {
556
+				return false;
557
+			}
558
+		}
559
+		// release the kraken
560
+		return true;
561
+	}
562
+
563
+
564
+	/**
565
+	 * Simply returns an array indexed by Registration Status ID and the related message_type name associated with that
566
+	 * status id.
567
+	 *
568
+	 * @deprecated 4.9.0  Use EEH_MSG_Template::reg_status_to_message_type_array()
569
+	 *                    or EEH_MSG_Template::convert_reg_status_to_message_type
570
+	 * @param string $reg_status
571
+	 * @return array
572
+	 */
573
+	protected static function _get_reg_status_array($reg_status = '')
574
+	{
575
+		EE_Registry::instance()->load_helper('MSG_Template');
576
+		return EEH_MSG_Template::convert_reg_status_to_message_type($reg_status)
577
+			? EEH_MSG_Template::convert_reg_status_to_message_type($reg_status)
578
+			: EEH_MSG_Template::reg_status_to_message_type_array();
579
+	}
580
+
581
+
582
+	/**
583
+	 * Simply returns the payment message type for the given payment status.
584
+	 *
585
+	 * @deprecated 4.9.0 Use EEH_MSG_Template::payment_status_to_message_type_array
586
+	 *                   or EEH_MSG_Template::convert_payment_status_to_message_type
587
+	 * @param string $payment_status The payment status being matched.
588
+	 * @return string|bool The payment message type slug matching the status or false if no match.
589
+	 */
590
+	protected static function _get_payment_message_type($payment_status)
591
+	{
592
+		EE_Registry::instance()->load_helper('MSG_Template');
593
+		return EEH_MSG_Template::convert_payment_status_to_message_type($payment_status)
594
+			? EEH_MSG_Template::convert_payment_status_to_message_type($payment_status)
595
+			: false;
596
+	}
597
+
598
+
599
+	/**
600
+	 * Message triggers for a resending already sent message(s) (via EE_Message list table)
601
+	 *
602
+	 * @access public
603
+	 * @param array $req_data This is the $_POST & $_GET data sent from EE_Admin Pages
604
+	 * @return bool          success/fail
605
+	 */
606
+	public static function process_resend($req_data)
607
+	{
608
+		self::_load_controller();
609
+
610
+		//if $msgID in this request then skip to the new resend_message
611
+		if (EE_Registry::instance()->REQ->get('MSG_ID')) {
612
+			return self::resend_message();
613
+		}
614
+
615
+		//make sure any incoming request data is set on the REQ so that it gets picked up later.
616
+		$req_data = (array)$req_data;
617
+		foreach ($req_data as $request_key => $request_value) {
618
+			EE_Registry::instance()->REQ->set($request_key, $request_value);
619
+		}
620
+
621
+		if (! $messages_to_send = self::$_MSG_PROCESSOR->setup_messages_to_generate_from_registration_ids_in_request()) {
622
+			return false;
623
+		}
624
+
625
+		try {
626
+			self::$_MSG_PROCESSOR->batch_queue_for_generation_and_persist($messages_to_send);
627
+			self::$_MSG_PROCESSOR->get_queue()->initiate_request_by_priority();
628
+		} catch (EE_Error $e) {
629
+			EE_Error::add_error($e->getMessage(), __FILE__, __FUNCTION__, __LINE__);
630
+			return false;
631
+		}
632
+		EE_Error::add_success(
633
+			__('Messages have been successfully queued for generation and sending.', 'event_espresso')
634
+		);
635
+		return true; //everything got queued.
636
+	}
637
+
638
+
639
+	/**
640
+	 * Message triggers for a resending already sent message(s) (via EE_Message list table)
641
+	 *
642
+	 * @return bool
643
+	 */
644
+	public static function resend_message()
645
+	{
646
+		self::_load_controller();
647
+
648
+		$msgID = EE_Registry::instance()->REQ->get('MSG_ID');
649
+		if (! $msgID) {
650
+			EE_Error::add_error(__('Something went wrong because there is no "MSG_ID" value in the request',
651
+				'event_espresso'), __FILE__, __FUNCTION__, __LINE__);
652
+			return false;
653
+		}
654
+
655
+		self::$_MSG_PROCESSOR->setup_messages_from_ids_and_send((array)$msgID);
656
+
657
+		//setup success message.
658
+		$count_ready_for_resend = self::$_MSG_PROCESSOR->get_queue()->count_STS_in_queue(EEM_Message::status_resend);
659
+		EE_Error::add_success(sprintf(
660
+			_n(
661
+				'There was %d message queued for resending.',
662
+				'There were %d messages queued for resending.',
663
+				$count_ready_for_resend,
664
+				'event_espresso'
665
+			),
666
+			$count_ready_for_resend
667
+		));
668
+		return true;
669
+	}
670
+
671
+
672
+	/**
673
+	 * Message triggers for manual payment applied by admin
674
+	 *
675
+	 * @param  EE_Payment $payment EE_payment object
676
+	 * @return bool              success/fail
677
+	 */
678
+	public static function process_admin_payment(EE_Payment $payment)
679
+	{
680
+		EE_Registry::instance()->load_helper('MSG_Template');
681
+		//we need to get the transaction object
682
+		$transaction = $payment->transaction();
683
+		if ($transaction instanceof EE_Transaction) {
684
+			$data         = array($transaction, $payment);
685
+			$message_type = EEH_MSG_Template::convert_payment_status_to_message_type($payment->STS_ID());
686
+
687
+			//if payment amount is less than 0 then switch to payment_refund message type.
688
+			$message_type = $payment->amount() < 0 ? 'payment_refund' : $message_type;
689
+
690
+			//if payment_refund is selected, but the status is NOT accepted.  Then change message type to false so NO message notification goes out.
691
+			$message_type = $message_type == 'payment_refund' && $payment->STS_ID() != EEM_Payment::status_id_approved ? false : $message_type;
692
+
693
+			self::_load_controller();
694
+
695
+			self::$_MSG_PROCESSOR->generate_for_all_active_messengers($message_type, $data);
696
+
697
+			//get count of queued for generation
698
+			$count_to_generate = self::$_MSG_PROCESSOR->get_queue()->count_STS_in_queue(array(
699
+				EEM_Message::status_incomplete,
700
+				EEM_Message::status_idle,
701
+			));
702
+
703
+			if ($count_to_generate > 0 && self::$_MSG_PROCESSOR->get_queue()->get_message_repository()->count() !== 0) {
704
+				add_filter('FHEE__EE_Admin_Page___process_admin_payment_notification__success', '__return_true');
705
+				return true;
706
+			} else {
707
+				$count_failed = self::$_MSG_PROCESSOR->get_queue()->count_STS_in_queue(EEM_Message::instance()->stati_indicating_failed_sending());
708
+				/**
709
+				 * Verify that there are actually errors.  If not then we return a success message because the queue might have been emptied due to successful
710
+				 * IMMEDIATE generation.
711
+				 */
712
+				if ($count_failed > 0) {
713
+					EE_Error::add_error(sprintf(
714
+						_n(
715
+							'The payment notification generation failed.',
716
+							'%d payment notifications failed being sent.',
717
+							$count_failed,
718
+							'event_espresso'
719
+						),
720
+						$count_failed
721
+					), __FILE__, __FUNCTION__, __LINE__);
722
+
723
+					return false;
724
+				} else {
725
+					add_filter('FHEE__EE_Admin_Page___process_admin_payment_notification__success', '__return_true');
726
+					return true;
727
+				}
728
+			}
729
+		} else {
730
+			EE_Error::add_error(
731
+				'Unable to generate the payment notification because the given value for the transaction is invalid.',
732
+				'event_espresso'
733
+			);
734
+			return false;
735
+		}
736
+	}
737
+
738
+
739
+	/**
740
+	 * Callback for AHEE__Extend_Registrations_Admin_Page___newsletter_selected_send_with_registrations trigger
741
+	 *
742
+	 * @since   4.3.0
743
+	 * @param  EE_Registration[] $registrations an array of EE_Registration objects
744
+	 * @param  int               $grp_id        a specific message template group id.
745
+	 * @return void
746
+	 */
747
+	public static function send_newsletter_message($registrations, $grp_id)
748
+	{
749
+		//make sure mtp is id and set it in the EE_Request Handler later messages setup.
750
+		EE_Registry::instance()->REQ->set('GRP_ID', (int)$grp_id);
751
+		self::_load_controller();
752
+		self::$_MSG_PROCESSOR->generate_for_all_active_messengers('newsletter', $registrations);
753
+	}
754
+
755
+
756
+	/**
757
+	 * Callback for FHEE__EE_Registration__invoice_url__invoice_url or FHEE__EE_Registration__receipt_url__receipt_url
758
+	 *
759
+	 * @since   4.3.0
760
+	 * @param    string          $registration_message_trigger_url
761
+	 * @param    EE_Registration $registration
762
+	 * @param string             $messenger
763
+	 * @param string             $message_type
764
+	 * @return    string
765
+	 */
766
+	public static function registration_message_trigger_url(
767
+		$registration_message_trigger_url,
768
+		EE_Registration $registration,
769
+		$messenger = 'html',
770
+		$message_type = 'invoice'
771
+	) {
772
+		// whitelist $messenger
773
+		switch ($messenger) {
774
+			case 'pdf' :
775
+				$sending_messenger    = 'pdf';
776
+				$generating_messenger = 'html';
777
+				break;
778
+			case 'html' :
779
+			default :
780
+				$sending_messenger    = 'html';
781
+				$generating_messenger = 'html';
782
+				break;
783
+		}
784
+		// whitelist $message_type
785
+		switch ($message_type) {
786
+			case 'receipt' :
787
+				$message_type = 'receipt';
788
+				break;
789
+			case 'invoice' :
790
+			default :
791
+				$message_type = 'invoice';
792
+				break;
793
+		}
794
+		// verify that both the messenger AND the message type are active
795
+		if (EEH_MSG_Template::is_messenger_active($sending_messenger) && EEH_MSG_Template::is_mt_active($message_type)) {
796
+			//need to get the correct message template group for this (i.e. is there a custom invoice for the event this registration is registered for?)
797
+			$template_query_params = array(
798
+				'MTP_is_active'    => true,
799
+				'MTP_messenger'    => $generating_messenger,
800
+				'MTP_message_type' => $message_type,
801
+				'Event.EVT_ID'     => $registration->event_ID(),
802
+			);
803
+			//get the message template group.
804
+			$msg_template_group = EEM_Message_Template_Group::instance()->get_one(array($template_query_params));
805
+			//if we don't have an EE_Message_Template_Group then return
806
+			if (! $msg_template_group instanceof EE_Message_Template_Group) {
807
+				// remove EVT_ID from query params so that global templates get picked up
808
+				unset($template_query_params['Event.EVT_ID']);
809
+				//get global template as the fallback
810
+				$msg_template_group = EEM_Message_Template_Group::instance()->get_one(array($template_query_params));
811
+			}
812
+			//if we don't have an EE_Message_Template_Group then return
813
+			if (! $msg_template_group instanceof EE_Message_Template_Group) {
814
+				return '';
815
+			}
816
+			// generate the URL
817
+			$registration_message_trigger_url = EEH_MSG_Template::generate_url_trigger(
818
+				$sending_messenger,
819
+				$generating_messenger,
820
+				'purchaser',
821
+				$message_type,
822
+				$registration,
823
+				$msg_template_group->ID(),
824
+				$registration->transaction_ID()
825
+			);
826
+
827
+		}
828
+		return $registration_message_trigger_url;
829
+	}
830
+
831
+
832
+	/**
833
+	 * Use to generate and return a message preview!
834
+	 *
835
+	 * @param  string $type      This should correspond with a valid message type
836
+	 * @param  string $context   This should correspond with a valid context for the message type
837
+	 * @param  string $messenger This should correspond with a valid messenger.
838
+	 * @param bool    $send      true we will do a test send using the messenger delivery, false we just do a regular
839
+	 *                           preview
840
+	 * @return bool|string The body of the message or if send is requested, sends.
841
+	 * @throws EE_Error
842
+	 */
843
+	public static function preview_message($type, $context, $messenger, $send = false)
844
+	{
845
+		self::_load_controller();
846
+		$mtg                     = new EE_Message_To_Generate(
847
+			$messenger,
848
+			$type,
849
+			array(),
850
+			$context,
851
+			true
852
+		);
853
+		$generated_preview_queue = self::$_MSG_PROCESSOR->generate_for_preview($mtg, $send);
854
+		if ($generated_preview_queue instanceof EE_Messages_Queue) {
855
+			//loop through all content for the preview and remove any persisted records.
856
+			$content = '';
857
+			foreach ($generated_preview_queue->get_message_repository() as $message) {
858
+				$content = $message->content();
859
+				if ($message->ID() > 0 && $message->STS_ID() !== EEM_Message::status_failed) {
860
+					$message->delete();
861
+				}
862
+			}
863
+			return $content;
864
+		} else {
865
+			return $generated_preview_queue;
866
+		}
867
+	}
868
+
869
+
870
+	/**
871
+	 * This is a method that allows for sending a message using a messenger matching the string given and the provided
872
+	 * EE_Message_Queue object.  The EE_Message_Queue object is used to create a single aggregate EE_Message via the
873
+	 * content found in the EE_Message objects in the queue.
874
+	 *
875
+	 * @since 4.9.0
876
+	 * @param string            $messenger            a string matching a valid active messenger in the system
877
+	 * @param string            $message_type         Although it seems contrary to the name of the method, a message
878
+	 *                                                type name is still required to send along the message type to the
879
+	 *                                                messenger because this is used for determining what specific
880
+	 *                                                variations might be loaded for the generated message.
881
+	 * @param EE_Messages_Queue $queue
882
+	 * @param string            $custom_subject       Can be used to set what the custom subject string will be on the
883
+	 *                                                aggregate EE_Message object.
884
+	 * @return bool          success or fail.
885
+	 */
886
+	public static function send_message_with_messenger_only(
887
+		$messenger,
888
+		$message_type,
889
+		EE_Messages_Queue $queue,
890
+		$custom_subject = ''
891
+	) {
892
+		self::_load_controller();
893
+		/** @type EE_Message_To_Generate_From_Queue $message_to_generate */
894
+		$message_to_generate = EE_Registry::instance()->load_lib(
895
+			'Message_To_Generate_From_Queue',
896
+			array(
897
+				$messenger,
898
+				$message_type,
899
+				$queue,
900
+				$custom_subject,
901
+			)
902
+		);
903
+		return self::$_MSG_PROCESSOR->queue_for_sending($message_to_generate);
904
+	}
905
+
906
+
907
+	/**
908
+	 * Generates Messages immediately for EE_Message IDs (but only for the correct status for generation)
909
+	 *
910
+	 * @since 4.9.0
911
+	 * @param array $message_ids An array of message ids
912
+	 * @return bool | EE_Messages_Queue     false if nothing was generated, EE_Messages_Queue containing generated
913
+	 *              messages.
914
+	 */
915
+	public static function generate_now($message_ids)
916
+	{
917
+		self::_load_controller();
918
+		$messages        = EEM_Message::instance()->get_all(
919
+			array(
920
+				0 => array(
921
+					'MSG_ID' => array('IN', $message_ids),
922
+					'STS_ID' => EEM_Message::status_incomplete,
923
+				),
924
+			)
925
+		);
926
+		$generated_queue = false;
927
+		if ($messages) {
928
+			$generated_queue = self::$_MSG_PROCESSOR->batch_generate_from_queue($messages);
929
+		}
930
+
931
+		if (! $generated_queue instanceof EE_Messages_Queue) {
932
+			EE_Error::add_error(
933
+				__('The messages were not generated. This could mean there is already a batch being generated on a separate request, or because the selected messages are not ready for generation. Please wait a minute or two and try again.',
934
+					'event_espresso'),
935
+				__FILE__, __FUNCTION__, __LINE__
936
+			);
937
+		}
938
+		return $generated_queue;
939
+	}
940
+
941
+
942
+	/**
943
+	 * Sends messages immediately for the incoming message_ids that have the status of EEM_Message::status_resend or,
944
+	 * EEM_Message::status_idle
945
+	 *
946
+	 * @since 4.9.0
947
+	 * @param $message_ids
948
+	 * @return bool | EE_Messages_Queue  false if no messages sent.
949
+	 */
950
+	public static function send_now($message_ids)
951
+	{
952
+		self::_load_controller();
953
+		$messages   = EEM_Message::instance()->get_all(
954
+			array(
955
+				0 => array(
956
+					'MSG_ID' => array('IN', $message_ids),
957
+					'STS_ID' => array(
958
+						'IN',
959
+						array(EEM_Message::status_idle, EEM_Message::status_resend, EEM_Message::status_retry),
960
+					),
961
+				),
962
+			)
963
+		);
964
+		$sent_queue = false;
965
+		if ($messages) {
966
+			$sent_queue = self::$_MSG_PROCESSOR->batch_send_from_queue($messages);
967
+		}
968
+
969
+		if (! $sent_queue instanceof EE_Messages_Queue) {
970
+			EE_Error::add_error(
971
+				__('The messages were not sent. This could mean there is already a batch being sent on a separate request, or because the selected messages are not sendable. Please wait a minute or two and try again.',
972
+					'event_espresso'),
973
+				__FILE__, __FUNCTION__, __LINE__
974
+			);
975
+		} else {
976
+			//can count how many sent by using the messages in the queue
977
+			$sent_count = $sent_queue->count_STS_in_queue(EEM_Message::instance()->stati_indicating_sent());
978
+			if ($sent_count > 0) {
979
+				EE_Error::add_success(
980
+					sprintf(
981
+						_n(
982
+							'There was %d message successfully sent.',
983
+							'There were %d messages successfully sent.',
984
+							$sent_count,
985
+							'event_espresso'
986
+						),
987
+						$sent_count
988
+					)
989
+				);
990
+			} else {
991
+				EE_Error::overwrite_errors();
992
+				EE_Error::add_error(
993
+					__('No message was sent because of problems with sending. Either all the messages you selected were not a sendable message, they were ALREADY sent on a different scheduled task, or there was an error.
994 994
 					If there was an error, you can look at the messages in the message activity list table for any error messages.',
995
-                        'event_espresso'),
996
-                    __FILE__, __FUNCTION__, __LINE__
997
-                );
998
-            }
999
-        }
1000
-        return $sent_queue;
1001
-    }
1002
-
1003
-
1004
-    /**
1005
-     * This will queue the incoming message ids for resending.
1006
-     * Note, only message_ids corresponding to messages with the status of EEM_Message::sent will be queued.
1007
-     *
1008
-     * @since 4.9.0
1009
-     * @param array $message_ids An array of EE_Message IDs
1010
-     * @return bool  true means messages were successfully queued for resending, false means none were queued for
1011
-     *               resending.
1012
-     */
1013
-    public static function queue_for_resending($message_ids)
1014
-    {
1015
-        self::_load_controller();
1016
-        self::$_MSG_PROCESSOR->setup_messages_from_ids_and_send($message_ids);
1017
-
1018
-        //get queue and count
1019
-        $queue_count = self::$_MSG_PROCESSOR->get_queue()->count_STS_in_queue(EEM_Message::status_resend);
1020
-
1021
-        if (
1022
-            $queue_count > 0
1023
-        ) {
1024
-            EE_Error::add_success(
1025
-                sprintf(
1026
-                    _n(
1027
-                        '%d message successfully queued for resending.',
1028
-                        '%d messages successfully queued for resending.',
1029
-                        $queue_count,
1030
-                        'event_espresso'
1031
-                    ),
1032
-                    $queue_count
1033
-                )
1034
-            );
1035
-            /**
1036
-             * @see filter usage in EE_Messages_Queue::initiate_request_by_priority
1037
-             */
1038
-        } elseif (
1039
-            apply_filters('FHEE__EE_Messages_Processor__initiate_request_by_priority__do_immediate_processing', true)
1040
-            || EE_Registry::instance()->NET_CFG->core->do_messages_on_same_request
1041
-        ) {
1042
-            $queue_count = self::$_MSG_PROCESSOR->get_queue()->count_STS_in_queue(EEM_Message::status_sent);
1043
-            if ($queue_count > 0) {
1044
-                EE_Error::add_success(
1045
-                    sprintf(
1046
-                        _n(
1047
-                            '%d message successfully sent.',
1048
-                            '%d messages successfully sent.',
1049
-                            $queue_count,
1050
-                            'event_espresso'
1051
-                        ),
1052
-                        $queue_count
1053
-                    )
1054
-                );
1055
-            } else {
1056
-                EE_Error::add_error(
1057
-                    __('No messages were queued for resending. This usually only happens when all the messages flagged for resending are not a status that can be resent.',
1058
-                        'event_espresso'),
1059
-                    __FILE__, __FUNCTION__, __LINE__
1060
-                );
1061
-            }
1062
-        } else {
1063
-            EE_Error::add_error(
1064
-                __('No messages were queued for resending. This usually only happens when all the messages flagged for resending are not a status that can be resent.',
1065
-                    'event_espresso'),
1066
-                __FILE__, __FUNCTION__, __LINE__
1067
-            );
1068
-        }
1069
-        return (bool)$queue_count;
1070
-    }
1071
-
1072
-
1073
-    /**
1074
-     * debug
1075
-     *
1076
-     * @param string          $class
1077
-     * @param string          $func
1078
-     * @param string          $line
1079
-     * @param \EE_Transaction $transaction
1080
-     * @param array           $info
1081
-     * @param bool            $display_request
1082
-     */
1083
-    protected static function log(
1084
-        $class = '',
1085
-        $func = '',
1086
-        $line = '',
1087
-        EE_Transaction $transaction,
1088
-        $info = array(),
1089
-        $display_request = false
1090
-    ) {
1091
-        if (WP_DEBUG && false) {
1092
-            if ($transaction instanceof EE_Transaction) {
1093
-                // don't serialize objects
1094
-                $info                  = EEH_Debug_Tools::strip_objects($info);
1095
-                $info['TXN_status']    = $transaction->status_ID();
1096
-                $info['TXN_reg_steps'] = $transaction->reg_steps();
1097
-                if ($transaction->ID()) {
1098
-                    $index = 'EE_Transaction: ' . $transaction->ID();
1099
-                    EEH_Debug_Tools::log($class, $func, $line, $info, $display_request, $index);
1100
-                }
1101
-            }
1102
-        }
1103
-
1104
-    }
1105
-
1106
-
1107
-    /**
1108
-     *  Resets all the static properties in this class when called.
1109
-     */
1110
-    public static function reset()
1111
-    {
1112
-        self::$_EEMSG                    = null;
1113
-        self::$_message_resource_manager = null;
1114
-        self::$_MSG_PROCESSOR            = null;
1115
-        self::$_MSG_PATHS                = null;
1116
-        self::$_TMP_PACKS                = array();
1117
-    }
995
+						'event_espresso'),
996
+					__FILE__, __FUNCTION__, __LINE__
997
+				);
998
+			}
999
+		}
1000
+		return $sent_queue;
1001
+	}
1002
+
1003
+
1004
+	/**
1005
+	 * This will queue the incoming message ids for resending.
1006
+	 * Note, only message_ids corresponding to messages with the status of EEM_Message::sent will be queued.
1007
+	 *
1008
+	 * @since 4.9.0
1009
+	 * @param array $message_ids An array of EE_Message IDs
1010
+	 * @return bool  true means messages were successfully queued for resending, false means none were queued for
1011
+	 *               resending.
1012
+	 */
1013
+	public static function queue_for_resending($message_ids)
1014
+	{
1015
+		self::_load_controller();
1016
+		self::$_MSG_PROCESSOR->setup_messages_from_ids_and_send($message_ids);
1017
+
1018
+		//get queue and count
1019
+		$queue_count = self::$_MSG_PROCESSOR->get_queue()->count_STS_in_queue(EEM_Message::status_resend);
1020
+
1021
+		if (
1022
+			$queue_count > 0
1023
+		) {
1024
+			EE_Error::add_success(
1025
+				sprintf(
1026
+					_n(
1027
+						'%d message successfully queued for resending.',
1028
+						'%d messages successfully queued for resending.',
1029
+						$queue_count,
1030
+						'event_espresso'
1031
+					),
1032
+					$queue_count
1033
+				)
1034
+			);
1035
+			/**
1036
+			 * @see filter usage in EE_Messages_Queue::initiate_request_by_priority
1037
+			 */
1038
+		} elseif (
1039
+			apply_filters('FHEE__EE_Messages_Processor__initiate_request_by_priority__do_immediate_processing', true)
1040
+			|| EE_Registry::instance()->NET_CFG->core->do_messages_on_same_request
1041
+		) {
1042
+			$queue_count = self::$_MSG_PROCESSOR->get_queue()->count_STS_in_queue(EEM_Message::status_sent);
1043
+			if ($queue_count > 0) {
1044
+				EE_Error::add_success(
1045
+					sprintf(
1046
+						_n(
1047
+							'%d message successfully sent.',
1048
+							'%d messages successfully sent.',
1049
+							$queue_count,
1050
+							'event_espresso'
1051
+						),
1052
+						$queue_count
1053
+					)
1054
+				);
1055
+			} else {
1056
+				EE_Error::add_error(
1057
+					__('No messages were queued for resending. This usually only happens when all the messages flagged for resending are not a status that can be resent.',
1058
+						'event_espresso'),
1059
+					__FILE__, __FUNCTION__, __LINE__
1060
+				);
1061
+			}
1062
+		} else {
1063
+			EE_Error::add_error(
1064
+				__('No messages were queued for resending. This usually only happens when all the messages flagged for resending are not a status that can be resent.',
1065
+					'event_espresso'),
1066
+				__FILE__, __FUNCTION__, __LINE__
1067
+			);
1068
+		}
1069
+		return (bool)$queue_count;
1070
+	}
1071
+
1072
+
1073
+	/**
1074
+	 * debug
1075
+	 *
1076
+	 * @param string          $class
1077
+	 * @param string          $func
1078
+	 * @param string          $line
1079
+	 * @param \EE_Transaction $transaction
1080
+	 * @param array           $info
1081
+	 * @param bool            $display_request
1082
+	 */
1083
+	protected static function log(
1084
+		$class = '',
1085
+		$func = '',
1086
+		$line = '',
1087
+		EE_Transaction $transaction,
1088
+		$info = array(),
1089
+		$display_request = false
1090
+	) {
1091
+		if (WP_DEBUG && false) {
1092
+			if ($transaction instanceof EE_Transaction) {
1093
+				// don't serialize objects
1094
+				$info                  = EEH_Debug_Tools::strip_objects($info);
1095
+				$info['TXN_status']    = $transaction->status_ID();
1096
+				$info['TXN_reg_steps'] = $transaction->reg_steps();
1097
+				if ($transaction->ID()) {
1098
+					$index = 'EE_Transaction: ' . $transaction->ID();
1099
+					EEH_Debug_Tools::log($class, $func, $line, $info, $display_request, $index);
1100
+				}
1101
+			}
1102
+		}
1103
+
1104
+	}
1105
+
1106
+
1107
+	/**
1108
+	 *  Resets all the static properties in this class when called.
1109
+	 */
1110
+	public static function reset()
1111
+	{
1112
+		self::$_EEMSG                    = null;
1113
+		self::$_message_resource_manager = null;
1114
+		self::$_MSG_PROCESSOR            = null;
1115
+		self::$_MSG_PATHS                = null;
1116
+		self::$_TMP_PACKS                = array();
1117
+	}
1118 1118
 
1119 1119
 }
1120 1120
 // End of file EED_Messages.module.php
Please login to merge, or discard this patch.
modules/ticket_selector/EED_Ticket_Selector.module.php 3 patches
Doc Comments   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -226,7 +226,7 @@  discard block
 block discarded – undo
226 226
 
227 227
 
228 228
     /**
229
-     * @return array  or FALSE
229
+     * @return boolean|null  or FALSE
230 230
      * @throws EE_Error
231 231
      */
232 232
     public function process_ticket_selections()
@@ -238,7 +238,7 @@  discard block
 block discarded – undo
238 238
 
239 239
 
240 240
     /**
241
-     * @return string
241
+     * @return false|null
242 242
      */
243 243
     public static function cancel_ticket_selections()
244 244
     {
Please login to merge, or discard this patch.
Indentation   +456 added lines, -456 removed lines patch added patch discarded remove patch
@@ -20,462 +20,462 @@
 block discarded – undo
20 20
 class EED_Ticket_Selector extends EED_Module
21 21
 {
22 22
 
23
-    /**
24
-     * @var DisplayTicketSelector $ticket_selector
25
-     */
26
-    private static $ticket_selector;
27
-
28
-    /**
29
-     * @var TicketSelectorIframeEmbedButton $iframe_embed_button
30
-     */
31
-    private static $iframe_embed_button;
32
-
33
-
34
-
35
-    /**
36
-     * @return EED_Module|EED_Ticket_Selector
37
-     */
38
-    public static function instance()
39
-    {
40
-        return parent::get_instance(__CLASS__);
41
-    }
42
-
43
-
44
-
45
-    /**
46
-     * @return void
47
-     */
48
-    protected function set_config()
49
-    {
50
-        $this->set_config_section('template_settings');
51
-        $this->set_config_class('EE_Ticket_Selector_Config');
52
-        $this->set_config_name('EED_Ticket_Selector');
53
-    }
54
-
55
-
56
-
57
-    /**
58
-     *    set_hooks - for hooking into EE Core, other modules, etc
59
-     *
60
-     * @return void
61
-     */
62
-    public static function set_hooks()
63
-    {
64
-        // routing
65
-        EE_Config::register_route(
66
-            'iframe',
67
-            'EED_Ticket_Selector',
68
-            'ticket_selector_iframe',
69
-            'ticket_selector'
70
-        );
71
-        EE_Config::register_route(
72
-            'process_ticket_selections',
73
-            'EED_Ticket_Selector',
74
-            'process_ticket_selections'
75
-        );
76
-        EE_Config::register_route(
77
-            'cancel_ticket_selections',
78
-            'EED_Ticket_Selector',
79
-            'cancel_ticket_selections'
80
-        );
81
-        add_action('wp_loaded', array('EED_Ticket_Selector', 'set_definitions'), 2);
82
-        add_action('AHEE_event_details_header_bottom', array('EED_Ticket_Selector', 'display_ticket_selector'), 10, 1);
83
-        add_action('wp_enqueue_scripts', array('EED_Ticket_Selector', 'translate_js_strings'), 0);
84
-        add_action('wp_enqueue_scripts', array('EED_Ticket_Selector', 'load_tckt_slctr_assets'), 10);
85
-        EED_Ticket_Selector::loadIframeAssets();
86
-    }
87
-
88
-
89
-
90
-    /**
91
-     *    set_hooks_admin - for hooking into EE Admin Core, other modules, etc
92
-     *
93
-     * @return void
94
-     */
95
-    public static function set_hooks_admin()
96
-    {
97
-        // hook into the end of the \EE_Admin_Page::_load_page_dependencies()
98
-        // to load assets for "espresso_events" page on the "edit" route (action)
99
-        add_action(
100
-            'FHEE__EE_Admin_Page___load_page_dependencies__after_load__espresso_events__edit',
101
-            array('EED_Ticket_Selector', 'ticket_selector_iframe_embed_button'),
102
-            10
103
-        );
104
-        /**
105
-         * Make sure assets for the ticket selector are loaded on the espresso registrations route so  admin side
106
-         * registrations work.
107
-         */
108
-        add_action(
109
-            'FHEE__EE_Admin_Page___load_page_dependencies__after_load__espresso_registrations__new_registration',
110
-            array('EED_Ticket_Selector', 'set_definitions'),
111
-            10
112
-        );
113
-    }
114
-
115
-
116
-
117
-    /**
118
-     *    set_definitions
119
-     *
120
-     * @return void
121
-     * @throws InvalidArgumentException
122
-     * @throws InvalidDataTypeException
123
-     * @throws InvalidInterfaceException
124
-     */
125
-    public static function set_definitions()
126
-    {
127
-        // don't do this twice
128
-        if (defined('TICKET_SELECTOR_ASSETS_URL')) {
129
-            return;
130
-        }
131
-        define('TICKET_SELECTOR_ASSETS_URL', plugin_dir_url(__FILE__) . 'assets' . DS);
132
-        define(
133
-            'TICKET_SELECTOR_TEMPLATES_PATH',
134
-            str_replace('\\', DS, plugin_dir_path(__FILE__)) . 'templates' . DS
135
-        );
136
-        //if config is not set, initialize
137
-        if (
138
-            ! EE_Registry::instance()->CFG->template_settings->EED_Ticket_Selector instanceof EE_Ticket_Selector_Config
139
-        ) {
140
-            EED_Ticket_Selector::instance()->set_config();
141
-            EE_Registry::instance()->CFG->template_settings->EED_Ticket_Selector = EED_Ticket_Selector::instance()->config();
142
-        }
143
-    }
144
-
145
-
146
-
147
-    /**
148
-     * @return DisplayTicketSelector
149
-     */
150
-    public static function ticketSelector()
151
-    {
152
-        if (! EED_Ticket_Selector::$ticket_selector instanceof DisplayTicketSelector) {
153
-            EED_Ticket_Selector::$ticket_selector = new DisplayTicketSelector(EED_Events_Archive::is_iframe());
154
-        }
155
-        return EED_Ticket_Selector::$ticket_selector;
156
-    }
157
-
158
-
159
-    /**
160
-     * gets the ball rolling
161
-     *
162
-     * @param WP $WP
163
-     * @return void
164
-     */
165
-    public function run($WP)
166
-    {
167
-    }
168
-
169
-
170
-
171
-    /**
172
-     * @return TicketSelectorIframeEmbedButton
173
-     */
174
-    public static function getIframeEmbedButton()
175
-    {
176
-        if (! self::$iframe_embed_button instanceof TicketSelectorIframeEmbedButton) {
177
-            self::$iframe_embed_button = new TicketSelectorIframeEmbedButton();
178
-        }
179
-        return self::$iframe_embed_button;
180
-    }
181
-
182
-
183
-
184
-    /**
185
-     * ticket_selector_iframe_embed_button
186
-     *
187
-     * @return void
188
-     * @throws EE_Error
189
-     */
190
-    public static function ticket_selector_iframe_embed_button()
191
-    {
192
-        $iframe_embed_button = EED_Ticket_Selector::getIframeEmbedButton();
193
-        $iframe_embed_button->addEventEditorIframeEmbedButton();
194
-    }
195
-
196
-
197
-
198
-    /**
199
-     * ticket_selector_iframe
200
-     *
201
-     * @return void
202
-     * @throws DomainException
203
-     * @throws EE_Error
204
-     */
205
-    public function ticket_selector_iframe()
206
-    {
207
-        $ticket_selector_iframe = new TicketSelectorIframe();
208
-        $ticket_selector_iframe->display();
209
-    }
210
-
211
-
212
-
213
-    /**
214
-     * creates buttons for selecting number of attendees for an event
215
-     *
216
-     * @param  WP_Post|int $event
217
-     * @param  bool        $view_details
218
-     * @return string
219
-     * @throws EE_Error
220
-     */
221
-    public static function display_ticket_selector($event = null, $view_details = false)
222
-    {
223
-        return EED_Ticket_Selector::ticketSelector()->display($event, $view_details);
224
-    }
225
-
226
-
227
-
228
-    /**
229
-     * @return array  or FALSE
230
-     * @throws EE_Error
231
-     */
232
-    public function process_ticket_selections()
233
-    {
234
-        $form = new ProcessTicketSelector();
235
-        return $form->processTicketSelections();
236
-    }
237
-
238
-
239
-
240
-    /**
241
-     * @return string
242
-     */
243
-    public static function cancel_ticket_selections()
244
-    {
245
-        $form = new ProcessTicketSelector();
246
-        return $form->cancelTicketSelections();
247
-    }
248
-
249
-
250
-
251
-    /**
252
-     * @return void
253
-     */
254
-    public static function translate_js_strings()
255
-    {
256
-        EE_Registry::$i18n_js_strings['please_select_date_filter_notice'] = esc_html__(
257
-            'please select a datetime',
258
-            'event_espresso'
259
-        );
260
-    }
261
-
262
-
263
-
264
-    /**
265
-     * @return void
266
-     */
267
-    public static function load_tckt_slctr_assets()
268
-    {
269
-        if (apply_filters('FHEE__EED_Ticket_Selector__load_tckt_slctr_assets', false)) {
270
-            // add some style
271
-            wp_register_style(
272
-                'ticket_selector',
273
-                TICKET_SELECTOR_ASSETS_URL . 'ticket_selector.css',
274
-                array(),
275
-                EVENT_ESPRESSO_VERSION
276
-            );
277
-            wp_enqueue_style('ticket_selector');
278
-            // make it dance
279
-            wp_register_script(
280
-                'ticket_selector',
281
-                TICKET_SELECTOR_ASSETS_URL . 'ticket_selector.js',
282
-                array('espresso_core'),
283
-                EVENT_ESPRESSO_VERSION,
284
-                true
285
-            );
286
-            wp_enqueue_script('ticket_selector');
287
-            require_once EE_LIBRARIES
288
-                         . 'form_sections/strategies/display/EE_Checkbox_Dropdown_Selector_Display_Strategy.strategy.php';
289
-            \EE_Checkbox_Dropdown_Selector_Display_Strategy::enqueue_styles_and_scripts();
290
-        }
291
-    }
292
-
293
-
294
-
295
-    /**
296
-     * @return void
297
-     */
298
-    public static function loadIframeAssets()
299
-    {
300
-        // for event lists
301
-        add_filter(
302
-            'FHEE__EventEspresso_modules_events_archive_EventsArchiveIframe__display__css',
303
-            array('EED_Ticket_Selector', 'iframeCss')
304
-        );
305
-        add_filter(
306
-            'FHEE__EventEspresso_modules_events_archive_EventsArchiveIframe__display__js',
307
-            array('EED_Ticket_Selector', 'iframeJs')
308
-        );
309
-        // for ticket selectors
310
-        add_filter(
311
-            'FHEE__EED_Ticket_Selector__ticket_selector_iframe__css',
312
-            array('EED_Ticket_Selector', 'iframeCss')
313
-        );
314
-        add_filter(
315
-            'FHEE__EED_Ticket_Selector__ticket_selector_iframe__js',
316
-            array('EED_Ticket_Selector', 'iframeJs')
317
-        );
318
-    }
319
-
320
-
321
-
322
-    /**
323
-     * Informs the rest of the forms system what CSS and JS is needed to display the input
324
-     *
325
-     * @param array $iframe_css
326
-     * @return array
327
-     */
328
-    public static function iframeCss(array $iframe_css)
329
-    {
330
-        $iframe_css['ticket_selector'] = TICKET_SELECTOR_ASSETS_URL . 'ticket_selector.css';
331
-        return $iframe_css;
332
-    }
333
-
334
-
335
-
336
-    /**
337
-     * Informs the rest of the forms system what CSS and JS is needed to display the input
338
-     *
339
-     * @param array $iframe_js
340
-     * @return array
341
-     */
342
-    public static function iframeJs(array $iframe_js)
343
-    {
344
-        $iframe_js['ticket_selector'] = TICKET_SELECTOR_ASSETS_URL . 'ticket_selector.js';
345
-        return $iframe_js;
346
-    }
347
-
348
-
349
-    /****************************** DEPRECATED ******************************/
350
-
351
-
352
-
353
-    /**
354
-     * @deprecated
355
-     * @return string
356
-     * @throws EE_Error
357
-     */
358
-    public static function display_view_details_btn()
359
-    {
360
-        // todo add doing_it_wrong() notice during next major version
361
-        return EED_Ticket_Selector::ticketSelector()->displayViewDetailsButton();
362
-    }
363
-
364
-
365
-
366
-    /**
367
-     * @deprecated
368
-     * @return string
369
-     * @throws EE_Error
370
-     */
371
-    public static function display_ticket_selector_submit()
372
-    {
373
-        // todo add doing_it_wrong() notice during next major version
374
-        return EED_Ticket_Selector::ticketSelector()->displaySubmitButton();
375
-    }
376
-
377
-
378
-
379
-    /**
380
-     * @deprecated
381
-     * @param string $permalink_string
382
-     * @param int    $id
383
-     * @param string $new_title
384
-     * @param string $new_slug
385
-     * @return string
386
-     * @throws InvalidArgumentException
387
-     * @throws InvalidDataTypeException
388
-     * @throws InvalidInterfaceException
389
-     */
390
-    public static function iframe_code_button($permalink_string, $id, $new_title = '', $new_slug = '')
391
-    {
392
-        // todo add doing_it_wrong() notice during next major version
393
-        if (
394
-            EE_Registry::instance()->REQ->get('page') === 'espresso_events'
395
-            && EE_Registry::instance()->REQ->get('action') === 'edit'
396
-        ) {
397
-            $iframe_embed_button = EED_Ticket_Selector::getIframeEmbedButton();
398
-            $iframe_embed_button->addEventEditorIframeEmbedButton();
399
-        }
400
-        return '';
401
-    }
402
-
403
-
404
-
405
-    /**
406
-     * @deprecated
407
-     * @param int    $ID
408
-     * @param string $external_url
409
-     * @return string
410
-     */
411
-    public static function ticket_selector_form_open($ID = 0, $external_url = '')
412
-    {
413
-        // todo add doing_it_wrong() notice during next major version
414
-        return EED_Ticket_Selector::ticketSelector()->formOpen($ID, $external_url);
415
-    }
416
-
417
-
418
-
419
-    /**
420
-     * @deprecated
421
-     * @return string
422
-     */
423
-    public static function ticket_selector_form_close()
424
-    {
425
-        // todo add doing_it_wrong() notice during next major version
426
-        return EED_Ticket_Selector::ticketSelector()->formClose();
427
-    }
428
-
429
-
430
-
431
-    /**
432
-     * @deprecated
433
-     * @return string
434
-     */
435
-    public static function no_tkt_slctr_end_dv()
436
-    {
437
-        // todo add doing_it_wrong() notice during next major version
438
-        return EED_Ticket_Selector::ticketSelector()->ticketSelectorEndDiv();
439
-    }
440
-
441
-
442
-
443
-    /**
444
-     * @deprecated 4.9.13
445
-     * @return string
446
-     */
447
-    public static function tkt_slctr_end_dv()
448
-    {
449
-        return EED_Ticket_Selector::ticketSelector()->clearTicketSelector();
450
-    }
451
-
452
-
453
-
454
-    /**
455
-     * @deprecated
456
-     * @return string
457
-     */
458
-    public static function clear_tkt_slctr()
459
-    {
460
-        return EED_Ticket_Selector::ticketSelector()->clearTicketSelector();
461
-    }
462
-
463
-
464
-
465
-    /**
466
-     * @deprecated
467
-     */
468
-    public static function load_tckt_slctr_assets_admin()
469
-    {
470
-        // todo add doing_it_wrong() notice during next major version
471
-        if (
472
-            EE_Registry::instance()->REQ->get('page') === 'espresso_events'
473
-            && EE_Registry::instance()->REQ->get('action') === 'edit'
474
-        ) {
475
-            $iframe_embed_button = EED_Ticket_Selector::getIframeEmbedButton();
476
-            $iframe_embed_button->embedButtonAssets();
477
-        }
478
-    }
23
+	/**
24
+	 * @var DisplayTicketSelector $ticket_selector
25
+	 */
26
+	private static $ticket_selector;
27
+
28
+	/**
29
+	 * @var TicketSelectorIframeEmbedButton $iframe_embed_button
30
+	 */
31
+	private static $iframe_embed_button;
32
+
33
+
34
+
35
+	/**
36
+	 * @return EED_Module|EED_Ticket_Selector
37
+	 */
38
+	public static function instance()
39
+	{
40
+		return parent::get_instance(__CLASS__);
41
+	}
42
+
43
+
44
+
45
+	/**
46
+	 * @return void
47
+	 */
48
+	protected function set_config()
49
+	{
50
+		$this->set_config_section('template_settings');
51
+		$this->set_config_class('EE_Ticket_Selector_Config');
52
+		$this->set_config_name('EED_Ticket_Selector');
53
+	}
54
+
55
+
56
+
57
+	/**
58
+	 *    set_hooks - for hooking into EE Core, other modules, etc
59
+	 *
60
+	 * @return void
61
+	 */
62
+	public static function set_hooks()
63
+	{
64
+		// routing
65
+		EE_Config::register_route(
66
+			'iframe',
67
+			'EED_Ticket_Selector',
68
+			'ticket_selector_iframe',
69
+			'ticket_selector'
70
+		);
71
+		EE_Config::register_route(
72
+			'process_ticket_selections',
73
+			'EED_Ticket_Selector',
74
+			'process_ticket_selections'
75
+		);
76
+		EE_Config::register_route(
77
+			'cancel_ticket_selections',
78
+			'EED_Ticket_Selector',
79
+			'cancel_ticket_selections'
80
+		);
81
+		add_action('wp_loaded', array('EED_Ticket_Selector', 'set_definitions'), 2);
82
+		add_action('AHEE_event_details_header_bottom', array('EED_Ticket_Selector', 'display_ticket_selector'), 10, 1);
83
+		add_action('wp_enqueue_scripts', array('EED_Ticket_Selector', 'translate_js_strings'), 0);
84
+		add_action('wp_enqueue_scripts', array('EED_Ticket_Selector', 'load_tckt_slctr_assets'), 10);
85
+		EED_Ticket_Selector::loadIframeAssets();
86
+	}
87
+
88
+
89
+
90
+	/**
91
+	 *    set_hooks_admin - for hooking into EE Admin Core, other modules, etc
92
+	 *
93
+	 * @return void
94
+	 */
95
+	public static function set_hooks_admin()
96
+	{
97
+		// hook into the end of the \EE_Admin_Page::_load_page_dependencies()
98
+		// to load assets for "espresso_events" page on the "edit" route (action)
99
+		add_action(
100
+			'FHEE__EE_Admin_Page___load_page_dependencies__after_load__espresso_events__edit',
101
+			array('EED_Ticket_Selector', 'ticket_selector_iframe_embed_button'),
102
+			10
103
+		);
104
+		/**
105
+		 * Make sure assets for the ticket selector are loaded on the espresso registrations route so  admin side
106
+		 * registrations work.
107
+		 */
108
+		add_action(
109
+			'FHEE__EE_Admin_Page___load_page_dependencies__after_load__espresso_registrations__new_registration',
110
+			array('EED_Ticket_Selector', 'set_definitions'),
111
+			10
112
+		);
113
+	}
114
+
115
+
116
+
117
+	/**
118
+	 *    set_definitions
119
+	 *
120
+	 * @return void
121
+	 * @throws InvalidArgumentException
122
+	 * @throws InvalidDataTypeException
123
+	 * @throws InvalidInterfaceException
124
+	 */
125
+	public static function set_definitions()
126
+	{
127
+		// don't do this twice
128
+		if (defined('TICKET_SELECTOR_ASSETS_URL')) {
129
+			return;
130
+		}
131
+		define('TICKET_SELECTOR_ASSETS_URL', plugin_dir_url(__FILE__) . 'assets' . DS);
132
+		define(
133
+			'TICKET_SELECTOR_TEMPLATES_PATH',
134
+			str_replace('\\', DS, plugin_dir_path(__FILE__)) . 'templates' . DS
135
+		);
136
+		//if config is not set, initialize
137
+		if (
138
+			! EE_Registry::instance()->CFG->template_settings->EED_Ticket_Selector instanceof EE_Ticket_Selector_Config
139
+		) {
140
+			EED_Ticket_Selector::instance()->set_config();
141
+			EE_Registry::instance()->CFG->template_settings->EED_Ticket_Selector = EED_Ticket_Selector::instance()->config();
142
+		}
143
+	}
144
+
145
+
146
+
147
+	/**
148
+	 * @return DisplayTicketSelector
149
+	 */
150
+	public static function ticketSelector()
151
+	{
152
+		if (! EED_Ticket_Selector::$ticket_selector instanceof DisplayTicketSelector) {
153
+			EED_Ticket_Selector::$ticket_selector = new DisplayTicketSelector(EED_Events_Archive::is_iframe());
154
+		}
155
+		return EED_Ticket_Selector::$ticket_selector;
156
+	}
157
+
158
+
159
+	/**
160
+	 * gets the ball rolling
161
+	 *
162
+	 * @param WP $WP
163
+	 * @return void
164
+	 */
165
+	public function run($WP)
166
+	{
167
+	}
168
+
169
+
170
+
171
+	/**
172
+	 * @return TicketSelectorIframeEmbedButton
173
+	 */
174
+	public static function getIframeEmbedButton()
175
+	{
176
+		if (! self::$iframe_embed_button instanceof TicketSelectorIframeEmbedButton) {
177
+			self::$iframe_embed_button = new TicketSelectorIframeEmbedButton();
178
+		}
179
+		return self::$iframe_embed_button;
180
+	}
181
+
182
+
183
+
184
+	/**
185
+	 * ticket_selector_iframe_embed_button
186
+	 *
187
+	 * @return void
188
+	 * @throws EE_Error
189
+	 */
190
+	public static function ticket_selector_iframe_embed_button()
191
+	{
192
+		$iframe_embed_button = EED_Ticket_Selector::getIframeEmbedButton();
193
+		$iframe_embed_button->addEventEditorIframeEmbedButton();
194
+	}
195
+
196
+
197
+
198
+	/**
199
+	 * ticket_selector_iframe
200
+	 *
201
+	 * @return void
202
+	 * @throws DomainException
203
+	 * @throws EE_Error
204
+	 */
205
+	public function ticket_selector_iframe()
206
+	{
207
+		$ticket_selector_iframe = new TicketSelectorIframe();
208
+		$ticket_selector_iframe->display();
209
+	}
210
+
211
+
212
+
213
+	/**
214
+	 * creates buttons for selecting number of attendees for an event
215
+	 *
216
+	 * @param  WP_Post|int $event
217
+	 * @param  bool        $view_details
218
+	 * @return string
219
+	 * @throws EE_Error
220
+	 */
221
+	public static function display_ticket_selector($event = null, $view_details = false)
222
+	{
223
+		return EED_Ticket_Selector::ticketSelector()->display($event, $view_details);
224
+	}
225
+
226
+
227
+
228
+	/**
229
+	 * @return array  or FALSE
230
+	 * @throws EE_Error
231
+	 */
232
+	public function process_ticket_selections()
233
+	{
234
+		$form = new ProcessTicketSelector();
235
+		return $form->processTicketSelections();
236
+	}
237
+
238
+
239
+
240
+	/**
241
+	 * @return string
242
+	 */
243
+	public static function cancel_ticket_selections()
244
+	{
245
+		$form = new ProcessTicketSelector();
246
+		return $form->cancelTicketSelections();
247
+	}
248
+
249
+
250
+
251
+	/**
252
+	 * @return void
253
+	 */
254
+	public static function translate_js_strings()
255
+	{
256
+		EE_Registry::$i18n_js_strings['please_select_date_filter_notice'] = esc_html__(
257
+			'please select a datetime',
258
+			'event_espresso'
259
+		);
260
+	}
261
+
262
+
263
+
264
+	/**
265
+	 * @return void
266
+	 */
267
+	public static function load_tckt_slctr_assets()
268
+	{
269
+		if (apply_filters('FHEE__EED_Ticket_Selector__load_tckt_slctr_assets', false)) {
270
+			// add some style
271
+			wp_register_style(
272
+				'ticket_selector',
273
+				TICKET_SELECTOR_ASSETS_URL . 'ticket_selector.css',
274
+				array(),
275
+				EVENT_ESPRESSO_VERSION
276
+			);
277
+			wp_enqueue_style('ticket_selector');
278
+			// make it dance
279
+			wp_register_script(
280
+				'ticket_selector',
281
+				TICKET_SELECTOR_ASSETS_URL . 'ticket_selector.js',
282
+				array('espresso_core'),
283
+				EVENT_ESPRESSO_VERSION,
284
+				true
285
+			);
286
+			wp_enqueue_script('ticket_selector');
287
+			require_once EE_LIBRARIES
288
+						 . 'form_sections/strategies/display/EE_Checkbox_Dropdown_Selector_Display_Strategy.strategy.php';
289
+			\EE_Checkbox_Dropdown_Selector_Display_Strategy::enqueue_styles_and_scripts();
290
+		}
291
+	}
292
+
293
+
294
+
295
+	/**
296
+	 * @return void
297
+	 */
298
+	public static function loadIframeAssets()
299
+	{
300
+		// for event lists
301
+		add_filter(
302
+			'FHEE__EventEspresso_modules_events_archive_EventsArchiveIframe__display__css',
303
+			array('EED_Ticket_Selector', 'iframeCss')
304
+		);
305
+		add_filter(
306
+			'FHEE__EventEspresso_modules_events_archive_EventsArchiveIframe__display__js',
307
+			array('EED_Ticket_Selector', 'iframeJs')
308
+		);
309
+		// for ticket selectors
310
+		add_filter(
311
+			'FHEE__EED_Ticket_Selector__ticket_selector_iframe__css',
312
+			array('EED_Ticket_Selector', 'iframeCss')
313
+		);
314
+		add_filter(
315
+			'FHEE__EED_Ticket_Selector__ticket_selector_iframe__js',
316
+			array('EED_Ticket_Selector', 'iframeJs')
317
+		);
318
+	}
319
+
320
+
321
+
322
+	/**
323
+	 * Informs the rest of the forms system what CSS and JS is needed to display the input
324
+	 *
325
+	 * @param array $iframe_css
326
+	 * @return array
327
+	 */
328
+	public static function iframeCss(array $iframe_css)
329
+	{
330
+		$iframe_css['ticket_selector'] = TICKET_SELECTOR_ASSETS_URL . 'ticket_selector.css';
331
+		return $iframe_css;
332
+	}
333
+
334
+
335
+
336
+	/**
337
+	 * Informs the rest of the forms system what CSS and JS is needed to display the input
338
+	 *
339
+	 * @param array $iframe_js
340
+	 * @return array
341
+	 */
342
+	public static function iframeJs(array $iframe_js)
343
+	{
344
+		$iframe_js['ticket_selector'] = TICKET_SELECTOR_ASSETS_URL . 'ticket_selector.js';
345
+		return $iframe_js;
346
+	}
347
+
348
+
349
+	/****************************** DEPRECATED ******************************/
350
+
351
+
352
+
353
+	/**
354
+	 * @deprecated
355
+	 * @return string
356
+	 * @throws EE_Error
357
+	 */
358
+	public static function display_view_details_btn()
359
+	{
360
+		// todo add doing_it_wrong() notice during next major version
361
+		return EED_Ticket_Selector::ticketSelector()->displayViewDetailsButton();
362
+	}
363
+
364
+
365
+
366
+	/**
367
+	 * @deprecated
368
+	 * @return string
369
+	 * @throws EE_Error
370
+	 */
371
+	public static function display_ticket_selector_submit()
372
+	{
373
+		// todo add doing_it_wrong() notice during next major version
374
+		return EED_Ticket_Selector::ticketSelector()->displaySubmitButton();
375
+	}
376
+
377
+
378
+
379
+	/**
380
+	 * @deprecated
381
+	 * @param string $permalink_string
382
+	 * @param int    $id
383
+	 * @param string $new_title
384
+	 * @param string $new_slug
385
+	 * @return string
386
+	 * @throws InvalidArgumentException
387
+	 * @throws InvalidDataTypeException
388
+	 * @throws InvalidInterfaceException
389
+	 */
390
+	public static function iframe_code_button($permalink_string, $id, $new_title = '', $new_slug = '')
391
+	{
392
+		// todo add doing_it_wrong() notice during next major version
393
+		if (
394
+			EE_Registry::instance()->REQ->get('page') === 'espresso_events'
395
+			&& EE_Registry::instance()->REQ->get('action') === 'edit'
396
+		) {
397
+			$iframe_embed_button = EED_Ticket_Selector::getIframeEmbedButton();
398
+			$iframe_embed_button->addEventEditorIframeEmbedButton();
399
+		}
400
+		return '';
401
+	}
402
+
403
+
404
+
405
+	/**
406
+	 * @deprecated
407
+	 * @param int    $ID
408
+	 * @param string $external_url
409
+	 * @return string
410
+	 */
411
+	public static function ticket_selector_form_open($ID = 0, $external_url = '')
412
+	{
413
+		// todo add doing_it_wrong() notice during next major version
414
+		return EED_Ticket_Selector::ticketSelector()->formOpen($ID, $external_url);
415
+	}
416
+
417
+
418
+
419
+	/**
420
+	 * @deprecated
421
+	 * @return string
422
+	 */
423
+	public static function ticket_selector_form_close()
424
+	{
425
+		// todo add doing_it_wrong() notice during next major version
426
+		return EED_Ticket_Selector::ticketSelector()->formClose();
427
+	}
428
+
429
+
430
+
431
+	/**
432
+	 * @deprecated
433
+	 * @return string
434
+	 */
435
+	public static function no_tkt_slctr_end_dv()
436
+	{
437
+		// todo add doing_it_wrong() notice during next major version
438
+		return EED_Ticket_Selector::ticketSelector()->ticketSelectorEndDiv();
439
+	}
440
+
441
+
442
+
443
+	/**
444
+	 * @deprecated 4.9.13
445
+	 * @return string
446
+	 */
447
+	public static function tkt_slctr_end_dv()
448
+	{
449
+		return EED_Ticket_Selector::ticketSelector()->clearTicketSelector();
450
+	}
451
+
452
+
453
+
454
+	/**
455
+	 * @deprecated
456
+	 * @return string
457
+	 */
458
+	public static function clear_tkt_slctr()
459
+	{
460
+		return EED_Ticket_Selector::ticketSelector()->clearTicketSelector();
461
+	}
462
+
463
+
464
+
465
+	/**
466
+	 * @deprecated
467
+	 */
468
+	public static function load_tckt_slctr_assets_admin()
469
+	{
470
+		// todo add doing_it_wrong() notice during next major version
471
+		if (
472
+			EE_Registry::instance()->REQ->get('page') === 'espresso_events'
473
+			&& EE_Registry::instance()->REQ->get('action') === 'edit'
474
+		) {
475
+			$iframe_embed_button = EED_Ticket_Selector::getIframeEmbedButton();
476
+			$iframe_embed_button->embedButtonAssets();
477
+		}
478
+	}
479 479
 
480 480
 
481 481
 }
Please login to merge, or discard this patch.
Spacing   +8 added lines, -8 removed lines patch added patch discarded remove patch
@@ -128,10 +128,10 @@  discard block
 block discarded – undo
128 128
         if (defined('TICKET_SELECTOR_ASSETS_URL')) {
129 129
             return;
130 130
         }
131
-        define('TICKET_SELECTOR_ASSETS_URL', plugin_dir_url(__FILE__) . 'assets' . DS);
131
+        define('TICKET_SELECTOR_ASSETS_URL', plugin_dir_url(__FILE__).'assets'.DS);
132 132
         define(
133 133
             'TICKET_SELECTOR_TEMPLATES_PATH',
134
-            str_replace('\\', DS, plugin_dir_path(__FILE__)) . 'templates' . DS
134
+            str_replace('\\', DS, plugin_dir_path(__FILE__)).'templates'.DS
135 135
         );
136 136
         //if config is not set, initialize
137 137
         if (
@@ -149,7 +149,7 @@  discard block
 block discarded – undo
149 149
      */
150 150
     public static function ticketSelector()
151 151
     {
152
-        if (! EED_Ticket_Selector::$ticket_selector instanceof DisplayTicketSelector) {
152
+        if ( ! EED_Ticket_Selector::$ticket_selector instanceof DisplayTicketSelector) {
153 153
             EED_Ticket_Selector::$ticket_selector = new DisplayTicketSelector(EED_Events_Archive::is_iframe());
154 154
         }
155 155
         return EED_Ticket_Selector::$ticket_selector;
@@ -173,7 +173,7 @@  discard block
 block discarded – undo
173 173
      */
174 174
     public static function getIframeEmbedButton()
175 175
     {
176
-        if (! self::$iframe_embed_button instanceof TicketSelectorIframeEmbedButton) {
176
+        if ( ! self::$iframe_embed_button instanceof TicketSelectorIframeEmbedButton) {
177 177
             self::$iframe_embed_button = new TicketSelectorIframeEmbedButton();
178 178
         }
179 179
         return self::$iframe_embed_button;
@@ -270,7 +270,7 @@  discard block
 block discarded – undo
270 270
             // add some style
271 271
             wp_register_style(
272 272
                 'ticket_selector',
273
-                TICKET_SELECTOR_ASSETS_URL . 'ticket_selector.css',
273
+                TICKET_SELECTOR_ASSETS_URL.'ticket_selector.css',
274 274
                 array(),
275 275
                 EVENT_ESPRESSO_VERSION
276 276
             );
@@ -278,7 +278,7 @@  discard block
 block discarded – undo
278 278
             // make it dance
279 279
             wp_register_script(
280 280
                 'ticket_selector',
281
-                TICKET_SELECTOR_ASSETS_URL . 'ticket_selector.js',
281
+                TICKET_SELECTOR_ASSETS_URL.'ticket_selector.js',
282 282
                 array('espresso_core'),
283 283
                 EVENT_ESPRESSO_VERSION,
284 284
                 true
@@ -327,7 +327,7 @@  discard block
 block discarded – undo
327 327
      */
328 328
     public static function iframeCss(array $iframe_css)
329 329
     {
330
-        $iframe_css['ticket_selector'] = TICKET_SELECTOR_ASSETS_URL . 'ticket_selector.css';
330
+        $iframe_css['ticket_selector'] = TICKET_SELECTOR_ASSETS_URL.'ticket_selector.css';
331 331
         return $iframe_css;
332 332
     }
333 333
 
@@ -341,7 +341,7 @@  discard block
 block discarded – undo
341 341
      */
342 342
     public static function iframeJs(array $iframe_js)
343 343
     {
344
-        $iframe_js['ticket_selector'] = TICKET_SELECTOR_ASSETS_URL . 'ticket_selector.js';
344
+        $iframe_js['ticket_selector'] = TICKET_SELECTOR_ASSETS_URL.'ticket_selector.js';
345 345
         return $iframe_js;
346 346
     }
347 347
 
Please login to merge, or discard this patch.
modules/ticket_selector/DisplayTicketSelector.php 2 patches
Indentation   +734 added lines, -734 removed lines patch added patch discarded remove patch
@@ -36,743 +36,743 @@
 block discarded – undo
36 36
 class DisplayTicketSelector
37 37
 {
38 38
 
39
-    /**
40
-     * event that ticket selector is being generated for
41
-     *
42
-     * @access protected
43
-     * @var EE_Event $event
44
-     */
45
-    protected $event;
46
-
47
-    /**
48
-     * Used to flag when the ticket selector is being called from an external iframe.
49
-     *
50
-     * @var bool $iframe
51
-     */
52
-    protected $iframe = false;
53
-
54
-    /**
55
-     * max attendees that can register for event at one time
56
-     *
57
-     * @var int $max_attendees
58
-     */
59
-    private $max_attendees = EE_INF;
60
-
61
-    /**
62
-     * @var string $date_format
63
-     */
64
-    private $date_format;
65
-
66
-    /**
67
-     * @var string $time_format
68
-     */
69
-    private $time_format;
70
-
71
-    /**
72
-     * @var boolean $display_full_ui
73
-     */
74
-    private $display_full_ui;
75
-
76
-
77
-
78
-    /**
79
-     * DisplayTicketSelector constructor.
80
-     *
81
-     * @param bool $iframe
82
-     */
83
-    public function __construct($iframe = false)
84
-    {
85
-        $this->iframe      = $iframe;
86
-        $this->date_format = apply_filters(
87
-            'FHEE__EED_Ticket_Selector__display_ticket_selector__date_format',
88
-            get_option('date_format')
89
-        );
90
-        $this->time_format = apply_filters(
91
-            'FHEE__EED_Ticket_Selector__display_ticket_selector__time_format',
92
-            get_option('time_format')
93
-        );
94
-    }
95
-
96
-
97
-    /**
98
-     * @return bool
99
-     */
100
-    public function isIframe()
101
-    {
102
-        return $this->iframe;
103
-    }
104
-
105
-
106
-
107
-    /**
108
-     * @param boolean $iframe
109
-     */
110
-    public function setIframe($iframe = true)
111
-    {
112
-        $this->iframe = filter_var($iframe, FILTER_VALIDATE_BOOLEAN);
113
-    }
114
-
115
-
116
-    /**
117
-     * finds and sets the \EE_Event object for use throughout class
118
-     *
119
-     * @param mixed $event
120
-     * @return bool
121
-     * @throws EE_Error
122
-     * @throws InvalidDataTypeException
123
-     * @throws InvalidInterfaceException
124
-     * @throws InvalidArgumentException
125
-     */
126
-    protected function setEvent($event = null)
127
-    {
128
-        if ($event === null) {
129
-            global $post;
130
-            $event = $post;
131
-        }
132
-        if ($event instanceof EE_Event) {
133
-            $this->event = $event;
134
-        } elseif ($event instanceof WP_Post) {
135
-            if (isset($event->EE_Event) && $event->EE_Event instanceof EE_Event) {
136
-                $this->event = $event->EE_Event;
137
-            } elseif ($event->post_type === 'espresso_events') {
138
-                $event->EE_Event = EEM_Event::instance()->instantiate_class_from_post_object($event);
139
-                $this->event     = $event->EE_Event;
140
-            }
141
-        } else {
142
-            $user_msg = __('No Event object or an invalid Event object was supplied.', 'event_espresso');
143
-            $dev_msg  = $user_msg . __(
144
-                    'In order to generate a ticket selector, please ensure you are passing either an EE_Event object or a WP_Post object of the post type "espresso_event" to the EE_Ticket_Selector class constructor.',
145
-                    'event_espresso'
146
-                );
147
-            EE_Error::add_error($user_msg . '||' . $dev_msg, __FILE__, __FUNCTION__, __LINE__);
148
-            return false;
149
-        }
150
-        return true;
151
-    }
152
-
153
-
154
-
155
-    /**
156
-     * @return int
157
-     */
158
-    public function getMaxAttendees()
159
-    {
160
-        return $this->max_attendees;
161
-    }
162
-
163
-
164
-
165
-    /**
166
-     * @param int $max_attendees
167
-     */
168
-    public function setMaxAttendees($max_attendees)
169
-    {
170
-        $this->max_attendees = absint(
171
-            apply_filters(
172
-                'FHEE__EE_Ticket_Selector__display_ticket_selector__max_tickets',
173
-                $max_attendees
174
-            )
175
-        );
176
-    }
177
-
178
-
179
-
180
-    /**
181
-     * Returns whether or not the full ticket selector should be shown or not.
182
-     * Currently, it displays on the frontend (including ajax requests) but not the backend
183
-     *
184
-     * @return bool
185
-     */
186
-    private function display_full_ui()
187
-    {
188
-        if ($this->display_full_ui === null) {
189
-            $this->display_full_ui = ! is_admin() || (defined('DOING_AJAX') && DOING_AJAX);
190
-        }
191
-        return $this->display_full_ui;
192
-    }
193
-
194
-
195
-    /**
196
-     * creates buttons for selecting number of attendees for an event
197
-     *
198
-     * @param WP_Post|int $event
199
-     * @param bool        $view_details
200
-     * @return string
201
-     * @throws EE_Error
202
-     * @throws InvalidArgumentException
203
-     * @throws InvalidDataTypeException
204
-     * @throws InvalidInterfaceException
205
-     */
206
-    public function display($event = null, $view_details = false)
207
-    {
208
-        // reset filter for displaying submit button
209
-        remove_filter('FHEE__EE_Ticket_Selector__display_ticket_selector_submit', '__return_true');
210
-        // poke and prod incoming event till it tells us what it is
211
-        if (! $this->setEvent($event)) {
212
-            return false;
213
-        }
214
-        // begin gathering template arguments by getting event status
215
-        $template_args = array('event_status' => $this->event->get_active_status());
216
-        if (
217
-        $this->activeEventAndShowTicketSelector(
218
-            $event,
219
-            $template_args['event_status'],
220
-            $view_details
221
-        )
222
-        ) {
223
-            return ! is_single() ? $this->displayViewDetailsButton() : '';
224
-        }
225
-        // filter the maximum qty that can appear in the Ticket Selector qty dropdowns
226
-        $this->setMaxAttendees($this->event->additional_limit());
227
-        if ($this->getMaxAttendees() < 1) {
228
-            return $this->ticketSalesClosedMessage();
229
-        }
230
-        // is the event expired ?
231
-        $template_args['event_is_expired'] = $this->event->is_expired();
232
-        if ($template_args['event_is_expired']) {
233
-            return $this->expiredEventMessage();
234
-        }
235
-        // get all tickets for this event ordered by the datetime
236
-        $tickets = $this->getTickets();
237
-        if (count($tickets) < 1) {
238
-            return $this->noTicketAvailableMessage();
239
-        }
240
-        // redirecting to another site for registration ??
241
-        $external_url = (string)$this->event->external_url();
242
-        // if redirecting to another site for registration, then we don't load the TS
243
-        $ticket_selector = $external_url
244
-            ? $this->externalEventRegistration()
245
-            : $this->loadTicketSelector($tickets, $template_args);
246
-        // now set up the form (but not for the admin)
247
-        $ticket_selector = $this->display_full_ui()
248
-            ? $this->formOpen($this->event->ID(), $external_url) . $ticket_selector
249
-            : $ticket_selector;
250
-        // submit button and form close tag
251
-        $ticket_selector .= $this->display_full_ui() ? $this->displaySubmitButton($external_url) : '';
252
-        return $ticket_selector;
253
-    }
254
-
255
-
256
-
257
-    /**
258
-     * displayTicketSelector
259
-     * examines the event properties and determines whether a Ticket Selector should be displayed
260
-     *
261
-     * @param WP_Post|int $event
262
-     * @param string      $_event_active_status
263
-     * @param bool        $view_details
264
-     * @return bool
265
-     * @throws EE_Error
266
-     */
267
-    protected function activeEventAndShowTicketSelector($event, $_event_active_status, $view_details)
268
-    {
269
-        $event_post = $this->event instanceof EE_Event ? $this->event->ID() : $event;
270
-        return $this->display_full_ui()
271
-               && (
272
-                   ! $this->event->display_ticket_selector()
273
-                   || $view_details
274
-                   || post_password_required($event_post)
275
-                   || (
276
-                       $_event_active_status !== EE_Datetime::active
277
-                       && $_event_active_status !== EE_Datetime::upcoming
278
-                       && $_event_active_status !== EE_Datetime::sold_out
279
-                       && ! (
280
-                           $_event_active_status === EE_Datetime::inactive
281
-                           && is_user_logged_in()
282
-                       )
283
-                   )
284
-               );
285
-    }
286
-
287
-
288
-
289
-    /**
290
-     * noTicketAvailableMessage
291
-     * notice displayed if event is expired
292
-     *
293
-     * @return string
294
-     * @throws EE_Error
295
-     */
296
-    protected function expiredEventMessage()
297
-    {
298
-        return '<div class="ee-event-expired-notice"><span class="important-notice">' . esc_html__(
299
-                'We\'re sorry, but all tickets sales have ended because the event is expired.',
300
-                'event_espresso'
301
-            ) . '</span></div><!-- .ee-event-expired-notice -->';
302
-    }
303
-
304
-
305
-
306
-    /**
307
-     * noTicketAvailableMessage
308
-     * notice displayed if event has no more tickets available
309
-     *
310
-     * @return string
311
-     * @throws EE_Error
312
-     */
313
-    protected function noTicketAvailableMessage()
314
-    {
315
-        $no_ticket_available_msg = esc_html__('We\'re sorry, but all ticket sales have ended.', 'event_espresso');
316
-        if (current_user_can('edit_post', $this->event->ID())) {
317
-            $no_ticket_available_msg .= sprintf(
318
-                esc_html__(
319
-                    '%1$sNote to Event Admin:%2$sNo tickets were found for this event. This effectively turns off ticket sales. Please ensure that at least one ticket is available for if you want people to be able to register.%3$s(click to edit this event)%4$s',
320
-                    'event_espresso'
321
-                ),
322
-                '<div class="ee-attention" style="text-align: left;"><b>',
323
-                '</b><br />',
324
-                '<span class="edit-link"><a class="post-edit-link" href="'
325
-                . get_edit_post_link($this->event->ID())
326
-                . '">',
327
-                '</a></span></div><!-- .ee-attention noTicketAvailableMessage -->'
328
-            );
329
-        }
330
-        return '
39
+	/**
40
+	 * event that ticket selector is being generated for
41
+	 *
42
+	 * @access protected
43
+	 * @var EE_Event $event
44
+	 */
45
+	protected $event;
46
+
47
+	/**
48
+	 * Used to flag when the ticket selector is being called from an external iframe.
49
+	 *
50
+	 * @var bool $iframe
51
+	 */
52
+	protected $iframe = false;
53
+
54
+	/**
55
+	 * max attendees that can register for event at one time
56
+	 *
57
+	 * @var int $max_attendees
58
+	 */
59
+	private $max_attendees = EE_INF;
60
+
61
+	/**
62
+	 * @var string $date_format
63
+	 */
64
+	private $date_format;
65
+
66
+	/**
67
+	 * @var string $time_format
68
+	 */
69
+	private $time_format;
70
+
71
+	/**
72
+	 * @var boolean $display_full_ui
73
+	 */
74
+	private $display_full_ui;
75
+
76
+
77
+
78
+	/**
79
+	 * DisplayTicketSelector constructor.
80
+	 *
81
+	 * @param bool $iframe
82
+	 */
83
+	public function __construct($iframe = false)
84
+	{
85
+		$this->iframe      = $iframe;
86
+		$this->date_format = apply_filters(
87
+			'FHEE__EED_Ticket_Selector__display_ticket_selector__date_format',
88
+			get_option('date_format')
89
+		);
90
+		$this->time_format = apply_filters(
91
+			'FHEE__EED_Ticket_Selector__display_ticket_selector__time_format',
92
+			get_option('time_format')
93
+		);
94
+	}
95
+
96
+
97
+	/**
98
+	 * @return bool
99
+	 */
100
+	public function isIframe()
101
+	{
102
+		return $this->iframe;
103
+	}
104
+
105
+
106
+
107
+	/**
108
+	 * @param boolean $iframe
109
+	 */
110
+	public function setIframe($iframe = true)
111
+	{
112
+		$this->iframe = filter_var($iframe, FILTER_VALIDATE_BOOLEAN);
113
+	}
114
+
115
+
116
+	/**
117
+	 * finds and sets the \EE_Event object for use throughout class
118
+	 *
119
+	 * @param mixed $event
120
+	 * @return bool
121
+	 * @throws EE_Error
122
+	 * @throws InvalidDataTypeException
123
+	 * @throws InvalidInterfaceException
124
+	 * @throws InvalidArgumentException
125
+	 */
126
+	protected function setEvent($event = null)
127
+	{
128
+		if ($event === null) {
129
+			global $post;
130
+			$event = $post;
131
+		}
132
+		if ($event instanceof EE_Event) {
133
+			$this->event = $event;
134
+		} elseif ($event instanceof WP_Post) {
135
+			if (isset($event->EE_Event) && $event->EE_Event instanceof EE_Event) {
136
+				$this->event = $event->EE_Event;
137
+			} elseif ($event->post_type === 'espresso_events') {
138
+				$event->EE_Event = EEM_Event::instance()->instantiate_class_from_post_object($event);
139
+				$this->event     = $event->EE_Event;
140
+			}
141
+		} else {
142
+			$user_msg = __('No Event object or an invalid Event object was supplied.', 'event_espresso');
143
+			$dev_msg  = $user_msg . __(
144
+					'In order to generate a ticket selector, please ensure you are passing either an EE_Event object or a WP_Post object of the post type "espresso_event" to the EE_Ticket_Selector class constructor.',
145
+					'event_espresso'
146
+				);
147
+			EE_Error::add_error($user_msg . '||' . $dev_msg, __FILE__, __FUNCTION__, __LINE__);
148
+			return false;
149
+		}
150
+		return true;
151
+	}
152
+
153
+
154
+
155
+	/**
156
+	 * @return int
157
+	 */
158
+	public function getMaxAttendees()
159
+	{
160
+		return $this->max_attendees;
161
+	}
162
+
163
+
164
+
165
+	/**
166
+	 * @param int $max_attendees
167
+	 */
168
+	public function setMaxAttendees($max_attendees)
169
+	{
170
+		$this->max_attendees = absint(
171
+			apply_filters(
172
+				'FHEE__EE_Ticket_Selector__display_ticket_selector__max_tickets',
173
+				$max_attendees
174
+			)
175
+		);
176
+	}
177
+
178
+
179
+
180
+	/**
181
+	 * Returns whether or not the full ticket selector should be shown or not.
182
+	 * Currently, it displays on the frontend (including ajax requests) but not the backend
183
+	 *
184
+	 * @return bool
185
+	 */
186
+	private function display_full_ui()
187
+	{
188
+		if ($this->display_full_ui === null) {
189
+			$this->display_full_ui = ! is_admin() || (defined('DOING_AJAX') && DOING_AJAX);
190
+		}
191
+		return $this->display_full_ui;
192
+	}
193
+
194
+
195
+	/**
196
+	 * creates buttons for selecting number of attendees for an event
197
+	 *
198
+	 * @param WP_Post|int $event
199
+	 * @param bool        $view_details
200
+	 * @return string
201
+	 * @throws EE_Error
202
+	 * @throws InvalidArgumentException
203
+	 * @throws InvalidDataTypeException
204
+	 * @throws InvalidInterfaceException
205
+	 */
206
+	public function display($event = null, $view_details = false)
207
+	{
208
+		// reset filter for displaying submit button
209
+		remove_filter('FHEE__EE_Ticket_Selector__display_ticket_selector_submit', '__return_true');
210
+		// poke and prod incoming event till it tells us what it is
211
+		if (! $this->setEvent($event)) {
212
+			return false;
213
+		}
214
+		// begin gathering template arguments by getting event status
215
+		$template_args = array('event_status' => $this->event->get_active_status());
216
+		if (
217
+		$this->activeEventAndShowTicketSelector(
218
+			$event,
219
+			$template_args['event_status'],
220
+			$view_details
221
+		)
222
+		) {
223
+			return ! is_single() ? $this->displayViewDetailsButton() : '';
224
+		}
225
+		// filter the maximum qty that can appear in the Ticket Selector qty dropdowns
226
+		$this->setMaxAttendees($this->event->additional_limit());
227
+		if ($this->getMaxAttendees() < 1) {
228
+			return $this->ticketSalesClosedMessage();
229
+		}
230
+		// is the event expired ?
231
+		$template_args['event_is_expired'] = $this->event->is_expired();
232
+		if ($template_args['event_is_expired']) {
233
+			return $this->expiredEventMessage();
234
+		}
235
+		// get all tickets for this event ordered by the datetime
236
+		$tickets = $this->getTickets();
237
+		if (count($tickets) < 1) {
238
+			return $this->noTicketAvailableMessage();
239
+		}
240
+		// redirecting to another site for registration ??
241
+		$external_url = (string)$this->event->external_url();
242
+		// if redirecting to another site for registration, then we don't load the TS
243
+		$ticket_selector = $external_url
244
+			? $this->externalEventRegistration()
245
+			: $this->loadTicketSelector($tickets, $template_args);
246
+		// now set up the form (but not for the admin)
247
+		$ticket_selector = $this->display_full_ui()
248
+			? $this->formOpen($this->event->ID(), $external_url) . $ticket_selector
249
+			: $ticket_selector;
250
+		// submit button and form close tag
251
+		$ticket_selector .= $this->display_full_ui() ? $this->displaySubmitButton($external_url) : '';
252
+		return $ticket_selector;
253
+	}
254
+
255
+
256
+
257
+	/**
258
+	 * displayTicketSelector
259
+	 * examines the event properties and determines whether a Ticket Selector should be displayed
260
+	 *
261
+	 * @param WP_Post|int $event
262
+	 * @param string      $_event_active_status
263
+	 * @param bool        $view_details
264
+	 * @return bool
265
+	 * @throws EE_Error
266
+	 */
267
+	protected function activeEventAndShowTicketSelector($event, $_event_active_status, $view_details)
268
+	{
269
+		$event_post = $this->event instanceof EE_Event ? $this->event->ID() : $event;
270
+		return $this->display_full_ui()
271
+			   && (
272
+				   ! $this->event->display_ticket_selector()
273
+				   || $view_details
274
+				   || post_password_required($event_post)
275
+				   || (
276
+					   $_event_active_status !== EE_Datetime::active
277
+					   && $_event_active_status !== EE_Datetime::upcoming
278
+					   && $_event_active_status !== EE_Datetime::sold_out
279
+					   && ! (
280
+						   $_event_active_status === EE_Datetime::inactive
281
+						   && is_user_logged_in()
282
+					   )
283
+				   )
284
+			   );
285
+	}
286
+
287
+
288
+
289
+	/**
290
+	 * noTicketAvailableMessage
291
+	 * notice displayed if event is expired
292
+	 *
293
+	 * @return string
294
+	 * @throws EE_Error
295
+	 */
296
+	protected function expiredEventMessage()
297
+	{
298
+		return '<div class="ee-event-expired-notice"><span class="important-notice">' . esc_html__(
299
+				'We\'re sorry, but all tickets sales have ended because the event is expired.',
300
+				'event_espresso'
301
+			) . '</span></div><!-- .ee-event-expired-notice -->';
302
+	}
303
+
304
+
305
+
306
+	/**
307
+	 * noTicketAvailableMessage
308
+	 * notice displayed if event has no more tickets available
309
+	 *
310
+	 * @return string
311
+	 * @throws EE_Error
312
+	 */
313
+	protected function noTicketAvailableMessage()
314
+	{
315
+		$no_ticket_available_msg = esc_html__('We\'re sorry, but all ticket sales have ended.', 'event_espresso');
316
+		if (current_user_can('edit_post', $this->event->ID())) {
317
+			$no_ticket_available_msg .= sprintf(
318
+				esc_html__(
319
+					'%1$sNote to Event Admin:%2$sNo tickets were found for this event. This effectively turns off ticket sales. Please ensure that at least one ticket is available for if you want people to be able to register.%3$s(click to edit this event)%4$s',
320
+					'event_espresso'
321
+				),
322
+				'<div class="ee-attention" style="text-align: left;"><b>',
323
+				'</b><br />',
324
+				'<span class="edit-link"><a class="post-edit-link" href="'
325
+				. get_edit_post_link($this->event->ID())
326
+				. '">',
327
+				'</a></span></div><!-- .ee-attention noTicketAvailableMessage -->'
328
+			);
329
+		}
330
+		return '
331 331
             <div class="ee-event-expired-notice">
332 332
                 <span class="important-notice">' . $no_ticket_available_msg . '</span>
333 333
             </div><!-- .ee-event-expired-notice -->';
334
-    }
335
-
336
-
337
-
338
-    /**
339
-     * ticketSalesClosed
340
-     * notice displayed if event ticket sales are turned off
341
-     *
342
-     * @return string
343
-     * @throws EE_Error
344
-     */
345
-    protected function ticketSalesClosedMessage()
346
-    {
347
-        $sales_closed_msg = esc_html__(
348
-            'We\'re sorry, but ticket sales have been closed at this time. Please check back again later.',
349
-            'event_espresso'
350
-        );
351
-        if (current_user_can('edit_post', $this->event->ID())) {
352
-            $sales_closed_msg .= sprintf(
353
-                esc_html__(
354
-                    '%sNote to Event Admin:%sThe "Maximum number of tickets allowed per order for this event" in the Event Registration Options has been set to "0". This effectively turns off ticket sales. %s(click to edit this event)%s',
355
-                    'event_espresso'
356
-                ),
357
-                '<div class="ee-attention" style="text-align: left;"><b>',
358
-                '</b><br />',
359
-                '<span class="edit-link"><a class="post-edit-link" href="'
360
-                . get_edit_post_link($this->event->ID())
361
-                . '">',
362
-                '</a></span></div><!-- .ee-attention ticketSalesClosedMessage -->'
363
-            );
364
-        }
365
-        return '<p><span class="important-notice">' . $sales_closed_msg . '</span></p>';
366
-    }
367
-
368
-
369
-
370
-    /**
371
-     * getTickets
372
-     *
373
-     * @return \EE_Base_Class[]|\EE_Ticket[]
374
-     * @throws EE_Error
375
-     * @throws InvalidDataTypeException
376
-     * @throws InvalidInterfaceException
377
-     * @throws InvalidArgumentException
378
-     */
379
-    protected function getTickets()
380
-    {
381
-        $ticket_query_args = array(
382
-            array('Datetime.EVT_ID' => $this->event->ID()),
383
-            'order_by' => array(
384
-                'TKT_order'              => 'ASC',
385
-                'TKT_required'           => 'DESC',
386
-                'TKT_start_date'         => 'ASC',
387
-                'TKT_end_date'           => 'ASC',
388
-                'Datetime.DTT_EVT_start' => 'DESC',
389
-            ),
390
-        );
391
-        if (
392
-        ! (
393
-            EE_Registry::instance()->CFG->template_settings->EED_Ticket_Selector instanceof EE_Ticket_Selector_Config
394
-            && EE_Registry::instance()->CFG->template_settings->EED_Ticket_Selector->show_expired_tickets
395
-        )
396
-        ) {
397
-            //use the correct applicable time query depending on what version of core is being run.
398
-            $current_time                         = method_exists('EEM_Datetime', 'current_time_for_query')
399
-                ? time()
400
-                : current_time('timestamp');
401
-            $ticket_query_args[0]['TKT_end_date'] = array('>', $current_time);
402
-        }
403
-        return EEM_Ticket::instance()->get_all($ticket_query_args);
404
-    }
405
-
406
-
407
-
408
-    /**
409
-     * loadTicketSelector
410
-     * begins to assemble template arguments
411
-     * and decides whether to load a "simple" ticket selector, or the standard
412
-     *
413
-     * @param \EE_Ticket[] $tickets
414
-     * @param array        $template_args
415
-     * @return string
416
-     * @throws EE_Error
417
-     */
418
-    protected function loadTicketSelector(array $tickets, array $template_args)
419
-    {
420
-        $template_args['event']            = $this->event;
421
-        $template_args['EVT_ID']           = $this->event->ID();
422
-        $template_args['event_is_expired'] = $this->event->is_expired();
423
-        $template_args['max_atndz']        = $this->getMaxAttendees();
424
-        $template_args['date_format']      = $this->date_format;
425
-        $template_args['time_format']      = $this->time_format;
426
-        /**
427
-         * Filters the anchor ID used when redirecting to the Ticket Selector if no quantity selected
428
-         *
429
-         * @since 4.9.13
430
-         * @param     string  '#tkt-slctr-tbl-' . $EVT_ID The html ID to anchor to
431
-         * @param int $EVT_ID The Event ID
432
-         */
433
-        $template_args['anchor_id']    = apply_filters(
434
-            'FHEE__EE_Ticket_Selector__redirect_anchor_id',
435
-            '#tkt-slctr-tbl-' . $this->event->ID(),
436
-            $this->event->ID()
437
-        );
438
-        $template_args['tickets']      = $tickets;
439
-        $template_args['ticket_count'] = count($tickets);
440
-        $ticket_selector               = $this->simpleTicketSelector($tickets, $template_args);
441
-        return $ticket_selector instanceof TicketSelectorSimple
442
-            ? $ticket_selector
443
-            : new TicketSelectorStandard(
444
-                $this->event,
445
-                $tickets,
446
-                $this->getMaxAttendees(),
447
-                $template_args,
448
-                $this->date_format,
449
-                $this->time_format
450
-            );
451
-    }
452
-
453
-
454
-
455
-    /**
456
-     * simpleTicketSelector
457
-     * there's one ticket, and max attendees is set to one,
458
-     * so if the event is free, then this is a "simple" ticket selector
459
-     * a.k.a. "Dude Where's my Ticket Selector?"
460
-     *
461
-     * @param \EE_Ticket[] $tickets
462
-     * @param array        $template_args
463
-     * @return string
464
-     * @throws EE_Error
465
-     */
466
-    protected function simpleTicketSelector($tickets, array $template_args)
467
-    {
468
-        // if there is only ONE ticket with a max qty of ONE
469
-        if (count($tickets) > 1 || $this->getMaxAttendees() !== 1) {
470
-            return '';
471
-        }
472
-        /** @var \EE_Ticket $ticket */
473
-        $ticket = reset($tickets);
474
-        // if the ticket is free... then not much need for the ticket selector
475
-        if (
476
-        apply_filters(
477
-            'FHEE__ticket_selector_chart_template__hide_ticket_selector',
478
-            $ticket->is_free(),
479
-            $this->event->ID()
480
-        )
481
-        ) {
482
-            return new TicketSelectorSimple(
483
-                $this->event,
484
-                $ticket,
485
-                $this->getMaxAttendees(),
486
-                $template_args
487
-            );
488
-        }
489
-        return '';
490
-    }
491
-
492
-
493
-
494
-    /**
495
-     * externalEventRegistration
496
-     *
497
-     * @return string
498
-     */
499
-    public function externalEventRegistration()
500
-    {
501
-        // if not we still need to trigger the display of the submit button
502
-        add_filter('FHEE__EE_Ticket_Selector__display_ticket_selector_submit', '__return_true');
503
-        //display notice to admin that registration is external
504
-        return $this->display_full_ui()
505
-            ? esc_html__(
506
-                'Registration is at an external URL for this event.',
507
-                'event_espresso'
508
-            )
509
-            : '';
510
-    }
511
-
512
-
513
-
514
-    /**
515
-     * formOpen
516
-     *
517
-     * @param        int    $ID
518
-     * @param        string $external_url
519
-     * @return        string
520
-     */
521
-    public function formOpen($ID = 0, $external_url = '')
522
-    {
523
-        // if redirecting, we don't need any anything else
524
-        if ($external_url) {
525
-            $html = '<form method="GET" action="' . EEH_URL::refactor_url($external_url) . '"';
526
-            // open link in new window ?
527
-            $html       .= apply_filters(
528
-                'FHEE__EventEspresso_modules_ticket_selector_DisplayTicketSelector__formOpen__external_url_target_blank',
529
-                $this->isIframe(),
530
-                $this
531
-            )
532
-                ? ' target="_blank"'
533
-                : '';
534
-            $html       .= '>';
535
-            $query_args = EEH_URL::get_query_string($external_url);
536
-            foreach ((array)$query_args as $query_arg => $value) {
537
-                $html .= '<input type="hidden" name="' . $query_arg . '" value="' . $value . '">';
538
-            }
539
-            return $html;
540
-        }
541
-        // if there is no submit button, then don't start building a form
542
-        // because the "View Details" button will build its own form
543
-        if (! apply_filters('FHEE__EE_Ticket_Selector__display_ticket_selector_submit', false)) {
544
-            return '';
545
-        }
546
-        $checkout_url = EEH_Event_View::event_link_url($ID);
547
-        if (! $checkout_url) {
548
-            EE_Error::add_error(
549
-                esc_html__('The URL for the Event Details page could not be retrieved.', 'event_espresso'),
550
-                __FILE__,
551
-                __FUNCTION__,
552
-                __LINE__
553
-            );
554
-        }
555
-        // set no cache headers and constants
556
-        EE_System::do_not_cache();
557
-        $extra_params = $this->iframe ? ' target="_blank"' : '';
558
-        $html         = '<form method="POST" action="' . $checkout_url . '"' . $extra_params . '>';
559
-        $html         .= '<input type="hidden" name="ee" value="process_ticket_selections">';
560
-        $html         = apply_filters('FHEE__EE_Ticket_Selector__ticket_selector_form_open__html', $html, $this->event);
561
-        return $html;
562
-    }
563
-
564
-
565
-
566
-    /**
567
-     * displaySubmitButton
568
-     *
569
-     * @param  string $external_url
570
-     * @return string
571
-     * @throws EE_Error
572
-     */
573
-    public function displaySubmitButton($external_url = '')
574
-    {
575
-        $html = '';
576
-        if ($this->display_full_ui()) {
577
-            // standard TS displayed with submit button, ie: "Register Now"
578
-            if (apply_filters('FHEE__EE_Ticket_Selector__display_ticket_selector_submit', false)) {
579
-                $html .= $this->displayRegisterNowButton();
580
-                $html .= empty($external_url)
581
-                    ? $this->ticketSelectorEndDiv()
582
-                    : $this->clearTicketSelector();
583
-                $html .= '<br/>' . $this->formClose();
584
-            } elseif ($this->getMaxAttendees() === 1) {
585
-                // its a "Dude Where's my Ticket Selector?" (DWMTS) type event (ie: $_max_atndz === 1)
586
-                if ($this->event->is_sold_out()) {
587
-                    // then instead of a View Details or Submit button, just display a "Sold Out" message
588
-                    $html .= apply_filters(
589
-                        'FHEE__EE_Ticket_Selector__display_ticket_selector_submit__sold_out_msg',
590
-                        sprintf(
591
-                            __(
592
-                                '%1$s"%2$s" is currently sold out.%4$sPlease check back again later, as spots may become available.%3$s',
593
-                                'event_espresso'
594
-                            ),
595
-                            '<p class="no-ticket-selector-msg clear-float">',
596
-                            $this->event->name(),
597
-                            '</p>',
598
-                            '<br />'
599
-                        ),
600
-                        $this->event
601
-                    );
602
-                    if (
603
-                    apply_filters(
604
-                        'FHEE__EE_Ticket_Selector__display_ticket_selector_submit__no_tickets_but_display_register_now_button',
605
-                        false,
606
-                        $this->event
607
-                    )
608
-                    ) {
609
-                        $html .= $this->displayRegisterNowButton();
610
-                    }
611
-                    // sold out DWMTS event, no TS, no submit or view details button, but has additional content
612
-                    $html .= $this->ticketSelectorEndDiv();
613
-                } elseif (
614
-                    apply_filters('FHEE__EE_Ticket_Selector__hide_ticket_selector', false)
615
-                    && ! is_single()
616
-                ) {
617
-                    // this is a "Dude Where's my Ticket Selector?" (DWMTS) type event,
618
-                    // but no tickets are available, so display event's "View Details" button.
619
-                    // it is being viewed via somewhere other than a single post
620
-                    $html .= $this->displayViewDetailsButton(true);
621
-                } else {
622
-                    $html .= $this->ticketSelectorEndDiv();
623
-                }
624
-            } elseif (is_archive()) {
625
-                // event list, no tickets available so display event's "View Details" button
626
-                $html .= $this->ticketSelectorEndDiv();
627
-                $html .= $this->displayViewDetailsButton();
628
-            } else {
629
-                if (
630
-                apply_filters(
631
-                    'FHEE__EE_Ticket_Selector__display_ticket_selector_submit__no_tickets_but_display_register_now_button',
632
-                    false,
633
-                    $this->event
634
-                )
635
-                ) {
636
-                    $html .= $this->displayRegisterNowButton();
637
-                }
638
-                // no submit or view details button, and no additional content
639
-                $html .= $this->ticketSelectorEndDiv();
640
-            }
641
-            if (! $this->iframe && ! is_archive()) {
642
-                $html .= EEH_Template::powered_by_event_espresso('', '', array('utm_content' => 'ticket_selector'));
643
-            }
644
-        }
645
-        return apply_filters(
646
-            'FHEE__EventEspresso_modules_ticket_selector_DisplayTicketSelector__displaySubmitButton__html',
647
-            $html,
648
-            $this->event,
649
-            $this
650
-        );
651
-    }
652
-
653
-
654
-
655
-    /**
656
-     * @return string
657
-     * @throws EE_Error
658
-     */
659
-    public function displayRegisterNowButton()
660
-    {
661
-        $btn_text     = apply_filters(
662
-            'FHEE__EE_Ticket_Selector__display_ticket_selector_submit__btn_text',
663
-            __('Register Now', 'event_espresso'),
664
-            $this->event
665
-        );
666
-        $external_url = $this->event->external_url();
667
-        $html         = EEH_HTML::div(
668
-            '',
669
-            'ticket-selector-submit-' . $this->event->ID() . '-btn-wrap',
670
-            'ticket-selector-submit-btn-wrap'
671
-        );
672
-        $html         .= '<input id="ticket-selector-submit-' . $this->event->ID() . '-btn"';
673
-        $html         .= ' class="ticket-selector-submit-btn ';
674
-        $html         .= empty($external_url) ? 'ticket-selector-submit-ajax"' : '"';
675
-        $html         .= ' type="submit" value="' . $btn_text . '" />';
676
-        $html         .= EEH_HTML::divx() . '<!-- .ticket-selector-submit-btn-wrap -->';
677
-        $html         .= apply_filters(
678
-            'FHEE__EE_Ticket_Selector__after_ticket_selector_submit',
679
-            '',
680
-            $this->event
681
-        );
682
-        return $html;
683
-    }
684
-
685
-
686
-    /**
687
-     * displayViewDetailsButton
688
-     *
689
-     * @param bool $DWMTS indicates a "Dude Where's my Ticket Selector?" (DWMTS) type event
690
-     *                    (ie: $_max_atndz === 1) where there are no available tickets,
691
-     *                    either because they are sold out, expired, or not yet on sale.
692
-     *                    In this case, we need to close the form BEFORE adding any closing divs
693
-     * @return string
694
-     * @throws EE_Error
695
-     */
696
-    public function displayViewDetailsButton($DWMTS = false)
697
-    {
698
-        if (! $this->event->get_permalink()) {
699
-            EE_Error::add_error(
700
-                esc_html__('The URL for the Event Details page could not be retrieved.', 'event_espresso'),
701
-                __FILE__,
702
-                __FUNCTION__,
703
-                __LINE__
704
-            );
705
-        }
706
-        $view_details_btn = '<form method="POST" action="';
707
-        $view_details_btn .= apply_filters(
708
-            'FHEE__EE_Ticket_Selector__display_view_details_btn__btn_url',
709
-            $this->event->get_permalink(),
710
-            $this->event
711
-        );
712
-        $view_details_btn .= '"';
713
-        // open link in new window ?
714
-        $view_details_btn .= apply_filters(
715
-            'FHEE__EventEspresso_modules_ticket_selector_DisplayTicketSelector__displayViewDetailsButton__url_target_blank',
716
-            $this->isIframe(),
717
-            $this
718
-        )
719
-            ? ' target="_blank"'
720
-            : '';
721
-        $view_details_btn .= '>';
722
-        $btn_text         = apply_filters(
723
-            'FHEE__EE_Ticket_Selector__display_view_details_btn__btn_text',
724
-            esc_html__('View Details', 'event_espresso'),
725
-            $this->event
726
-        );
727
-        $view_details_btn .= '<input id="ticket-selector-submit-'
728
-                             . $this->event->ID()
729
-                             . '-btn" class="ticket-selector-submit-btn view-details-btn" type="submit" value="'
730
-                             . $btn_text
731
-                             . '" />';
732
-        $view_details_btn .= apply_filters('FHEE__EE_Ticket_Selector__after_view_details_btn', '', $this->event);
733
-        if ($DWMTS) {
734
-            $view_details_btn .= $this->formClose();
735
-            $view_details_btn .= $this->ticketSelectorEndDiv();
736
-            $view_details_btn .= '<br/>';
737
-        } else {
738
-            $view_details_btn .= $this->clearTicketSelector();
739
-            $view_details_btn .= '<br/>';
740
-            $view_details_btn .= $this->formClose();
741
-        }
742
-        return $view_details_btn;
743
-    }
744
-
745
-
746
-
747
-    /**
748
-     * @return string
749
-     */
750
-    public function ticketSelectorEndDiv()
751
-    {
752
-        return $this->clearTicketSelector() . '</div><!-- ticketSelectorEndDiv -->';
753
-    }
754
-
755
-
756
-
757
-    /**
758
-     * @return string
759
-     */
760
-    public function clearTicketSelector()
761
-    {
762
-        // standard TS displayed, appears after a "Register Now" or "view Details" button
763
-        return '<div class="clear"></div><!-- clearTicketSelector -->';
764
-    }
765
-
766
-
767
-
768
-    /**
769
-     * @access        public
770
-     * @return        string
771
-     */
772
-    public function formClose()
773
-    {
774
-        return '</form>';
775
-    }
334
+	}
335
+
336
+
337
+
338
+	/**
339
+	 * ticketSalesClosed
340
+	 * notice displayed if event ticket sales are turned off
341
+	 *
342
+	 * @return string
343
+	 * @throws EE_Error
344
+	 */
345
+	protected function ticketSalesClosedMessage()
346
+	{
347
+		$sales_closed_msg = esc_html__(
348
+			'We\'re sorry, but ticket sales have been closed at this time. Please check back again later.',
349
+			'event_espresso'
350
+		);
351
+		if (current_user_can('edit_post', $this->event->ID())) {
352
+			$sales_closed_msg .= sprintf(
353
+				esc_html__(
354
+					'%sNote to Event Admin:%sThe "Maximum number of tickets allowed per order for this event" in the Event Registration Options has been set to "0". This effectively turns off ticket sales. %s(click to edit this event)%s',
355
+					'event_espresso'
356
+				),
357
+				'<div class="ee-attention" style="text-align: left;"><b>',
358
+				'</b><br />',
359
+				'<span class="edit-link"><a class="post-edit-link" href="'
360
+				. get_edit_post_link($this->event->ID())
361
+				. '">',
362
+				'</a></span></div><!-- .ee-attention ticketSalesClosedMessage -->'
363
+			);
364
+		}
365
+		return '<p><span class="important-notice">' . $sales_closed_msg . '</span></p>';
366
+	}
367
+
368
+
369
+
370
+	/**
371
+	 * getTickets
372
+	 *
373
+	 * @return \EE_Base_Class[]|\EE_Ticket[]
374
+	 * @throws EE_Error
375
+	 * @throws InvalidDataTypeException
376
+	 * @throws InvalidInterfaceException
377
+	 * @throws InvalidArgumentException
378
+	 */
379
+	protected function getTickets()
380
+	{
381
+		$ticket_query_args = array(
382
+			array('Datetime.EVT_ID' => $this->event->ID()),
383
+			'order_by' => array(
384
+				'TKT_order'              => 'ASC',
385
+				'TKT_required'           => 'DESC',
386
+				'TKT_start_date'         => 'ASC',
387
+				'TKT_end_date'           => 'ASC',
388
+				'Datetime.DTT_EVT_start' => 'DESC',
389
+			),
390
+		);
391
+		if (
392
+		! (
393
+			EE_Registry::instance()->CFG->template_settings->EED_Ticket_Selector instanceof EE_Ticket_Selector_Config
394
+			&& EE_Registry::instance()->CFG->template_settings->EED_Ticket_Selector->show_expired_tickets
395
+		)
396
+		) {
397
+			//use the correct applicable time query depending on what version of core is being run.
398
+			$current_time                         = method_exists('EEM_Datetime', 'current_time_for_query')
399
+				? time()
400
+				: current_time('timestamp');
401
+			$ticket_query_args[0]['TKT_end_date'] = array('>', $current_time);
402
+		}
403
+		return EEM_Ticket::instance()->get_all($ticket_query_args);
404
+	}
405
+
406
+
407
+
408
+	/**
409
+	 * loadTicketSelector
410
+	 * begins to assemble template arguments
411
+	 * and decides whether to load a "simple" ticket selector, or the standard
412
+	 *
413
+	 * @param \EE_Ticket[] $tickets
414
+	 * @param array        $template_args
415
+	 * @return string
416
+	 * @throws EE_Error
417
+	 */
418
+	protected function loadTicketSelector(array $tickets, array $template_args)
419
+	{
420
+		$template_args['event']            = $this->event;
421
+		$template_args['EVT_ID']           = $this->event->ID();
422
+		$template_args['event_is_expired'] = $this->event->is_expired();
423
+		$template_args['max_atndz']        = $this->getMaxAttendees();
424
+		$template_args['date_format']      = $this->date_format;
425
+		$template_args['time_format']      = $this->time_format;
426
+		/**
427
+		 * Filters the anchor ID used when redirecting to the Ticket Selector if no quantity selected
428
+		 *
429
+		 * @since 4.9.13
430
+		 * @param     string  '#tkt-slctr-tbl-' . $EVT_ID The html ID to anchor to
431
+		 * @param int $EVT_ID The Event ID
432
+		 */
433
+		$template_args['anchor_id']    = apply_filters(
434
+			'FHEE__EE_Ticket_Selector__redirect_anchor_id',
435
+			'#tkt-slctr-tbl-' . $this->event->ID(),
436
+			$this->event->ID()
437
+		);
438
+		$template_args['tickets']      = $tickets;
439
+		$template_args['ticket_count'] = count($tickets);
440
+		$ticket_selector               = $this->simpleTicketSelector($tickets, $template_args);
441
+		return $ticket_selector instanceof TicketSelectorSimple
442
+			? $ticket_selector
443
+			: new TicketSelectorStandard(
444
+				$this->event,
445
+				$tickets,
446
+				$this->getMaxAttendees(),
447
+				$template_args,
448
+				$this->date_format,
449
+				$this->time_format
450
+			);
451
+	}
452
+
453
+
454
+
455
+	/**
456
+	 * simpleTicketSelector
457
+	 * there's one ticket, and max attendees is set to one,
458
+	 * so if the event is free, then this is a "simple" ticket selector
459
+	 * a.k.a. "Dude Where's my Ticket Selector?"
460
+	 *
461
+	 * @param \EE_Ticket[] $tickets
462
+	 * @param array        $template_args
463
+	 * @return string
464
+	 * @throws EE_Error
465
+	 */
466
+	protected function simpleTicketSelector($tickets, array $template_args)
467
+	{
468
+		// if there is only ONE ticket with a max qty of ONE
469
+		if (count($tickets) > 1 || $this->getMaxAttendees() !== 1) {
470
+			return '';
471
+		}
472
+		/** @var \EE_Ticket $ticket */
473
+		$ticket = reset($tickets);
474
+		// if the ticket is free... then not much need for the ticket selector
475
+		if (
476
+		apply_filters(
477
+			'FHEE__ticket_selector_chart_template__hide_ticket_selector',
478
+			$ticket->is_free(),
479
+			$this->event->ID()
480
+		)
481
+		) {
482
+			return new TicketSelectorSimple(
483
+				$this->event,
484
+				$ticket,
485
+				$this->getMaxAttendees(),
486
+				$template_args
487
+			);
488
+		}
489
+		return '';
490
+	}
491
+
492
+
493
+
494
+	/**
495
+	 * externalEventRegistration
496
+	 *
497
+	 * @return string
498
+	 */
499
+	public function externalEventRegistration()
500
+	{
501
+		// if not we still need to trigger the display of the submit button
502
+		add_filter('FHEE__EE_Ticket_Selector__display_ticket_selector_submit', '__return_true');
503
+		//display notice to admin that registration is external
504
+		return $this->display_full_ui()
505
+			? esc_html__(
506
+				'Registration is at an external URL for this event.',
507
+				'event_espresso'
508
+			)
509
+			: '';
510
+	}
511
+
512
+
513
+
514
+	/**
515
+	 * formOpen
516
+	 *
517
+	 * @param        int    $ID
518
+	 * @param        string $external_url
519
+	 * @return        string
520
+	 */
521
+	public function formOpen($ID = 0, $external_url = '')
522
+	{
523
+		// if redirecting, we don't need any anything else
524
+		if ($external_url) {
525
+			$html = '<form method="GET" action="' . EEH_URL::refactor_url($external_url) . '"';
526
+			// open link in new window ?
527
+			$html       .= apply_filters(
528
+				'FHEE__EventEspresso_modules_ticket_selector_DisplayTicketSelector__formOpen__external_url_target_blank',
529
+				$this->isIframe(),
530
+				$this
531
+			)
532
+				? ' target="_blank"'
533
+				: '';
534
+			$html       .= '>';
535
+			$query_args = EEH_URL::get_query_string($external_url);
536
+			foreach ((array)$query_args as $query_arg => $value) {
537
+				$html .= '<input type="hidden" name="' . $query_arg . '" value="' . $value . '">';
538
+			}
539
+			return $html;
540
+		}
541
+		// if there is no submit button, then don't start building a form
542
+		// because the "View Details" button will build its own form
543
+		if (! apply_filters('FHEE__EE_Ticket_Selector__display_ticket_selector_submit', false)) {
544
+			return '';
545
+		}
546
+		$checkout_url = EEH_Event_View::event_link_url($ID);
547
+		if (! $checkout_url) {
548
+			EE_Error::add_error(
549
+				esc_html__('The URL for the Event Details page could not be retrieved.', 'event_espresso'),
550
+				__FILE__,
551
+				__FUNCTION__,
552
+				__LINE__
553
+			);
554
+		}
555
+		// set no cache headers and constants
556
+		EE_System::do_not_cache();
557
+		$extra_params = $this->iframe ? ' target="_blank"' : '';
558
+		$html         = '<form method="POST" action="' . $checkout_url . '"' . $extra_params . '>';
559
+		$html         .= '<input type="hidden" name="ee" value="process_ticket_selections">';
560
+		$html         = apply_filters('FHEE__EE_Ticket_Selector__ticket_selector_form_open__html', $html, $this->event);
561
+		return $html;
562
+	}
563
+
564
+
565
+
566
+	/**
567
+	 * displaySubmitButton
568
+	 *
569
+	 * @param  string $external_url
570
+	 * @return string
571
+	 * @throws EE_Error
572
+	 */
573
+	public function displaySubmitButton($external_url = '')
574
+	{
575
+		$html = '';
576
+		if ($this->display_full_ui()) {
577
+			// standard TS displayed with submit button, ie: "Register Now"
578
+			if (apply_filters('FHEE__EE_Ticket_Selector__display_ticket_selector_submit', false)) {
579
+				$html .= $this->displayRegisterNowButton();
580
+				$html .= empty($external_url)
581
+					? $this->ticketSelectorEndDiv()
582
+					: $this->clearTicketSelector();
583
+				$html .= '<br/>' . $this->formClose();
584
+			} elseif ($this->getMaxAttendees() === 1) {
585
+				// its a "Dude Where's my Ticket Selector?" (DWMTS) type event (ie: $_max_atndz === 1)
586
+				if ($this->event->is_sold_out()) {
587
+					// then instead of a View Details or Submit button, just display a "Sold Out" message
588
+					$html .= apply_filters(
589
+						'FHEE__EE_Ticket_Selector__display_ticket_selector_submit__sold_out_msg',
590
+						sprintf(
591
+							__(
592
+								'%1$s"%2$s" is currently sold out.%4$sPlease check back again later, as spots may become available.%3$s',
593
+								'event_espresso'
594
+							),
595
+							'<p class="no-ticket-selector-msg clear-float">',
596
+							$this->event->name(),
597
+							'</p>',
598
+							'<br />'
599
+						),
600
+						$this->event
601
+					);
602
+					if (
603
+					apply_filters(
604
+						'FHEE__EE_Ticket_Selector__display_ticket_selector_submit__no_tickets_but_display_register_now_button',
605
+						false,
606
+						$this->event
607
+					)
608
+					) {
609
+						$html .= $this->displayRegisterNowButton();
610
+					}
611
+					// sold out DWMTS event, no TS, no submit or view details button, but has additional content
612
+					$html .= $this->ticketSelectorEndDiv();
613
+				} elseif (
614
+					apply_filters('FHEE__EE_Ticket_Selector__hide_ticket_selector', false)
615
+					&& ! is_single()
616
+				) {
617
+					// this is a "Dude Where's my Ticket Selector?" (DWMTS) type event,
618
+					// but no tickets are available, so display event's "View Details" button.
619
+					// it is being viewed via somewhere other than a single post
620
+					$html .= $this->displayViewDetailsButton(true);
621
+				} else {
622
+					$html .= $this->ticketSelectorEndDiv();
623
+				}
624
+			} elseif (is_archive()) {
625
+				// event list, no tickets available so display event's "View Details" button
626
+				$html .= $this->ticketSelectorEndDiv();
627
+				$html .= $this->displayViewDetailsButton();
628
+			} else {
629
+				if (
630
+				apply_filters(
631
+					'FHEE__EE_Ticket_Selector__display_ticket_selector_submit__no_tickets_but_display_register_now_button',
632
+					false,
633
+					$this->event
634
+				)
635
+				) {
636
+					$html .= $this->displayRegisterNowButton();
637
+				}
638
+				// no submit or view details button, and no additional content
639
+				$html .= $this->ticketSelectorEndDiv();
640
+			}
641
+			if (! $this->iframe && ! is_archive()) {
642
+				$html .= EEH_Template::powered_by_event_espresso('', '', array('utm_content' => 'ticket_selector'));
643
+			}
644
+		}
645
+		return apply_filters(
646
+			'FHEE__EventEspresso_modules_ticket_selector_DisplayTicketSelector__displaySubmitButton__html',
647
+			$html,
648
+			$this->event,
649
+			$this
650
+		);
651
+	}
652
+
653
+
654
+
655
+	/**
656
+	 * @return string
657
+	 * @throws EE_Error
658
+	 */
659
+	public function displayRegisterNowButton()
660
+	{
661
+		$btn_text     = apply_filters(
662
+			'FHEE__EE_Ticket_Selector__display_ticket_selector_submit__btn_text',
663
+			__('Register Now', 'event_espresso'),
664
+			$this->event
665
+		);
666
+		$external_url = $this->event->external_url();
667
+		$html         = EEH_HTML::div(
668
+			'',
669
+			'ticket-selector-submit-' . $this->event->ID() . '-btn-wrap',
670
+			'ticket-selector-submit-btn-wrap'
671
+		);
672
+		$html         .= '<input id="ticket-selector-submit-' . $this->event->ID() . '-btn"';
673
+		$html         .= ' class="ticket-selector-submit-btn ';
674
+		$html         .= empty($external_url) ? 'ticket-selector-submit-ajax"' : '"';
675
+		$html         .= ' type="submit" value="' . $btn_text . '" />';
676
+		$html         .= EEH_HTML::divx() . '<!-- .ticket-selector-submit-btn-wrap -->';
677
+		$html         .= apply_filters(
678
+			'FHEE__EE_Ticket_Selector__after_ticket_selector_submit',
679
+			'',
680
+			$this->event
681
+		);
682
+		return $html;
683
+	}
684
+
685
+
686
+	/**
687
+	 * displayViewDetailsButton
688
+	 *
689
+	 * @param bool $DWMTS indicates a "Dude Where's my Ticket Selector?" (DWMTS) type event
690
+	 *                    (ie: $_max_atndz === 1) where there are no available tickets,
691
+	 *                    either because they are sold out, expired, or not yet on sale.
692
+	 *                    In this case, we need to close the form BEFORE adding any closing divs
693
+	 * @return string
694
+	 * @throws EE_Error
695
+	 */
696
+	public function displayViewDetailsButton($DWMTS = false)
697
+	{
698
+		if (! $this->event->get_permalink()) {
699
+			EE_Error::add_error(
700
+				esc_html__('The URL for the Event Details page could not be retrieved.', 'event_espresso'),
701
+				__FILE__,
702
+				__FUNCTION__,
703
+				__LINE__
704
+			);
705
+		}
706
+		$view_details_btn = '<form method="POST" action="';
707
+		$view_details_btn .= apply_filters(
708
+			'FHEE__EE_Ticket_Selector__display_view_details_btn__btn_url',
709
+			$this->event->get_permalink(),
710
+			$this->event
711
+		);
712
+		$view_details_btn .= '"';
713
+		// open link in new window ?
714
+		$view_details_btn .= apply_filters(
715
+			'FHEE__EventEspresso_modules_ticket_selector_DisplayTicketSelector__displayViewDetailsButton__url_target_blank',
716
+			$this->isIframe(),
717
+			$this
718
+		)
719
+			? ' target="_blank"'
720
+			: '';
721
+		$view_details_btn .= '>';
722
+		$btn_text         = apply_filters(
723
+			'FHEE__EE_Ticket_Selector__display_view_details_btn__btn_text',
724
+			esc_html__('View Details', 'event_espresso'),
725
+			$this->event
726
+		);
727
+		$view_details_btn .= '<input id="ticket-selector-submit-'
728
+							 . $this->event->ID()
729
+							 . '-btn" class="ticket-selector-submit-btn view-details-btn" type="submit" value="'
730
+							 . $btn_text
731
+							 . '" />';
732
+		$view_details_btn .= apply_filters('FHEE__EE_Ticket_Selector__after_view_details_btn', '', $this->event);
733
+		if ($DWMTS) {
734
+			$view_details_btn .= $this->formClose();
735
+			$view_details_btn .= $this->ticketSelectorEndDiv();
736
+			$view_details_btn .= '<br/>';
737
+		} else {
738
+			$view_details_btn .= $this->clearTicketSelector();
739
+			$view_details_btn .= '<br/>';
740
+			$view_details_btn .= $this->formClose();
741
+		}
742
+		return $view_details_btn;
743
+	}
744
+
745
+
746
+
747
+	/**
748
+	 * @return string
749
+	 */
750
+	public function ticketSelectorEndDiv()
751
+	{
752
+		return $this->clearTicketSelector() . '</div><!-- ticketSelectorEndDiv -->';
753
+	}
754
+
755
+
756
+
757
+	/**
758
+	 * @return string
759
+	 */
760
+	public function clearTicketSelector()
761
+	{
762
+		// standard TS displayed, appears after a "Register Now" or "view Details" button
763
+		return '<div class="clear"></div><!-- clearTicketSelector -->';
764
+	}
765
+
766
+
767
+
768
+	/**
769
+	 * @access        public
770
+	 * @return        string
771
+	 */
772
+	public function formClose()
773
+	{
774
+		return '</form>';
775
+	}
776 776
 
777 777
 
778 778
 
Please login to merge, or discard this patch.
Spacing   +31 added lines, -31 removed lines patch added patch discarded remove patch
@@ -19,7 +19,7 @@  discard block
 block discarded – undo
19 19
 use InvalidArgumentException;
20 20
 use WP_Post;
21 21
 
22
-defined('EVENT_ESPRESSO_VERSION')|| exit('No direct script access allowed');
22
+defined('EVENT_ESPRESSO_VERSION') || exit('No direct script access allowed');
23 23
 
24 24
 
25 25
 
@@ -140,11 +140,11 @@  discard block
 block discarded – undo
140 140
             }
141 141
         } else {
142 142
             $user_msg = __('No Event object or an invalid Event object was supplied.', 'event_espresso');
143
-            $dev_msg  = $user_msg . __(
143
+            $dev_msg  = $user_msg.__(
144 144
                     'In order to generate a ticket selector, please ensure you are passing either an EE_Event object or a WP_Post object of the post type "espresso_event" to the EE_Ticket_Selector class constructor.',
145 145
                     'event_espresso'
146 146
                 );
147
-            EE_Error::add_error($user_msg . '||' . $dev_msg, __FILE__, __FUNCTION__, __LINE__);
147
+            EE_Error::add_error($user_msg.'||'.$dev_msg, __FILE__, __FUNCTION__, __LINE__);
148 148
             return false;
149 149
         }
150 150
         return true;
@@ -208,7 +208,7 @@  discard block
 block discarded – undo
208 208
         // reset filter for displaying submit button
209 209
         remove_filter('FHEE__EE_Ticket_Selector__display_ticket_selector_submit', '__return_true');
210 210
         // poke and prod incoming event till it tells us what it is
211
-        if (! $this->setEvent($event)) {
211
+        if ( ! $this->setEvent($event)) {
212 212
             return false;
213 213
         }
214 214
         // begin gathering template arguments by getting event status
@@ -238,14 +238,14 @@  discard block
 block discarded – undo
238 238
             return $this->noTicketAvailableMessage();
239 239
         }
240 240
         // redirecting to another site for registration ??
241
-        $external_url = (string)$this->event->external_url();
241
+        $external_url = (string) $this->event->external_url();
242 242
         // if redirecting to another site for registration, then we don't load the TS
243 243
         $ticket_selector = $external_url
244 244
             ? $this->externalEventRegistration()
245 245
             : $this->loadTicketSelector($tickets, $template_args);
246 246
         // now set up the form (but not for the admin)
247 247
         $ticket_selector = $this->display_full_ui()
248
-            ? $this->formOpen($this->event->ID(), $external_url) . $ticket_selector
248
+            ? $this->formOpen($this->event->ID(), $external_url).$ticket_selector
249 249
             : $ticket_selector;
250 250
         // submit button and form close tag
251 251
         $ticket_selector .= $this->display_full_ui() ? $this->displaySubmitButton($external_url) : '';
@@ -295,10 +295,10 @@  discard block
 block discarded – undo
295 295
      */
296 296
     protected function expiredEventMessage()
297 297
     {
298
-        return '<div class="ee-event-expired-notice"><span class="important-notice">' . esc_html__(
298
+        return '<div class="ee-event-expired-notice"><span class="important-notice">'.esc_html__(
299 299
                 'We\'re sorry, but all tickets sales have ended because the event is expired.',
300 300
                 'event_espresso'
301
-            ) . '</span></div><!-- .ee-event-expired-notice -->';
301
+            ).'</span></div><!-- .ee-event-expired-notice -->';
302 302
     }
303 303
 
304 304
 
@@ -329,7 +329,7 @@  discard block
 block discarded – undo
329 329
         }
330 330
         return '
331 331
             <div class="ee-event-expired-notice">
332
-                <span class="important-notice">' . $no_ticket_available_msg . '</span>
332
+                <span class="important-notice">' . $no_ticket_available_msg.'</span>
333 333
             </div><!-- .ee-event-expired-notice -->';
334 334
     }
335 335
 
@@ -362,7 +362,7 @@  discard block
 block discarded – undo
362 362
                 '</a></span></div><!-- .ee-attention ticketSalesClosedMessage -->'
363 363
             );
364 364
         }
365
-        return '<p><span class="important-notice">' . $sales_closed_msg . '</span></p>';
365
+        return '<p><span class="important-notice">'.$sales_closed_msg.'</span></p>';
366 366
     }
367 367
 
368 368
 
@@ -430,9 +430,9 @@  discard block
 block discarded – undo
430 430
          * @param     string  '#tkt-slctr-tbl-' . $EVT_ID The html ID to anchor to
431 431
          * @param int $EVT_ID The Event ID
432 432
          */
433
-        $template_args['anchor_id']    = apply_filters(
433
+        $template_args['anchor_id'] = apply_filters(
434 434
             'FHEE__EE_Ticket_Selector__redirect_anchor_id',
435
-            '#tkt-slctr-tbl-' . $this->event->ID(),
435
+            '#tkt-slctr-tbl-'.$this->event->ID(),
436 436
             $this->event->ID()
437 437
         );
438 438
         $template_args['tickets']      = $tickets;
@@ -522,29 +522,29 @@  discard block
 block discarded – undo
522 522
     {
523 523
         // if redirecting, we don't need any anything else
524 524
         if ($external_url) {
525
-            $html = '<form method="GET" action="' . EEH_URL::refactor_url($external_url) . '"';
525
+            $html = '<form method="GET" action="'.EEH_URL::refactor_url($external_url).'"';
526 526
             // open link in new window ?
527
-            $html       .= apply_filters(
527
+            $html .= apply_filters(
528 528
                 'FHEE__EventEspresso_modules_ticket_selector_DisplayTicketSelector__formOpen__external_url_target_blank',
529 529
                 $this->isIframe(),
530 530
                 $this
531 531
             )
532 532
                 ? ' target="_blank"'
533 533
                 : '';
534
-            $html       .= '>';
534
+            $html .= '>';
535 535
             $query_args = EEH_URL::get_query_string($external_url);
536
-            foreach ((array)$query_args as $query_arg => $value) {
537
-                $html .= '<input type="hidden" name="' . $query_arg . '" value="' . $value . '">';
536
+            foreach ((array) $query_args as $query_arg => $value) {
537
+                $html .= '<input type="hidden" name="'.$query_arg.'" value="'.$value.'">';
538 538
             }
539 539
             return $html;
540 540
         }
541 541
         // if there is no submit button, then don't start building a form
542 542
         // because the "View Details" button will build its own form
543
-        if (! apply_filters('FHEE__EE_Ticket_Selector__display_ticket_selector_submit', false)) {
543
+        if ( ! apply_filters('FHEE__EE_Ticket_Selector__display_ticket_selector_submit', false)) {
544 544
             return '';
545 545
         }
546 546
         $checkout_url = EEH_Event_View::event_link_url($ID);
547
-        if (! $checkout_url) {
547
+        if ( ! $checkout_url) {
548 548
             EE_Error::add_error(
549 549
                 esc_html__('The URL for the Event Details page could not be retrieved.', 'event_espresso'),
550 550
                 __FILE__,
@@ -555,8 +555,8 @@  discard block
 block discarded – undo
555 555
         // set no cache headers and constants
556 556
         EE_System::do_not_cache();
557 557
         $extra_params = $this->iframe ? ' target="_blank"' : '';
558
-        $html         = '<form method="POST" action="' . $checkout_url . '"' . $extra_params . '>';
559
-        $html         .= '<input type="hidden" name="ee" value="process_ticket_selections">';
558
+        $html         = '<form method="POST" action="'.$checkout_url.'"'.$extra_params.'>';
559
+        $html .= '<input type="hidden" name="ee" value="process_ticket_selections">';
560 560
         $html         = apply_filters('FHEE__EE_Ticket_Selector__ticket_selector_form_open__html', $html, $this->event);
561 561
         return $html;
562 562
     }
@@ -580,7 +580,7 @@  discard block
 block discarded – undo
580 580
                 $html .= empty($external_url)
581 581
                     ? $this->ticketSelectorEndDiv()
582 582
                     : $this->clearTicketSelector();
583
-                $html .= '<br/>' . $this->formClose();
583
+                $html .= '<br/>'.$this->formClose();
584 584
             } elseif ($this->getMaxAttendees() === 1) {
585 585
                 // its a "Dude Where's my Ticket Selector?" (DWMTS) type event (ie: $_max_atndz === 1)
586 586
                 if ($this->event->is_sold_out()) {
@@ -638,7 +638,7 @@  discard block
 block discarded – undo
638 638
                 // no submit or view details button, and no additional content
639 639
                 $html .= $this->ticketSelectorEndDiv();
640 640
             }
641
-            if (! $this->iframe && ! is_archive()) {
641
+            if ( ! $this->iframe && ! is_archive()) {
642 642
                 $html .= EEH_Template::powered_by_event_espresso('', '', array('utm_content' => 'ticket_selector'));
643 643
             }
644 644
         }
@@ -658,7 +658,7 @@  discard block
 block discarded – undo
658 658
      */
659 659
     public function displayRegisterNowButton()
660 660
     {
661
-        $btn_text     = apply_filters(
661
+        $btn_text = apply_filters(
662 662
             'FHEE__EE_Ticket_Selector__display_ticket_selector_submit__btn_text',
663 663
             __('Register Now', 'event_espresso'),
664 664
             $this->event
@@ -666,14 +666,14 @@  discard block
 block discarded – undo
666 666
         $external_url = $this->event->external_url();
667 667
         $html         = EEH_HTML::div(
668 668
             '',
669
-            'ticket-selector-submit-' . $this->event->ID() . '-btn-wrap',
669
+            'ticket-selector-submit-'.$this->event->ID().'-btn-wrap',
670 670
             'ticket-selector-submit-btn-wrap'
671 671
         );
672
-        $html         .= '<input id="ticket-selector-submit-' . $this->event->ID() . '-btn"';
672
+        $html         .= '<input id="ticket-selector-submit-'.$this->event->ID().'-btn"';
673 673
         $html         .= ' class="ticket-selector-submit-btn ';
674 674
         $html         .= empty($external_url) ? 'ticket-selector-submit-ajax"' : '"';
675
-        $html         .= ' type="submit" value="' . $btn_text . '" />';
676
-        $html         .= EEH_HTML::divx() . '<!-- .ticket-selector-submit-btn-wrap -->';
675
+        $html         .= ' type="submit" value="'.$btn_text.'" />';
676
+        $html         .= EEH_HTML::divx().'<!-- .ticket-selector-submit-btn-wrap -->';
677 677
         $html         .= apply_filters(
678 678
             'FHEE__EE_Ticket_Selector__after_ticket_selector_submit',
679 679
             '',
@@ -695,7 +695,7 @@  discard block
 block discarded – undo
695 695
      */
696 696
     public function displayViewDetailsButton($DWMTS = false)
697 697
     {
698
-        if (! $this->event->get_permalink()) {
698
+        if ( ! $this->event->get_permalink()) {
699 699
             EE_Error::add_error(
700 700
                 esc_html__('The URL for the Event Details page could not be retrieved.', 'event_espresso'),
701 701
                 __FILE__,
@@ -719,7 +719,7 @@  discard block
 block discarded – undo
719 719
             ? ' target="_blank"'
720 720
             : '';
721 721
         $view_details_btn .= '>';
722
-        $btn_text         = apply_filters(
722
+        $btn_text = apply_filters(
723 723
             'FHEE__EE_Ticket_Selector__display_view_details_btn__btn_text',
724 724
             esc_html__('View Details', 'event_espresso'),
725 725
             $this->event
@@ -749,7 +749,7 @@  discard block
 block discarded – undo
749 749
      */
750 750
     public function ticketSelectorEndDiv()
751 751
     {
752
-        return $this->clearTicketSelector() . '</div><!-- ticketSelectorEndDiv -->';
752
+        return $this->clearTicketSelector().'</div><!-- ticketSelectorEndDiv -->';
753 753
     }
754 754
 
755 755
 
Please login to merge, or discard this patch.
admin_pages/registrations/Registrations_Admin_Page.core.php 2 patches
Indentation   +3690 added lines, -3690 removed lines patch added patch discarded remove patch
@@ -30,2301 +30,2301 @@  discard block
 block discarded – undo
30 30
 class Registrations_Admin_Page extends EE_Admin_Page_CPT
31 31
 {
32 32
 
33
-    /**
34
-     * @var EE_Registration
35
-     */
36
-    private $_registration;
37
-
38
-    /**
39
-     * @var EE_Event
40
-     */
41
-    private $_reg_event;
42
-
43
-    /**
44
-     * @var EE_Session
45
-     */
46
-    private $_session;
47
-
48
-    private static $_reg_status;
49
-
50
-    /**
51
-     * Form for displaying the custom questions for this registration.
52
-     * This gets used a few times throughout the request so its best to cache it
53
-     *
54
-     * @var EE_Registration_Custom_Questions_Form
55
-     */
56
-    protected $_reg_custom_questions_form = null;
57
-
58
-
59
-    /**
60
-     *        constructor
61
-     *
62
-     * @Constructor
63
-     * @access public
64
-     * @param bool $routing
65
-     * @return Registrations_Admin_Page
66
-     */
67
-    public function __construct($routing = true)
68
-    {
69
-        parent::__construct($routing);
70
-        add_action('wp_loaded', array($this, 'wp_loaded'));
71
-    }
72
-
73
-
74
-    public function wp_loaded()
75
-    {
76
-        // when adding a new registration...
77
-        if (isset($this->_req_data['action']) && $this->_req_data['action'] === 'new_registration') {
78
-            EE_System::do_not_cache();
79
-            if (! isset($this->_req_data['processing_registration'])
80
-                 || absint($this->_req_data['processing_registration']) !== 1
81
-            ) {
82
-                // and it's NOT the attendee information reg step
83
-                // force cookie expiration by setting time to last week
84
-                setcookie('ee_registration_added', 0, time() - WEEK_IN_SECONDS, '/');
85
-                // and update the global
86
-                $_COOKIE['ee_registration_added'] = 0;
87
-            }
88
-        }
89
-    }
90
-
91
-
92
-    protected function _init_page_props()
93
-    {
94
-        $this->page_slug        = REG_PG_SLUG;
95
-        $this->_admin_base_url  = REG_ADMIN_URL;
96
-        $this->_admin_base_path = REG_ADMIN;
97
-        $this->page_label       = esc_html__('Registrations', 'event_espresso');
98
-        $this->_cpt_routes      = array(
99
-            'add_new_attendee' => 'espresso_attendees',
100
-            'edit_attendee'    => 'espresso_attendees',
101
-            'insert_attendee'  => 'espresso_attendees',
102
-            'update_attendee'  => 'espresso_attendees',
103
-        );
104
-        $this->_cpt_model_names = array(
105
-            'add_new_attendee' => 'EEM_Attendee',
106
-            'edit_attendee'    => 'EEM_Attendee',
107
-        );
108
-        $this->_cpt_edit_routes = array(
109
-            'espresso_attendees' => 'edit_attendee',
110
-        );
111
-        $this->_pagenow_map     = array(
112
-            'add_new_attendee' => 'post-new.php',
113
-            'edit_attendee'    => 'post.php',
114
-            'trash'            => 'post.php',
115
-        );
116
-        add_action('edit_form_after_title', array($this, 'after_title_form_fields'), 10);
117
-        //add filters so that the comment urls don't take users to a confusing 404 page
118
-        add_filter('get_comment_link', array($this, 'clear_comment_link'), 10, 3);
119
-    }
120
-
121
-
122
-    public function clear_comment_link($link, $comment, $args)
123
-    {
124
-        //gotta make sure this only happens on this route
125
-        $post_type = get_post_type($comment->comment_post_ID);
126
-        if ($post_type === 'espresso_attendees') {
127
-            return '#commentsdiv';
128
-        }
129
-        return $link;
130
-    }
131
-
132
-
133
-    protected function _ajax_hooks()
134
-    {
135
-        //todo: all hooks for registrations ajax goes in here
136
-        add_action('wp_ajax_toggle_checkin_status', array($this, 'toggle_checkin_status'));
137
-    }
138
-
139
-
140
-    protected function _define_page_props()
141
-    {
142
-        $this->_admin_page_title = $this->page_label;
143
-        $this->_labels           = array(
144
-            'buttons'                      => array(
145
-                'add-registrant'      => esc_html__('Add New Registration', 'event_espresso'),
146
-                'add-attendee'        => esc_html__('Add Contact', 'event_espresso'),
147
-                'edit'                => esc_html__('Edit Contact', 'event_espresso'),
148
-                'report'              => esc_html__("Event Registrations CSV Report", "event_espresso"),
149
-                'report_all'          => esc_html__('All Registrations CSV Report', 'event_espresso'),
150
-                'report_filtered'     => esc_html__('Filtered CSV Report', 'event_espresso'),
151
-                'contact_list_report' => esc_html__('Contact List Report', 'event_espresso'),
152
-                'contact_list_export' => esc_html__("Export Data", "event_espresso"),
153
-            ),
154
-            'publishbox'                   => array(
155
-                'add_new_attendee' => esc_html__("Add Contact Record", 'event_espresso'),
156
-                'edit_attendee'    => esc_html__("Update Contact Record", 'event_espresso'),
157
-            ),
158
-            'hide_add_button_on_cpt_route' => array(
159
-                'edit_attendee' => true,
160
-            ),
161
-        );
162
-    }
163
-
164
-
165
-    /**
166
-     *        grab url requests and route them
167
-     *
168
-     * @access private
169
-     * @return void
170
-     */
171
-    public function _set_page_routes()
172
-    {
173
-        $this->_get_registration_status_array();
174
-        $reg_id             = ! empty($this->_req_data['_REG_ID']) && ! is_array($this->_req_data['_REG_ID'])
175
-            ? $this->_req_data['_REG_ID'] : 0;
176
-        $reg_id = empty($reg_id) && ! empty($this->_req_data['reg_status_change_form']['REG_ID'])
177
-            ? $this->_req_data['reg_status_change_form']['REG_ID']
178
-            : $reg_id;
179
-        $att_id             = ! empty($this->_req_data['ATT_ID']) && ! is_array($this->_req_data['ATT_ID'])
180
-            ? $this->_req_data['ATT_ID'] : 0;
181
-        $att_id             = ! empty($this->_req_data['post']) && ! is_array($this->_req_data['post'])
182
-            ? $this->_req_data['post']
183
-            : $att_id;
184
-        $this->_page_routes = array(
185
-            'default'                            => array(
186
-                'func'       => '_registrations_overview_list_table',
187
-                'capability' => 'ee_read_registrations',
188
-            ),
189
-            'view_registration'                  => array(
190
-                'func'       => '_registration_details',
191
-                'capability' => 'ee_read_registration',
192
-                'obj_id'     => $reg_id,
193
-            ),
194
-            'edit_registration'                  => array(
195
-                'func'               => '_update_attendee_registration_form',
196
-                'noheader'           => true,
197
-                'headers_sent_route' => 'view_registration',
198
-                'capability'         => 'ee_edit_registration',
199
-                'obj_id'             => $reg_id,
200
-                '_REG_ID'            => $reg_id,
201
-            ),
202
-            'trash_registrations'                => array(
203
-                'func'       => '_trash_or_restore_registrations',
204
-                'args'       => array('trash' => true),
205
-                'noheader'   => true,
206
-                'capability' => 'ee_delete_registrations',
207
-            ),
208
-            'restore_registrations'              => array(
209
-                'func'       => '_trash_or_restore_registrations',
210
-                'args'       => array('trash' => false),
211
-                'noheader'   => true,
212
-                'capability' => 'ee_delete_registrations',
213
-            ),
214
-            'delete_registrations'               => array(
215
-                'func'       => '_delete_registrations',
216
-                'noheader'   => true,
217
-                'capability' => 'ee_delete_registrations',
218
-            ),
219
-            'new_registration'                   => array(
220
-                'func'       => 'new_registration',
221
-                'capability' => 'ee_edit_registrations',
222
-            ),
223
-            'process_reg_step'                   => array(
224
-                'func'       => 'process_reg_step',
225
-                'noheader'   => true,
226
-                'capability' => 'ee_edit_registrations',
227
-            ),
228
-            'redirect_to_txn'                    => array(
229
-                'func'       => 'redirect_to_txn',
230
-                'noheader'   => true,
231
-                'capability' => 'ee_edit_registrations',
232
-            ),
233
-            'change_reg_status'                  => array(
234
-                'func'       => '_change_reg_status',
235
-                'noheader'   => true,
236
-                'capability' => 'ee_edit_registration',
237
-                'obj_id'     => $reg_id,
238
-            ),
239
-            'approve_registration'               => array(
240
-                'func'       => 'approve_registration',
241
-                'noheader'   => true,
242
-                'capability' => 'ee_edit_registration',
243
-                'obj_id'     => $reg_id,
244
-            ),
245
-            'approve_and_notify_registration'    => array(
246
-                'func'       => 'approve_registration',
247
-                'noheader'   => true,
248
-                'args'       => array(true),
249
-                'capability' => 'ee_edit_registration',
250
-                'obj_id'     => $reg_id,
251
-            ),
252
-            'approve_registrations'               => array(
253
-                'func'       => 'bulk_action_on_registrations',
254
-                'noheader'   => true,
255
-                'capability' => 'ee_edit_registrations',
256
-                'args' => array('approve')
257
-            ),
258
-            'approve_and_notify_registrations'               => array(
259
-                'func'       => 'bulk_action_on_registrations',
260
-                'noheader'   => true,
261
-                'capability' => 'ee_edit_registrations',
262
-                'args' => array('approve', true)
263
-            ),
264
-            'decline_registration'               => array(
265
-                'func'       => 'decline_registration',
266
-                'noheader'   => true,
267
-                'capability' => 'ee_edit_registration',
268
-                'obj_id'     => $reg_id,
269
-            ),
270
-            'decline_and_notify_registration'    => array(
271
-                'func'       => 'decline_registration',
272
-                'noheader'   => true,
273
-                'args'       => array(true),
274
-                'capability' => 'ee_edit_registration',
275
-                'obj_id'     => $reg_id,
276
-            ),
277
-            'decline_registrations'               => array(
278
-                'func'       => 'bulk_action_on_registrations',
279
-                'noheader'   => true,
280
-                'capability' => 'ee_edit_registrations',
281
-                'args' => array('decline')
282
-            ),
283
-            'decline_and_notify_registrations'    => array(
284
-                'func'       => 'bulk_action_on_registrations',
285
-                'noheader'   => true,
286
-                'capability' => 'ee_edit_registrations',
287
-                'args' => array('decline', true)
288
-            ),
289
-            'pending_registration'               => array(
290
-                'func'       => 'pending_registration',
291
-                'noheader'   => true,
292
-                'capability' => 'ee_edit_registration',
293
-                'obj_id'     => $reg_id,
294
-            ),
295
-            'pending_and_notify_registration'    => array(
296
-                'func'       => 'pending_registration',
297
-                'noheader'   => true,
298
-                'args'       => array(true),
299
-                'capability' => 'ee_edit_registration',
300
-                'obj_id'     => $reg_id,
301
-            ),
302
-            'pending_registrations'               => array(
303
-                'func'       => 'bulk_action_on_registrations',
304
-                'noheader'   => true,
305
-                'capability' => 'ee_edit_registrations',
306
-                'args' => array('pending')
307
-            ),
308
-            'pending_and_notify_registrations'    => array(
309
-                'func'       => 'bulk_action_on_registrations',
310
-                'noheader'   => true,
311
-                'capability' => 'ee_edit_registrations',
312
-                'args' => array('pending', true)
313
-            ),
314
-            'no_approve_registration'            => array(
315
-                'func'       => 'not_approve_registration',
316
-                'noheader'   => true,
317
-                'capability' => 'ee_edit_registration',
318
-                'obj_id'     => $reg_id,
319
-            ),
320
-            'no_approve_and_notify_registration' => array(
321
-                'func'       => 'not_approve_registration',
322
-                'noheader'   => true,
323
-                'args'       => array(true),
324
-                'capability' => 'ee_edit_registration',
325
-                'obj_id'     => $reg_id,
326
-            ),
327
-            'no_approve_registrations'            => array(
328
-                'func'       => 'bulk_action_on_registrations',
329
-                'noheader'   => true,
330
-                'capability' => 'ee_edit_registrations',
331
-                'args' => array('not_approve')
332
-            ),
333
-            'no_approve_and_notify_registrations' => array(
334
-                'func'       => 'bulk_action_on_registrations',
335
-                'noheader'   => true,
336
-                'capability' => 'ee_edit_registrations',
337
-                'args' => array('not_approve', true)
338
-            ),
339
-            'cancel_registration'                => array(
340
-                'func'       => 'cancel_registration',
341
-                'noheader'   => true,
342
-                'capability' => 'ee_edit_registration',
343
-                'obj_id'     => $reg_id,
344
-            ),
345
-            'cancel_and_notify_registration'     => array(
346
-                'func'       => 'cancel_registration',
347
-                'noheader'   => true,
348
-                'args'       => array(true),
349
-                'capability' => 'ee_edit_registration',
350
-                'obj_id'     => $reg_id,
351
-            ),
352
-            'cancel_registrations'                => array(
353
-                'func'       => 'bulk_action_on_registrations',
354
-                'noheader'   => true,
355
-                'capability' => 'ee_edit_registrations',
356
-                'args' => array('cancel')
357
-            ),
358
-            'cancel_and_notify_registrations'     => array(
359
-                'func'       => 'bulk_action_on_registrations',
360
-                'noheader'   => true,
361
-                'capability' => 'ee_edit_registrations',
362
-                'args' => array('cancel', true)
363
-            ),
364
-            'wait_list_registration' => array(
365
-                'func'       => 'wait_list_registration',
366
-                'noheader'   => true,
367
-                'capability' => 'ee_edit_registration',
368
-                'obj_id'     => $reg_id,
369
-            ),
370
-            'wait_list_and_notify_registration' => array(
371
-                'func'       => 'wait_list_registration',
372
-                'noheader'   => true,
373
-                'args'       => array(true),
374
-                'capability' => 'ee_edit_registration',
375
-                'obj_id'     => $reg_id,
376
-            ),
377
-            'contact_list'                       => array(
378
-                'func'       => '_attendee_contact_list_table',
379
-                'capability' => 'ee_read_contacts',
380
-            ),
381
-            'add_new_attendee'                   => array(
382
-                'func' => '_create_new_cpt_item',
383
-                'args' => array(
384
-                    'new_attendee' => true,
385
-                    'capability'   => 'ee_edit_contacts',
386
-                ),
387
-            ),
388
-            'edit_attendee'                      => array(
389
-                'func'       => '_edit_cpt_item',
390
-                'capability' => 'ee_edit_contacts',
391
-                'obj_id'     => $att_id,
392
-            ),
393
-            'duplicate_attendee'                 => array(
394
-                'func'       => '_duplicate_attendee',
395
-                'noheader'   => true,
396
-                'capability' => 'ee_edit_contacts',
397
-                'obj_id'     => $att_id,
398
-            ),
399
-            'insert_attendee'                    => array(
400
-                'func'       => '_insert_or_update_attendee',
401
-                'args'       => array(
402
-                    'new_attendee' => true,
403
-                ),
404
-                'noheader'   => true,
405
-                'capability' => 'ee_edit_contacts',
406
-            ),
407
-            'update_attendee'                    => array(
408
-                'func'       => '_insert_or_update_attendee',
409
-                'args'       => array(
410
-                    'new_attendee' => false,
411
-                ),
412
-                'noheader'   => true,
413
-                'capability' => 'ee_edit_contacts',
414
-                'obj_id'     => $att_id,
415
-            ),
416
-            'trash_attendees' => array(
417
-                'func' => '_trash_or_restore_attendees',
418
-                'args' => array(
419
-                    'trash' => 'true'
420
-                ),
421
-                'noheader' => true,
422
-                'capability' => 'ee_delete_contacts'
423
-            ),
424
-            'trash_attendee'                    => array(
425
-                'func'       => '_trash_or_restore_attendees',
426
-                'args'       => array(
427
-                    'trash' => true,
428
-                ),
429
-                'noheader'   => true,
430
-                'capability' => 'ee_delete_contacts',
431
-                'obj_id'     => $att_id,
432
-            ),
433
-            'restore_attendees'                  => array(
434
-                'func'       => '_trash_or_restore_attendees',
435
-                'args'       => array(
436
-                    'trash' => false,
437
-                ),
438
-                'noheader'   => true,
439
-                'capability' => 'ee_delete_contacts',
440
-                'obj_id'     => $att_id,
441
-            ),
442
-            'resend_registration'                => array(
443
-                'func'       => '_resend_registration',
444
-                'noheader'   => true,
445
-                'capability' => 'ee_send_message',
446
-            ),
447
-            'registrations_report'               => array(
448
-                'func'       => '_registrations_report',
449
-                'noheader'   => true,
450
-                'capability' => 'ee_read_registrations',
451
-            ),
452
-            'contact_list_export'                => array(
453
-                'func'       => '_contact_list_export',
454
-                'noheader'   => true,
455
-                'capability' => 'export',
456
-            ),
457
-            'contact_list_report'                => array(
458
-                'func'       => '_contact_list_report',
459
-                'noheader'   => true,
460
-                'capability' => 'ee_read_contacts',
461
-            ),
462
-        );
463
-    }
464
-
465
-
466
-    protected function _set_page_config()
467
-    {
468
-        $this->_page_config = array(
469
-            'default'           => array(
470
-                'nav'           => array(
471
-                    'label' => esc_html__('Overview', 'event_espresso'),
472
-                    'order' => 5,
473
-                ),
474
-                'help_tabs'     => array(
475
-                    'registrations_overview_help_tab'                       => array(
476
-                        'title'    => esc_html__('Registrations Overview', 'event_espresso'),
477
-                        'filename' => 'registrations_overview',
478
-                    ),
479
-                    'registrations_overview_table_column_headings_help_tab' => array(
480
-                        'title'    => esc_html__('Registrations Table Column Headings', 'event_espresso'),
481
-                        'filename' => 'registrations_overview_table_column_headings',
482
-                    ),
483
-                    'registrations_overview_filters_help_tab'               => array(
484
-                        'title'    => esc_html__('Registration Filters', 'event_espresso'),
485
-                        'filename' => 'registrations_overview_filters',
486
-                    ),
487
-                    'registrations_overview_views_help_tab'                 => array(
488
-                        'title'    => esc_html__('Registration Views', 'event_espresso'),
489
-                        'filename' => 'registrations_overview_views',
490
-                    ),
491
-                    'registrations_regoverview_other_help_tab'              => array(
492
-                        'title'    => esc_html__('Registrations Other', 'event_espresso'),
493
-                        'filename' => 'registrations_overview_other',
494
-                    ),
495
-                ),
496
-                'help_tour'     => array('Registration_Overview_Help_Tour'),
497
-                'qtips'         => array('Registration_List_Table_Tips'),
498
-                'list_table'    => 'EE_Registrations_List_Table',
499
-                'require_nonce' => false,
500
-            ),
501
-            'view_registration' => array(
502
-                'nav'           => array(
503
-                    'label'      => esc_html__('REG Details', 'event_espresso'),
504
-                    'order'      => 15,
505
-                    'url'        => isset($this->_req_data['_REG_ID'])
506
-                        ? add_query_arg(array('_REG_ID' => $this->_req_data['_REG_ID']), $this->_current_page_view_url)
507
-                        : $this->_admin_base_url,
508
-                    'persistent' => false,
509
-                ),
510
-                'help_tabs'     => array(
511
-                    'registrations_details_help_tab'                    => array(
512
-                        'title'    => esc_html__('Registration Details', 'event_espresso'),
513
-                        'filename' => 'registrations_details',
514
-                    ),
515
-                    'registrations_details_table_help_tab'              => array(
516
-                        'title'    => esc_html__('Registration Details Table', 'event_espresso'),
517
-                        'filename' => 'registrations_details_table',
518
-                    ),
519
-                    'registrations_details_form_answers_help_tab'       => array(
520
-                        'title'    => esc_html__('Registration Form Answers', 'event_espresso'),
521
-                        'filename' => 'registrations_details_form_answers',
522
-                    ),
523
-                    'registrations_details_registrant_details_help_tab' => array(
524
-                        'title'    => esc_html__('Contact Details', 'event_espresso'),
525
-                        'filename' => 'registrations_details_registrant_details',
526
-                    ),
527
-                ),
528
-                'help_tour'     => array('Registration_Details_Help_Tour'),
529
-                'metaboxes'     => array_merge(
530
-                    $this->_default_espresso_metaboxes,
531
-                    array('_registration_details_metaboxes')
532
-                ),
533
-                'require_nonce' => false,
534
-            ),
535
-            'new_registration'  => array(
536
-                'nav'           => array(
537
-                    'label'      => esc_html__('Add New Registration', 'event_espresso'),
538
-                    'url'        => '#',
539
-                    'order'      => 15,
540
-                    'persistent' => false,
541
-                ),
542
-                'metaboxes'     => $this->_default_espresso_metaboxes,
543
-                'labels'        => array(
544
-                    'publishbox' => esc_html__('Save Registration', 'event_espresso'),
545
-                ),
546
-                'require_nonce' => false,
547
-            ),
548
-            'add_new_attendee'  => array(
549
-                'nav'           => array(
550
-                    'label'      => esc_html__('Add Contact', 'event_espresso'),
551
-                    'order'      => 15,
552
-                    'persistent' => false,
553
-                ),
554
-                'metaboxes'     => array_merge(
555
-                    $this->_default_espresso_metaboxes,
556
-                    array('_publish_post_box', 'attendee_editor_metaboxes')
557
-                ),
558
-                'require_nonce' => false,
559
-            ),
560
-            'edit_attendee'     => array(
561
-                'nav'           => array(
562
-                    'label'      => esc_html__('Edit Contact', 'event_espresso'),
563
-                    'order'      => 15,
564
-                    'persistent' => false,
565
-                    'url'        => isset($this->_req_data['ATT_ID'])
566
-                        ? add_query_arg(array('ATT_ID' => $this->_req_data['ATT_ID']), $this->_current_page_view_url)
567
-                        : $this->_admin_base_url,
568
-                ),
569
-                'metaboxes'     => array('attendee_editor_metaboxes'),
570
-                'require_nonce' => false,
571
-            ),
572
-            'contact_list'      => array(
573
-                'nav'           => array(
574
-                    'label' => esc_html__('Contact List', 'event_espresso'),
575
-                    'order' => 20,
576
-                ),
577
-                'list_table'    => 'EE_Attendee_Contact_List_Table',
578
-                'help_tabs'     => array(
579
-                    'registrations_contact_list_help_tab'                       => array(
580
-                        'title'    => esc_html__('Registrations Contact List', 'event_espresso'),
581
-                        'filename' => 'registrations_contact_list',
582
-                    ),
583
-                    'registrations_contact-list_table_column_headings_help_tab' => array(
584
-                        'title'    => esc_html__('Contact List Table Column Headings', 'event_espresso'),
585
-                        'filename' => 'registrations_contact_list_table_column_headings',
586
-                    ),
587
-                    'registrations_contact_list_views_help_tab'                 => array(
588
-                        'title'    => esc_html__('Contact List Views', 'event_espresso'),
589
-                        'filename' => 'registrations_contact_list_views',
590
-                    ),
591
-                    'registrations_contact_list_other_help_tab'                 => array(
592
-                        'title'    => esc_html__('Contact List Other', 'event_espresso'),
593
-                        'filename' => 'registrations_contact_list_other',
594
-                    ),
595
-                ),
596
-                'help_tour'     => array('Contact_List_Help_Tour'),
597
-                'metaboxes'     => array(),
598
-                'require_nonce' => false,
599
-            ),
600
-            //override default cpt routes
601
-            'create_new'        => '',
602
-            'edit'              => '',
603
-        );
604
-    }
605
-
606
-
607
-    /**
608
-     * The below methods aren't used by this class currently
609
-     */
610
-    protected function _add_screen_options()
611
-    {
612
-    }
613
-
614
-
615
-    protected function _add_feature_pointers()
616
-    {
617
-    }
618
-
619
-
620
-    public function admin_init()
621
-    {
622
-        EE_Registry::$i18n_js_strings['update_att_qstns'] = esc_html__(
623
-            'click "Update Registration Questions" to save your changes',
624
-            'event_espresso'
625
-        );
626
-    }
627
-
628
-
629
-    public function admin_notices()
630
-    {
631
-    }
632
-
633
-
634
-    public function admin_footer_scripts()
635
-    {
636
-    }
637
-
638
-
639
-    /**
640
-     *        get list of registration statuses
641
-     *
642
-     * @access private
643
-     * @return void
644
-     * @throws EE_Error
645
-     */
646
-    private function _get_registration_status_array()
647
-    {
648
-        self::$_reg_status = EEM_Registration::reg_status_array(array(), true);
649
-    }
650
-
651
-
652
-    protected function _add_screen_options_default()
653
-    {
654
-        $this->_per_page_screen_option();
655
-    }
656
-
657
-
658
-    protected function _add_screen_options_contact_list()
659
-    {
660
-        $page_title              = $this->_admin_page_title;
661
-        $this->_admin_page_title = esc_html__("Contacts", 'event_espresso');
662
-        $this->_per_page_screen_option();
663
-        $this->_admin_page_title = $page_title;
664
-    }
665
-
666
-
667
-    public function load_scripts_styles()
668
-    {
669
-        //style
670
-        wp_register_style(
671
-            'espresso_reg',
672
-            REG_ASSETS_URL . 'espresso_registrations_admin.css',
673
-            array('ee-admin-css'),
674
-            EVENT_ESPRESSO_VERSION
675
-        );
676
-        wp_enqueue_style('espresso_reg');
677
-        //script
678
-        wp_register_script(
679
-            'espresso_reg',
680
-            REG_ASSETS_URL . 'espresso_registrations_admin.js',
681
-            array('jquery-ui-datepicker', 'jquery-ui-draggable', 'ee_admin_js'),
682
-            EVENT_ESPRESSO_VERSION,
683
-            true
684
-        );
685
-        wp_enqueue_script('espresso_reg');
686
-    }
687
-
688
-
689
-    public function load_scripts_styles_edit_attendee()
690
-    {
691
-        //stuff to only show up on our attendee edit details page.
692
-        $attendee_details_translations = array(
693
-            'att_publish_text' => sprintf(
694
-                esc_html__('Created on: <b>%1$s</b>', 'event_espresso'),
695
-                $this->_cpt_model_obj->get_datetime('ATT_created')
696
-            ),
697
-        );
698
-        wp_localize_script('espresso_reg', 'ATTENDEE_DETAILS', $attendee_details_translations);
699
-        wp_enqueue_script('jquery-validate');
700
-    }
701
-
702
-
703
-    public function load_scripts_styles_view_registration()
704
-    {
705
-        //styles
706
-        wp_enqueue_style('espresso-ui-theme');
707
-        //scripts
708
-        $this->_get_reg_custom_questions_form($this->_registration->ID());
709
-        $this->_reg_custom_questions_form->wp_enqueue_scripts(true);
710
-    }
711
-
712
-
713
-    public function load_scripts_styles_contact_list()
714
-    {
715
-        wp_deregister_style('espresso_reg');
716
-        wp_register_style(
717
-            'espresso_att',
718
-            REG_ASSETS_URL . 'espresso_attendees_admin.css',
719
-            array('ee-admin-css'),
720
-            EVENT_ESPRESSO_VERSION
721
-        );
722
-        wp_enqueue_style('espresso_att');
723
-    }
724
-
725
-
726
-    public function load_scripts_styles_new_registration()
727
-    {
728
-        wp_register_script(
729
-            'ee-spco-for-admin',
730
-            REG_ASSETS_URL . 'spco_for_admin.js',
731
-            array('underscore', 'jquery'),
732
-            EVENT_ESPRESSO_VERSION,
733
-            true
734
-        );
735
-        wp_enqueue_script('ee-spco-for-admin');
736
-        add_filter('FHEE__EED_Ticket_Selector__load_tckt_slctr_assets', '__return_true');
737
-        EE_Form_Section_Proper::wp_enqueue_scripts();
738
-        EED_Ticket_Selector::load_tckt_slctr_assets();
739
-        EE_Datepicker_Input::enqueue_styles_and_scripts();
740
-    }
741
-
742
-
743
-    public function AHEE__EE_Admin_Page__route_admin_request_resend_registration()
744
-    {
745
-        add_filter('FHEE_load_EE_messages', '__return_true');
746
-    }
747
-
748
-
749
-    public function AHEE__EE_Admin_Page__route_admin_request_approve_registration()
750
-    {
751
-        add_filter('FHEE_load_EE_messages', '__return_true');
752
-    }
753
-
754
-
755
-    protected function _set_list_table_views_default()
756
-    {
757
-        //for notification related bulk actions we need to make sure only active messengers have an option.
758
-        EED_Messages::set_autoloaders();
759
-        /** @type EE_Message_Resource_Manager $message_resource_manager */
760
-        $message_resource_manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
761
-        $active_mts               = $message_resource_manager->list_of_active_message_types();
762
-        //key= bulk_action_slug, value= message type.
763
-        $match_array = array(
764
-            'approve_registrations'    => 'registration',
765
-            'decline_registrations'    => 'declined_registration',
766
-            'pending_registrations'    => 'pending_approval',
767
-            'no_approve_registrations' => 'not_approved_registration',
768
-            'cancel_registrations'     => 'cancelled_registration',
769
-        );
770
-        $can_send = EE_Registry::instance()->CAP->current_user_can(
771
-            'ee_send_message',
772
-            'batch_send_messages'
773
-        );
774
-        /** setup reg status bulk actions **/
775
-        $def_reg_status_actions['approve_registrations'] = esc_html__('Approve Registrations', 'event_espresso');
776
-        if ($can_send && in_array($match_array['approve_registrations'], $active_mts, true)) {
777
-                $def_reg_status_actions['approve_and_notify_registrations'] = esc_html__(
778
-                    'Approve and Notify Registrations',
779
-                    'event_espresso'
780
-                );
781
-        }
782
-        $def_reg_status_actions['decline_registrations'] = esc_html__('Decline Registrations', 'event_espresso');
783
-        if ($can_send && in_array($match_array['decline_registrations'], $active_mts, true)) {
784
-                $def_reg_status_actions['decline_and_notify_registrations'] = esc_html__(
785
-                    'Decline and Notify Registrations',
786
-                    'event_espresso'
787
-                );
788
-        }
789
-        $def_reg_status_actions['pending_registrations'] = esc_html__(
790
-            'Set Registrations to Pending Payment',
791
-            'event_espresso'
792
-        );
793
-        if ($can_send && in_array($match_array['pending_registrations'], $active_mts, true)) {
794
-                $def_reg_status_actions['pending_and_notify_registrations'] = esc_html__(
795
-                    'Set Registrations to Pending Payment and Notify',
796
-                    'event_espresso'
797
-                );
798
-        }
799
-        $def_reg_status_actions['no_approve_registrations'] = esc_html__(
800
-            'Set Registrations to Not Approved',
801
-            'event_espresso'
802
-        );
803
-        if ($can_send && in_array($match_array['no_approve_registrations'], $active_mts, true)) {
804
-                $def_reg_status_actions['no_approve_and_notify_registrations'] = esc_html__(
805
-                    'Set Registrations to Not Approved and Notify',
806
-                    'event_espresso'
807
-                );
808
-        }
809
-        $def_reg_status_actions['cancel_registrations'] = esc_html__('Cancel Registrations', 'event_espresso');
810
-        if ($can_send && in_array($match_array['cancel_registrations'], $active_mts, true)) {
811
-                $def_reg_status_actions['cancel_and_notify_registrations'] = esc_html__(
812
-                    'Cancel Registrations and Notify',
813
-                    'event_espresso'
814
-                );
815
-        }
816
-        $def_reg_status_actions = apply_filters(
817
-            'FHEE__Registrations_Admin_Page___set_list_table_views_default__def_reg_status_actions_array',
818
-            $def_reg_status_actions,
819
-            $active_mts,
820
-            $can_send
821
-        );
822
-
823
-        $this->_views = array(
824
-            'all'   => array(
825
-                'slug'        => 'all',
826
-                'label'       => esc_html__('View All Registrations', 'event_espresso'),
827
-                'count'       => 0,
828
-                'bulk_action' => array_merge($def_reg_status_actions, array(
829
-                    'trash_registrations' => esc_html__('Trash Registrations', 'event_espresso'),
830
-                )),
831
-            ),
832
-            'month' => array(
833
-                'slug'        => 'month',
834
-                'label'       => esc_html__('This Month', 'event_espresso'),
835
-                'count'       => 0,
836
-                'bulk_action' => array_merge($def_reg_status_actions, array(
837
-                    'trash_registrations' => esc_html__('Trash Registrations', 'event_espresso'),
838
-                )),
839
-            ),
840
-            'today' => array(
841
-                'slug'        => 'today',
842
-                'label'       => sprintf(
843
-                    esc_html__('Today - %s', 'event_espresso'),
844
-                    date('M d, Y', current_time('timestamp'))
845
-                ),
846
-                'count'       => 0,
847
-                'bulk_action' => array_merge($def_reg_status_actions, array(
848
-                    'trash_registrations' => esc_html__('Trash Registrations', 'event_espresso'),
849
-                )),
850
-            ),
851
-        );
852
-        if (EE_Registry::instance()->CAP->current_user_can(
853
-            'ee_delete_registrations',
854
-            'espresso_registrations_delete_registration'
855
-        )) {
856
-            $this->_views['incomplete'] = array(
857
-                'slug'        => 'incomplete',
858
-                'label'       => esc_html__('Incomplete', 'event_espresso'),
859
-                'count'       => 0,
860
-                'bulk_action' => array(
861
-                    'trash_registrations' => esc_html__('Trash Registrations', 'event_espresso'),
862
-                ),
863
-            );
864
-            $this->_views['trash']      = array(
865
-                'slug'        => 'trash',
866
-                'label'       => esc_html__('Trash', 'event_espresso'),
867
-                'count'       => 0,
868
-                'bulk_action' => array(
869
-                    'restore_registrations' => esc_html__('Restore Registrations', 'event_espresso'),
870
-                    'delete_registrations'  => esc_html__('Delete Registrations Permanently', 'event_espresso'),
871
-                ),
872
-            );
873
-        }
874
-    }
875
-
876
-
877
-    protected function _set_list_table_views_contact_list()
878
-    {
879
-        $this->_views = array(
880
-            'in_use' => array(
881
-                'slug'        => 'in_use',
882
-                'label'       => esc_html__('In Use', 'event_espresso'),
883
-                'count'       => 0,
884
-                'bulk_action' => array(
885
-                    'trash_attendees' => esc_html__('Move to Trash', 'event_espresso'),
886
-                ),
887
-            ),
888
-        );
889
-        if (EE_Registry::instance()->CAP->current_user_can('ee_delete_contacts',
890
-            'espresso_registrations_trash_attendees')
891
-        ) {
892
-            $this->_views['trash'] = array(
893
-                'slug'        => 'trash',
894
-                'label'       => esc_html__('Trash', 'event_espresso'),
895
-                'count'       => 0,
896
-                'bulk_action' => array(
897
-                    'restore_attendees' => esc_html__('Restore from Trash', 'event_espresso'),
898
-                ),
899
-            );
900
-        }
901
-    }
902
-
903
-
904
-    protected function _registration_legend_items()
905
-    {
906
-        $fc_items = array(
907
-            'star-icon'        => array(
908
-                'class' => 'dashicons dashicons-star-filled lt-blue-icon ee-icon-size-8',
909
-                'desc'  => esc_html__('This is the Primary Registrant', 'event_espresso'),
910
-            ),
911
-            'view_details'     => array(
912
-                'class' => 'dashicons dashicons-clipboard',
913
-                'desc'  => esc_html__('View Registration Details', 'event_espresso'),
914
-            ),
915
-            'edit_attendee'    => array(
916
-                'class' => 'ee-icon ee-icon-user-edit ee-icon-size-16',
917
-                'desc'  => esc_html__('Edit Contact Details', 'event_espresso'),
918
-            ),
919
-            'view_transaction' => array(
920
-                'class' => 'dashicons dashicons-cart',
921
-                'desc'  => esc_html__('View Transaction Details', 'event_espresso'),
922
-            ),
923
-            'view_invoice'     => array(
924
-                'class' => 'dashicons dashicons-media-spreadsheet',
925
-                'desc'  => esc_html__('View Transaction Invoice', 'event_espresso'),
926
-            ),
927
-        );
928
-        if (EE_Registry::instance()->CAP->current_user_can(
929
-            'ee_send_message',
930
-            'espresso_registrations_resend_registration'
931
-        )) {
932
-            $fc_items['resend_registration'] = array(
933
-                'class' => 'dashicons dashicons-email-alt',
934
-                'desc'  => esc_html__('Resend Registration Details', 'event_espresso'),
935
-            );
936
-        } else {
937
-            $fc_items['blank'] = array('class' => 'blank', 'desc' => '');
938
-        }
939
-        if (EE_Registry::instance()->CAP->current_user_can(
940
-            'ee_read_global_messages',
941
-            'view_filtered_messages'
942
-        )) {
943
-            $related_for_icon = EEH_MSG_Template::get_message_action_icon('see_notifications_for');
944
-            if (isset($related_for_icon['css_class']) && isset($related_for_icon['label'])) {
945
-                $fc_items['view_related_messages'] = array(
946
-                    'class' => $related_for_icon['css_class'],
947
-                    'desc'  => $related_for_icon['label'],
948
-                );
949
-            }
950
-        }
951
-        $sc_items = array(
952
-            'approved_status'   => array(
953
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_approved,
954
-                'desc'  => EEH_Template::pretty_status(
955
-                    EEM_Registration::status_id_approved,
956
-                    false,
957
-                    'sentence'
958
-                ),
959
-            ),
960
-            'pending_status'    => array(
961
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_pending_payment,
962
-                'desc'  => EEH_Template::pretty_status(
963
-                    EEM_Registration::status_id_pending_payment,
964
-                    false,
965
-                    'sentence'
966
-                ),
967
-            ),
968
-            'wait_list'         => array(
969
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_wait_list,
970
-                'desc'  => EEH_Template::pretty_status(
971
-                    EEM_Registration::status_id_wait_list,
972
-                    false,
973
-                    'sentence'
974
-                ),
975
-            ),
976
-            'incomplete_status' => array(
977
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_incomplete,
978
-                'desc'  => EEH_Template::pretty_status(
979
-                    EEM_Registration::status_id_incomplete,
980
-                    false,
981
-                    'sentence'
982
-                ),
983
-            ),
984
-            'not_approved'      => array(
985
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_not_approved,
986
-                'desc'  => EEH_Template::pretty_status(
987
-                    EEM_Registration::status_id_not_approved,
988
-                    false,
989
-                    'sentence'
990
-                ),
991
-            ),
992
-            'declined_status'   => array(
993
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_declined,
994
-                'desc'  => EEH_Template::pretty_status(
995
-                    EEM_Registration::status_id_declined,
996
-                    false,
997
-                    'sentence'
998
-                ),
999
-            ),
1000
-            'cancelled_status'  => array(
1001
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_cancelled,
1002
-                'desc'  => EEH_Template::pretty_status(
1003
-                    EEM_Registration::status_id_cancelled,
1004
-                    false,
1005
-                    'sentence'
1006
-                ),
1007
-            ),
1008
-        );
1009
-        return array_merge($fc_items, $sc_items);
1010
-    }
1011
-
1012
-
1013
-
1014
-    /***************************************        REGISTRATION OVERVIEW        **************************************/
1015
-    /**
1016
-     * @throws \EE_Error
1017
-     */
1018
-    protected function _registrations_overview_list_table()
1019
-    {
1020
-        $this->_template_args['admin_page_header'] = '';
1021
-        $EVT_ID                                    = ! empty($this->_req_data['event_id'])
1022
-            ? absint($this->_req_data['event_id'])
1023
-            : 0;
1024
-        if ($EVT_ID) {
1025
-            if (EE_Registry::instance()->CAP->current_user_can(
1026
-                'ee_edit_registrations',
1027
-                'espresso_registrations_new_registration',
1028
-                $EVT_ID
1029
-            )) {
1030
-                $this->_admin_page_title .= ' ' . $this->get_action_link_or_button(
1031
-                    'new_registration',
1032
-                    'add-registrant',
1033
-                    array('event_id' => $EVT_ID),
1034
-                    'add-new-h2'
1035
-                );
1036
-            }
1037
-            $event = EEM_Event::instance()->get_one_by_ID($EVT_ID);
1038
-            if ($event instanceof EE_Event) {
1039
-                $this->_template_args['admin_page_header'] = sprintf(
1040
-                    esc_html__(
1041
-                        '%s Viewing registrations for the event: %s%s',
1042
-                        'event_espresso'
1043
-                    ),
1044
-                    '<h3 style="line-height:1.5em;">',
1045
-                    '<br /><a href="'
1046
-                        . EE_Admin_Page::add_query_args_and_nonce(
1047
-                            array(
1048
-                                'action' => 'edit',
1049
-                                'post'   => $event->ID(),
1050
-                            ),
1051
-                            EVENTS_ADMIN_URL
1052
-                        )
1053
-                        . '">&nbsp;'
1054
-                        . $event->get('EVT_name')
1055
-                        . '&nbsp;</a>&nbsp;',
1056
-                    '</h3>'
1057
-                );
1058
-            }
1059
-            $DTT_ID   = ! empty($this->_req_data['datetime_id']) ? absint($this->_req_data['datetime_id']) : 0;
1060
-            $datetime = EEM_Datetime::instance()->get_one_by_ID($DTT_ID);
1061
-            if ($datetime instanceof EE_Datetime && $this->_template_args['admin_page_header'] !== '') {
1062
-                $this->_template_args['admin_page_header'] = substr(
1063
-                    $this->_template_args['admin_page_header'],
1064
-                    0,
1065
-                    -5
1066
-                );
1067
-                $this->_template_args['admin_page_header'] .= ' &nbsp;<span class="drk-grey-text">';
1068
-                $this->_template_args['admin_page_header'] .= '<span class="dashicons dashicons-calendar"></span>';
1069
-                $this->_template_args['admin_page_header'] .= $datetime->name();
1070
-                $this->_template_args['admin_page_header'] .= ' ( ' . $datetime->start_date() . ' )';
1071
-                $this->_template_args['admin_page_header'] .= '</span></h3>';
1072
-            }
1073
-        }
1074
-        $this->_template_args['after_list_table'] = $this->_display_legend($this->_registration_legend_items());
1075
-        $this->display_admin_list_table_page_with_no_sidebar();
1076
-    }
1077
-
1078
-
1079
-    /**
1080
-     * This sets the _registration property for the registration details screen
1081
-     *
1082
-     * @access private
1083
-     * @return bool
1084
-     * @throws EE_Error
1085
-     * @throws InvalidArgumentException
1086
-     * @throws InvalidDataTypeException
1087
-     * @throws InvalidInterfaceException
1088
-     */
1089
-    private function _set_registration_object()
1090
-    {
1091
-        //get out if we've already set the object
1092
-        if ($this->_registration instanceof EE_Registration) {
1093
-            return true;
1094
-        }
1095
-        $REG    = EEM_Registration::instance();
1096
-        $REG_ID = ( ! empty($this->_req_data['_REG_ID'])) ? absint($this->_req_data['_REG_ID']) : false;
1097
-        if ($this->_registration = $REG->get_one_by_ID($REG_ID)) {
1098
-            return true;
1099
-        } else {
1100
-            $error_msg = sprintf(
1101
-                esc_html__(
1102
-                    'An error occurred and the details for Registration ID #%s could not be retrieved.',
1103
-                    'event_espresso'
1104
-                ),
1105
-                $REG_ID
1106
-            );
1107
-            EE_Error::add_error($error_msg, __FILE__, __FUNCTION__, __LINE__);
1108
-            $this->_registration = null;
1109
-            return false;
1110
-        }
1111
-    }
1112
-
1113
-
1114
-    /**
1115
-     * Used to retrieve registrations for the list table.
1116
-     *
1117
-     * @param int  $per_page
1118
-     * @param bool $count
1119
-     * @param bool $this_month
1120
-     * @param bool $today
1121
-     * @return EE_Registration[]|int
1122
-     * @throws EE_Error
1123
-     * @throws InvalidArgumentException
1124
-     * @throws InvalidDataTypeException
1125
-     * @throws InvalidInterfaceException
1126
-     */
1127
-    public function get_registrations(
1128
-        $per_page = 10,
1129
-        $count = false,
1130
-        $this_month = false,
1131
-        $today = false
1132
-    ) {
1133
-        if ($this_month) {
1134
-            $this->_req_data['status'] = 'month';
1135
-        }
1136
-        if ($today) {
1137
-            $this->_req_data['status'] = 'today';
1138
-        }
1139
-        $query_params = $this->_get_registration_query_parameters($this->_req_data, $per_page, $count);
1140
-        /**
1141
-         * Override the default groupby added by EEM_Base so that sorts with multiple order bys work as expected
1142
-         * @link https://events.codebasehq.com/projects/event-espresso/tickets/10093
1143
-         * @see EEM_Base::get_all()
1144
-         */
1145
-        $query_params['group_by'] = '';
1146
-
1147
-        return $count
1148
-            ? EEM_Registration::instance()->count($query_params)
1149
-            /** @type EE_Registration[] */
1150
-            : EEM_Registration::instance()->get_all($query_params);
1151
-    }
1152
-
1153
-
1154
-    /**
1155
-     * Retrieves the query parameters to be used by the Registration model for getting registrations.
1156
-     * Note: this listens to values on the request for some of the query parameters.
1157
-     *
1158
-     * @param array $request
1159
-     * @param int   $per_page
1160
-     * @param bool  $count
1161
-     * @return array
1162
-     * @throws EE_Error
1163
-     */
1164
-    protected function _get_registration_query_parameters(
1165
-        $request = array(),
1166
-        $per_page = 10,
1167
-        $count = false
1168
-    ) {
1169
-
1170
-        $query_params = array(
1171
-            0                          => $this->_get_where_conditions_for_registrations_query(
1172
-                $request
1173
-            ),
1174
-            'caps'                     => EEM_Registration::caps_read_admin,
1175
-            'default_where_conditions' => 'this_model_only',
1176
-        );
1177
-        if (! $count) {
1178
-            $query_params = array_merge(
1179
-                $query_params,
1180
-                $this->_get_orderby_for_registrations_query(),
1181
-                $this->_get_limit($per_page)
1182
-            );
1183
-        }
1184
-
1185
-        return $query_params;
1186
-    }
1187
-
1188
-
1189
-    /**
1190
-     * This will add EVT_ID to the provided $where array for EE model query parameters.
1191
-     *
1192
-     * @param array $request usually the same as $this->_req_data but not necessarily
1193
-     * @return array
1194
-     */
1195
-    protected function _add_event_id_to_where_conditions(array $request)
1196
-    {
1197
-        $where = array();
1198
-        if (! empty($request['event_id'])) {
1199
-            $where['EVT_ID'] = absint($request['event_id']);
1200
-        }
1201
-        return $where;
1202
-    }
1203
-
1204
-
1205
-    /**
1206
-     * Adds category ID if it exists in the request to the where conditions for the registrations query.
1207
-     *
1208
-     * @param array $request usually the same as $this->_req_data but not necessarily
1209
-     * @return array
1210
-     */
1211
-    protected function _add_category_id_to_where_conditions(array $request)
1212
-    {
1213
-        $where = array();
1214
-        if (! empty($request['EVT_CAT']) && (int)$request['EVT_CAT'] !== -1) {
1215
-            $where['Event.Term_Taxonomy.term_id'] = absint($request['EVT_CAT']);
1216
-        }
1217
-        return $where;
1218
-    }
1219
-
1220
-
1221
-    /**
1222
-     * Adds the datetime ID if it exists in the request to the where conditions for the registrations query.
1223
-     *
1224
-     * @param array $request usually the same as $this->_req_data but not necessarily
1225
-     * @return array
1226
-     */
1227
-    protected function _add_datetime_id_to_where_conditions(array $request)
1228
-    {
1229
-        $where = array();
1230
-        if (! empty($request['datetime_id'])) {
1231
-            $where['Ticket.Datetime.DTT_ID'] = absint($request['datetime_id']);
1232
-        }
1233
-        if (! empty($request['DTT_ID'])) {
1234
-            $where['Ticket.Datetime.DTT_ID'] = absint($request['DTT_ID']);
1235
-        }
1236
-        return $where;
1237
-    }
1238
-
1239
-
1240
-    /**
1241
-     * Adds the correct registration status to the where conditions for the registrations query.
1242
-     *
1243
-     * @param array $request usually the same as $this->_req_data but not necessarily
1244
-     * @return array
1245
-     */
1246
-    protected function _add_registration_status_to_where_conditions(array $request)
1247
-    {
1248
-        $where = array();
1249
-        $view = EEH_Array::is_set($request, 'status', '');
1250
-        $registration_status = ! empty($request['_reg_status'])
1251
-            ? sanitize_text_field($request['_reg_status'])
1252
-            : '';
1253
-
1254
-        /*
33
+	/**
34
+	 * @var EE_Registration
35
+	 */
36
+	private $_registration;
37
+
38
+	/**
39
+	 * @var EE_Event
40
+	 */
41
+	private $_reg_event;
42
+
43
+	/**
44
+	 * @var EE_Session
45
+	 */
46
+	private $_session;
47
+
48
+	private static $_reg_status;
49
+
50
+	/**
51
+	 * Form for displaying the custom questions for this registration.
52
+	 * This gets used a few times throughout the request so its best to cache it
53
+	 *
54
+	 * @var EE_Registration_Custom_Questions_Form
55
+	 */
56
+	protected $_reg_custom_questions_form = null;
57
+
58
+
59
+	/**
60
+	 *        constructor
61
+	 *
62
+	 * @Constructor
63
+	 * @access public
64
+	 * @param bool $routing
65
+	 * @return Registrations_Admin_Page
66
+	 */
67
+	public function __construct($routing = true)
68
+	{
69
+		parent::__construct($routing);
70
+		add_action('wp_loaded', array($this, 'wp_loaded'));
71
+	}
72
+
73
+
74
+	public function wp_loaded()
75
+	{
76
+		// when adding a new registration...
77
+		if (isset($this->_req_data['action']) && $this->_req_data['action'] === 'new_registration') {
78
+			EE_System::do_not_cache();
79
+			if (! isset($this->_req_data['processing_registration'])
80
+				 || absint($this->_req_data['processing_registration']) !== 1
81
+			) {
82
+				// and it's NOT the attendee information reg step
83
+				// force cookie expiration by setting time to last week
84
+				setcookie('ee_registration_added', 0, time() - WEEK_IN_SECONDS, '/');
85
+				// and update the global
86
+				$_COOKIE['ee_registration_added'] = 0;
87
+			}
88
+		}
89
+	}
90
+
91
+
92
+	protected function _init_page_props()
93
+	{
94
+		$this->page_slug        = REG_PG_SLUG;
95
+		$this->_admin_base_url  = REG_ADMIN_URL;
96
+		$this->_admin_base_path = REG_ADMIN;
97
+		$this->page_label       = esc_html__('Registrations', 'event_espresso');
98
+		$this->_cpt_routes      = array(
99
+			'add_new_attendee' => 'espresso_attendees',
100
+			'edit_attendee'    => 'espresso_attendees',
101
+			'insert_attendee'  => 'espresso_attendees',
102
+			'update_attendee'  => 'espresso_attendees',
103
+		);
104
+		$this->_cpt_model_names = array(
105
+			'add_new_attendee' => 'EEM_Attendee',
106
+			'edit_attendee'    => 'EEM_Attendee',
107
+		);
108
+		$this->_cpt_edit_routes = array(
109
+			'espresso_attendees' => 'edit_attendee',
110
+		);
111
+		$this->_pagenow_map     = array(
112
+			'add_new_attendee' => 'post-new.php',
113
+			'edit_attendee'    => 'post.php',
114
+			'trash'            => 'post.php',
115
+		);
116
+		add_action('edit_form_after_title', array($this, 'after_title_form_fields'), 10);
117
+		//add filters so that the comment urls don't take users to a confusing 404 page
118
+		add_filter('get_comment_link', array($this, 'clear_comment_link'), 10, 3);
119
+	}
120
+
121
+
122
+	public function clear_comment_link($link, $comment, $args)
123
+	{
124
+		//gotta make sure this only happens on this route
125
+		$post_type = get_post_type($comment->comment_post_ID);
126
+		if ($post_type === 'espresso_attendees') {
127
+			return '#commentsdiv';
128
+		}
129
+		return $link;
130
+	}
131
+
132
+
133
+	protected function _ajax_hooks()
134
+	{
135
+		//todo: all hooks for registrations ajax goes in here
136
+		add_action('wp_ajax_toggle_checkin_status', array($this, 'toggle_checkin_status'));
137
+	}
138
+
139
+
140
+	protected function _define_page_props()
141
+	{
142
+		$this->_admin_page_title = $this->page_label;
143
+		$this->_labels           = array(
144
+			'buttons'                      => array(
145
+				'add-registrant'      => esc_html__('Add New Registration', 'event_espresso'),
146
+				'add-attendee'        => esc_html__('Add Contact', 'event_espresso'),
147
+				'edit'                => esc_html__('Edit Contact', 'event_espresso'),
148
+				'report'              => esc_html__("Event Registrations CSV Report", "event_espresso"),
149
+				'report_all'          => esc_html__('All Registrations CSV Report', 'event_espresso'),
150
+				'report_filtered'     => esc_html__('Filtered CSV Report', 'event_espresso'),
151
+				'contact_list_report' => esc_html__('Contact List Report', 'event_espresso'),
152
+				'contact_list_export' => esc_html__("Export Data", "event_espresso"),
153
+			),
154
+			'publishbox'                   => array(
155
+				'add_new_attendee' => esc_html__("Add Contact Record", 'event_espresso'),
156
+				'edit_attendee'    => esc_html__("Update Contact Record", 'event_espresso'),
157
+			),
158
+			'hide_add_button_on_cpt_route' => array(
159
+				'edit_attendee' => true,
160
+			),
161
+		);
162
+	}
163
+
164
+
165
+	/**
166
+	 *        grab url requests and route them
167
+	 *
168
+	 * @access private
169
+	 * @return void
170
+	 */
171
+	public function _set_page_routes()
172
+	{
173
+		$this->_get_registration_status_array();
174
+		$reg_id             = ! empty($this->_req_data['_REG_ID']) && ! is_array($this->_req_data['_REG_ID'])
175
+			? $this->_req_data['_REG_ID'] : 0;
176
+		$reg_id = empty($reg_id) && ! empty($this->_req_data['reg_status_change_form']['REG_ID'])
177
+			? $this->_req_data['reg_status_change_form']['REG_ID']
178
+			: $reg_id;
179
+		$att_id             = ! empty($this->_req_data['ATT_ID']) && ! is_array($this->_req_data['ATT_ID'])
180
+			? $this->_req_data['ATT_ID'] : 0;
181
+		$att_id             = ! empty($this->_req_data['post']) && ! is_array($this->_req_data['post'])
182
+			? $this->_req_data['post']
183
+			: $att_id;
184
+		$this->_page_routes = array(
185
+			'default'                            => array(
186
+				'func'       => '_registrations_overview_list_table',
187
+				'capability' => 'ee_read_registrations',
188
+			),
189
+			'view_registration'                  => array(
190
+				'func'       => '_registration_details',
191
+				'capability' => 'ee_read_registration',
192
+				'obj_id'     => $reg_id,
193
+			),
194
+			'edit_registration'                  => array(
195
+				'func'               => '_update_attendee_registration_form',
196
+				'noheader'           => true,
197
+				'headers_sent_route' => 'view_registration',
198
+				'capability'         => 'ee_edit_registration',
199
+				'obj_id'             => $reg_id,
200
+				'_REG_ID'            => $reg_id,
201
+			),
202
+			'trash_registrations'                => array(
203
+				'func'       => '_trash_or_restore_registrations',
204
+				'args'       => array('trash' => true),
205
+				'noheader'   => true,
206
+				'capability' => 'ee_delete_registrations',
207
+			),
208
+			'restore_registrations'              => array(
209
+				'func'       => '_trash_or_restore_registrations',
210
+				'args'       => array('trash' => false),
211
+				'noheader'   => true,
212
+				'capability' => 'ee_delete_registrations',
213
+			),
214
+			'delete_registrations'               => array(
215
+				'func'       => '_delete_registrations',
216
+				'noheader'   => true,
217
+				'capability' => 'ee_delete_registrations',
218
+			),
219
+			'new_registration'                   => array(
220
+				'func'       => 'new_registration',
221
+				'capability' => 'ee_edit_registrations',
222
+			),
223
+			'process_reg_step'                   => array(
224
+				'func'       => 'process_reg_step',
225
+				'noheader'   => true,
226
+				'capability' => 'ee_edit_registrations',
227
+			),
228
+			'redirect_to_txn'                    => array(
229
+				'func'       => 'redirect_to_txn',
230
+				'noheader'   => true,
231
+				'capability' => 'ee_edit_registrations',
232
+			),
233
+			'change_reg_status'                  => array(
234
+				'func'       => '_change_reg_status',
235
+				'noheader'   => true,
236
+				'capability' => 'ee_edit_registration',
237
+				'obj_id'     => $reg_id,
238
+			),
239
+			'approve_registration'               => array(
240
+				'func'       => 'approve_registration',
241
+				'noheader'   => true,
242
+				'capability' => 'ee_edit_registration',
243
+				'obj_id'     => $reg_id,
244
+			),
245
+			'approve_and_notify_registration'    => array(
246
+				'func'       => 'approve_registration',
247
+				'noheader'   => true,
248
+				'args'       => array(true),
249
+				'capability' => 'ee_edit_registration',
250
+				'obj_id'     => $reg_id,
251
+			),
252
+			'approve_registrations'               => array(
253
+				'func'       => 'bulk_action_on_registrations',
254
+				'noheader'   => true,
255
+				'capability' => 'ee_edit_registrations',
256
+				'args' => array('approve')
257
+			),
258
+			'approve_and_notify_registrations'               => array(
259
+				'func'       => 'bulk_action_on_registrations',
260
+				'noheader'   => true,
261
+				'capability' => 'ee_edit_registrations',
262
+				'args' => array('approve', true)
263
+			),
264
+			'decline_registration'               => array(
265
+				'func'       => 'decline_registration',
266
+				'noheader'   => true,
267
+				'capability' => 'ee_edit_registration',
268
+				'obj_id'     => $reg_id,
269
+			),
270
+			'decline_and_notify_registration'    => array(
271
+				'func'       => 'decline_registration',
272
+				'noheader'   => true,
273
+				'args'       => array(true),
274
+				'capability' => 'ee_edit_registration',
275
+				'obj_id'     => $reg_id,
276
+			),
277
+			'decline_registrations'               => array(
278
+				'func'       => 'bulk_action_on_registrations',
279
+				'noheader'   => true,
280
+				'capability' => 'ee_edit_registrations',
281
+				'args' => array('decline')
282
+			),
283
+			'decline_and_notify_registrations'    => array(
284
+				'func'       => 'bulk_action_on_registrations',
285
+				'noheader'   => true,
286
+				'capability' => 'ee_edit_registrations',
287
+				'args' => array('decline', true)
288
+			),
289
+			'pending_registration'               => array(
290
+				'func'       => 'pending_registration',
291
+				'noheader'   => true,
292
+				'capability' => 'ee_edit_registration',
293
+				'obj_id'     => $reg_id,
294
+			),
295
+			'pending_and_notify_registration'    => array(
296
+				'func'       => 'pending_registration',
297
+				'noheader'   => true,
298
+				'args'       => array(true),
299
+				'capability' => 'ee_edit_registration',
300
+				'obj_id'     => $reg_id,
301
+			),
302
+			'pending_registrations'               => array(
303
+				'func'       => 'bulk_action_on_registrations',
304
+				'noheader'   => true,
305
+				'capability' => 'ee_edit_registrations',
306
+				'args' => array('pending')
307
+			),
308
+			'pending_and_notify_registrations'    => array(
309
+				'func'       => 'bulk_action_on_registrations',
310
+				'noheader'   => true,
311
+				'capability' => 'ee_edit_registrations',
312
+				'args' => array('pending', true)
313
+			),
314
+			'no_approve_registration'            => array(
315
+				'func'       => 'not_approve_registration',
316
+				'noheader'   => true,
317
+				'capability' => 'ee_edit_registration',
318
+				'obj_id'     => $reg_id,
319
+			),
320
+			'no_approve_and_notify_registration' => array(
321
+				'func'       => 'not_approve_registration',
322
+				'noheader'   => true,
323
+				'args'       => array(true),
324
+				'capability' => 'ee_edit_registration',
325
+				'obj_id'     => $reg_id,
326
+			),
327
+			'no_approve_registrations'            => array(
328
+				'func'       => 'bulk_action_on_registrations',
329
+				'noheader'   => true,
330
+				'capability' => 'ee_edit_registrations',
331
+				'args' => array('not_approve')
332
+			),
333
+			'no_approve_and_notify_registrations' => array(
334
+				'func'       => 'bulk_action_on_registrations',
335
+				'noheader'   => true,
336
+				'capability' => 'ee_edit_registrations',
337
+				'args' => array('not_approve', true)
338
+			),
339
+			'cancel_registration'                => array(
340
+				'func'       => 'cancel_registration',
341
+				'noheader'   => true,
342
+				'capability' => 'ee_edit_registration',
343
+				'obj_id'     => $reg_id,
344
+			),
345
+			'cancel_and_notify_registration'     => array(
346
+				'func'       => 'cancel_registration',
347
+				'noheader'   => true,
348
+				'args'       => array(true),
349
+				'capability' => 'ee_edit_registration',
350
+				'obj_id'     => $reg_id,
351
+			),
352
+			'cancel_registrations'                => array(
353
+				'func'       => 'bulk_action_on_registrations',
354
+				'noheader'   => true,
355
+				'capability' => 'ee_edit_registrations',
356
+				'args' => array('cancel')
357
+			),
358
+			'cancel_and_notify_registrations'     => array(
359
+				'func'       => 'bulk_action_on_registrations',
360
+				'noheader'   => true,
361
+				'capability' => 'ee_edit_registrations',
362
+				'args' => array('cancel', true)
363
+			),
364
+			'wait_list_registration' => array(
365
+				'func'       => 'wait_list_registration',
366
+				'noheader'   => true,
367
+				'capability' => 'ee_edit_registration',
368
+				'obj_id'     => $reg_id,
369
+			),
370
+			'wait_list_and_notify_registration' => array(
371
+				'func'       => 'wait_list_registration',
372
+				'noheader'   => true,
373
+				'args'       => array(true),
374
+				'capability' => 'ee_edit_registration',
375
+				'obj_id'     => $reg_id,
376
+			),
377
+			'contact_list'                       => array(
378
+				'func'       => '_attendee_contact_list_table',
379
+				'capability' => 'ee_read_contacts',
380
+			),
381
+			'add_new_attendee'                   => array(
382
+				'func' => '_create_new_cpt_item',
383
+				'args' => array(
384
+					'new_attendee' => true,
385
+					'capability'   => 'ee_edit_contacts',
386
+				),
387
+			),
388
+			'edit_attendee'                      => array(
389
+				'func'       => '_edit_cpt_item',
390
+				'capability' => 'ee_edit_contacts',
391
+				'obj_id'     => $att_id,
392
+			),
393
+			'duplicate_attendee'                 => array(
394
+				'func'       => '_duplicate_attendee',
395
+				'noheader'   => true,
396
+				'capability' => 'ee_edit_contacts',
397
+				'obj_id'     => $att_id,
398
+			),
399
+			'insert_attendee'                    => array(
400
+				'func'       => '_insert_or_update_attendee',
401
+				'args'       => array(
402
+					'new_attendee' => true,
403
+				),
404
+				'noheader'   => true,
405
+				'capability' => 'ee_edit_contacts',
406
+			),
407
+			'update_attendee'                    => array(
408
+				'func'       => '_insert_or_update_attendee',
409
+				'args'       => array(
410
+					'new_attendee' => false,
411
+				),
412
+				'noheader'   => true,
413
+				'capability' => 'ee_edit_contacts',
414
+				'obj_id'     => $att_id,
415
+			),
416
+			'trash_attendees' => array(
417
+				'func' => '_trash_or_restore_attendees',
418
+				'args' => array(
419
+					'trash' => 'true'
420
+				),
421
+				'noheader' => true,
422
+				'capability' => 'ee_delete_contacts'
423
+			),
424
+			'trash_attendee'                    => array(
425
+				'func'       => '_trash_or_restore_attendees',
426
+				'args'       => array(
427
+					'trash' => true,
428
+				),
429
+				'noheader'   => true,
430
+				'capability' => 'ee_delete_contacts',
431
+				'obj_id'     => $att_id,
432
+			),
433
+			'restore_attendees'                  => array(
434
+				'func'       => '_trash_or_restore_attendees',
435
+				'args'       => array(
436
+					'trash' => false,
437
+				),
438
+				'noheader'   => true,
439
+				'capability' => 'ee_delete_contacts',
440
+				'obj_id'     => $att_id,
441
+			),
442
+			'resend_registration'                => array(
443
+				'func'       => '_resend_registration',
444
+				'noheader'   => true,
445
+				'capability' => 'ee_send_message',
446
+			),
447
+			'registrations_report'               => array(
448
+				'func'       => '_registrations_report',
449
+				'noheader'   => true,
450
+				'capability' => 'ee_read_registrations',
451
+			),
452
+			'contact_list_export'                => array(
453
+				'func'       => '_contact_list_export',
454
+				'noheader'   => true,
455
+				'capability' => 'export',
456
+			),
457
+			'contact_list_report'                => array(
458
+				'func'       => '_contact_list_report',
459
+				'noheader'   => true,
460
+				'capability' => 'ee_read_contacts',
461
+			),
462
+		);
463
+	}
464
+
465
+
466
+	protected function _set_page_config()
467
+	{
468
+		$this->_page_config = array(
469
+			'default'           => array(
470
+				'nav'           => array(
471
+					'label' => esc_html__('Overview', 'event_espresso'),
472
+					'order' => 5,
473
+				),
474
+				'help_tabs'     => array(
475
+					'registrations_overview_help_tab'                       => array(
476
+						'title'    => esc_html__('Registrations Overview', 'event_espresso'),
477
+						'filename' => 'registrations_overview',
478
+					),
479
+					'registrations_overview_table_column_headings_help_tab' => array(
480
+						'title'    => esc_html__('Registrations Table Column Headings', 'event_espresso'),
481
+						'filename' => 'registrations_overview_table_column_headings',
482
+					),
483
+					'registrations_overview_filters_help_tab'               => array(
484
+						'title'    => esc_html__('Registration Filters', 'event_espresso'),
485
+						'filename' => 'registrations_overview_filters',
486
+					),
487
+					'registrations_overview_views_help_tab'                 => array(
488
+						'title'    => esc_html__('Registration Views', 'event_espresso'),
489
+						'filename' => 'registrations_overview_views',
490
+					),
491
+					'registrations_regoverview_other_help_tab'              => array(
492
+						'title'    => esc_html__('Registrations Other', 'event_espresso'),
493
+						'filename' => 'registrations_overview_other',
494
+					),
495
+				),
496
+				'help_tour'     => array('Registration_Overview_Help_Tour'),
497
+				'qtips'         => array('Registration_List_Table_Tips'),
498
+				'list_table'    => 'EE_Registrations_List_Table',
499
+				'require_nonce' => false,
500
+			),
501
+			'view_registration' => array(
502
+				'nav'           => array(
503
+					'label'      => esc_html__('REG Details', 'event_espresso'),
504
+					'order'      => 15,
505
+					'url'        => isset($this->_req_data['_REG_ID'])
506
+						? add_query_arg(array('_REG_ID' => $this->_req_data['_REG_ID']), $this->_current_page_view_url)
507
+						: $this->_admin_base_url,
508
+					'persistent' => false,
509
+				),
510
+				'help_tabs'     => array(
511
+					'registrations_details_help_tab'                    => array(
512
+						'title'    => esc_html__('Registration Details', 'event_espresso'),
513
+						'filename' => 'registrations_details',
514
+					),
515
+					'registrations_details_table_help_tab'              => array(
516
+						'title'    => esc_html__('Registration Details Table', 'event_espresso'),
517
+						'filename' => 'registrations_details_table',
518
+					),
519
+					'registrations_details_form_answers_help_tab'       => array(
520
+						'title'    => esc_html__('Registration Form Answers', 'event_espresso'),
521
+						'filename' => 'registrations_details_form_answers',
522
+					),
523
+					'registrations_details_registrant_details_help_tab' => array(
524
+						'title'    => esc_html__('Contact Details', 'event_espresso'),
525
+						'filename' => 'registrations_details_registrant_details',
526
+					),
527
+				),
528
+				'help_tour'     => array('Registration_Details_Help_Tour'),
529
+				'metaboxes'     => array_merge(
530
+					$this->_default_espresso_metaboxes,
531
+					array('_registration_details_metaboxes')
532
+				),
533
+				'require_nonce' => false,
534
+			),
535
+			'new_registration'  => array(
536
+				'nav'           => array(
537
+					'label'      => esc_html__('Add New Registration', 'event_espresso'),
538
+					'url'        => '#',
539
+					'order'      => 15,
540
+					'persistent' => false,
541
+				),
542
+				'metaboxes'     => $this->_default_espresso_metaboxes,
543
+				'labels'        => array(
544
+					'publishbox' => esc_html__('Save Registration', 'event_espresso'),
545
+				),
546
+				'require_nonce' => false,
547
+			),
548
+			'add_new_attendee'  => array(
549
+				'nav'           => array(
550
+					'label'      => esc_html__('Add Contact', 'event_espresso'),
551
+					'order'      => 15,
552
+					'persistent' => false,
553
+				),
554
+				'metaboxes'     => array_merge(
555
+					$this->_default_espresso_metaboxes,
556
+					array('_publish_post_box', 'attendee_editor_metaboxes')
557
+				),
558
+				'require_nonce' => false,
559
+			),
560
+			'edit_attendee'     => array(
561
+				'nav'           => array(
562
+					'label'      => esc_html__('Edit Contact', 'event_espresso'),
563
+					'order'      => 15,
564
+					'persistent' => false,
565
+					'url'        => isset($this->_req_data['ATT_ID'])
566
+						? add_query_arg(array('ATT_ID' => $this->_req_data['ATT_ID']), $this->_current_page_view_url)
567
+						: $this->_admin_base_url,
568
+				),
569
+				'metaboxes'     => array('attendee_editor_metaboxes'),
570
+				'require_nonce' => false,
571
+			),
572
+			'contact_list'      => array(
573
+				'nav'           => array(
574
+					'label' => esc_html__('Contact List', 'event_espresso'),
575
+					'order' => 20,
576
+				),
577
+				'list_table'    => 'EE_Attendee_Contact_List_Table',
578
+				'help_tabs'     => array(
579
+					'registrations_contact_list_help_tab'                       => array(
580
+						'title'    => esc_html__('Registrations Contact List', 'event_espresso'),
581
+						'filename' => 'registrations_contact_list',
582
+					),
583
+					'registrations_contact-list_table_column_headings_help_tab' => array(
584
+						'title'    => esc_html__('Contact List Table Column Headings', 'event_espresso'),
585
+						'filename' => 'registrations_contact_list_table_column_headings',
586
+					),
587
+					'registrations_contact_list_views_help_tab'                 => array(
588
+						'title'    => esc_html__('Contact List Views', 'event_espresso'),
589
+						'filename' => 'registrations_contact_list_views',
590
+					),
591
+					'registrations_contact_list_other_help_tab'                 => array(
592
+						'title'    => esc_html__('Contact List Other', 'event_espresso'),
593
+						'filename' => 'registrations_contact_list_other',
594
+					),
595
+				),
596
+				'help_tour'     => array('Contact_List_Help_Tour'),
597
+				'metaboxes'     => array(),
598
+				'require_nonce' => false,
599
+			),
600
+			//override default cpt routes
601
+			'create_new'        => '',
602
+			'edit'              => '',
603
+		);
604
+	}
605
+
606
+
607
+	/**
608
+	 * The below methods aren't used by this class currently
609
+	 */
610
+	protected function _add_screen_options()
611
+	{
612
+	}
613
+
614
+
615
+	protected function _add_feature_pointers()
616
+	{
617
+	}
618
+
619
+
620
+	public function admin_init()
621
+	{
622
+		EE_Registry::$i18n_js_strings['update_att_qstns'] = esc_html__(
623
+			'click "Update Registration Questions" to save your changes',
624
+			'event_espresso'
625
+		);
626
+	}
627
+
628
+
629
+	public function admin_notices()
630
+	{
631
+	}
632
+
633
+
634
+	public function admin_footer_scripts()
635
+	{
636
+	}
637
+
638
+
639
+	/**
640
+	 *        get list of registration statuses
641
+	 *
642
+	 * @access private
643
+	 * @return void
644
+	 * @throws EE_Error
645
+	 */
646
+	private function _get_registration_status_array()
647
+	{
648
+		self::$_reg_status = EEM_Registration::reg_status_array(array(), true);
649
+	}
650
+
651
+
652
+	protected function _add_screen_options_default()
653
+	{
654
+		$this->_per_page_screen_option();
655
+	}
656
+
657
+
658
+	protected function _add_screen_options_contact_list()
659
+	{
660
+		$page_title              = $this->_admin_page_title;
661
+		$this->_admin_page_title = esc_html__("Contacts", 'event_espresso');
662
+		$this->_per_page_screen_option();
663
+		$this->_admin_page_title = $page_title;
664
+	}
665
+
666
+
667
+	public function load_scripts_styles()
668
+	{
669
+		//style
670
+		wp_register_style(
671
+			'espresso_reg',
672
+			REG_ASSETS_URL . 'espresso_registrations_admin.css',
673
+			array('ee-admin-css'),
674
+			EVENT_ESPRESSO_VERSION
675
+		);
676
+		wp_enqueue_style('espresso_reg');
677
+		//script
678
+		wp_register_script(
679
+			'espresso_reg',
680
+			REG_ASSETS_URL . 'espresso_registrations_admin.js',
681
+			array('jquery-ui-datepicker', 'jquery-ui-draggable', 'ee_admin_js'),
682
+			EVENT_ESPRESSO_VERSION,
683
+			true
684
+		);
685
+		wp_enqueue_script('espresso_reg');
686
+	}
687
+
688
+
689
+	public function load_scripts_styles_edit_attendee()
690
+	{
691
+		//stuff to only show up on our attendee edit details page.
692
+		$attendee_details_translations = array(
693
+			'att_publish_text' => sprintf(
694
+				esc_html__('Created on: <b>%1$s</b>', 'event_espresso'),
695
+				$this->_cpt_model_obj->get_datetime('ATT_created')
696
+			),
697
+		);
698
+		wp_localize_script('espresso_reg', 'ATTENDEE_DETAILS', $attendee_details_translations);
699
+		wp_enqueue_script('jquery-validate');
700
+	}
701
+
702
+
703
+	public function load_scripts_styles_view_registration()
704
+	{
705
+		//styles
706
+		wp_enqueue_style('espresso-ui-theme');
707
+		//scripts
708
+		$this->_get_reg_custom_questions_form($this->_registration->ID());
709
+		$this->_reg_custom_questions_form->wp_enqueue_scripts(true);
710
+	}
711
+
712
+
713
+	public function load_scripts_styles_contact_list()
714
+	{
715
+		wp_deregister_style('espresso_reg');
716
+		wp_register_style(
717
+			'espresso_att',
718
+			REG_ASSETS_URL . 'espresso_attendees_admin.css',
719
+			array('ee-admin-css'),
720
+			EVENT_ESPRESSO_VERSION
721
+		);
722
+		wp_enqueue_style('espresso_att');
723
+	}
724
+
725
+
726
+	public function load_scripts_styles_new_registration()
727
+	{
728
+		wp_register_script(
729
+			'ee-spco-for-admin',
730
+			REG_ASSETS_URL . 'spco_for_admin.js',
731
+			array('underscore', 'jquery'),
732
+			EVENT_ESPRESSO_VERSION,
733
+			true
734
+		);
735
+		wp_enqueue_script('ee-spco-for-admin');
736
+		add_filter('FHEE__EED_Ticket_Selector__load_tckt_slctr_assets', '__return_true');
737
+		EE_Form_Section_Proper::wp_enqueue_scripts();
738
+		EED_Ticket_Selector::load_tckt_slctr_assets();
739
+		EE_Datepicker_Input::enqueue_styles_and_scripts();
740
+	}
741
+
742
+
743
+	public function AHEE__EE_Admin_Page__route_admin_request_resend_registration()
744
+	{
745
+		add_filter('FHEE_load_EE_messages', '__return_true');
746
+	}
747
+
748
+
749
+	public function AHEE__EE_Admin_Page__route_admin_request_approve_registration()
750
+	{
751
+		add_filter('FHEE_load_EE_messages', '__return_true');
752
+	}
753
+
754
+
755
+	protected function _set_list_table_views_default()
756
+	{
757
+		//for notification related bulk actions we need to make sure only active messengers have an option.
758
+		EED_Messages::set_autoloaders();
759
+		/** @type EE_Message_Resource_Manager $message_resource_manager */
760
+		$message_resource_manager = EE_Registry::instance()->load_lib('Message_Resource_Manager');
761
+		$active_mts               = $message_resource_manager->list_of_active_message_types();
762
+		//key= bulk_action_slug, value= message type.
763
+		$match_array = array(
764
+			'approve_registrations'    => 'registration',
765
+			'decline_registrations'    => 'declined_registration',
766
+			'pending_registrations'    => 'pending_approval',
767
+			'no_approve_registrations' => 'not_approved_registration',
768
+			'cancel_registrations'     => 'cancelled_registration',
769
+		);
770
+		$can_send = EE_Registry::instance()->CAP->current_user_can(
771
+			'ee_send_message',
772
+			'batch_send_messages'
773
+		);
774
+		/** setup reg status bulk actions **/
775
+		$def_reg_status_actions['approve_registrations'] = esc_html__('Approve Registrations', 'event_espresso');
776
+		if ($can_send && in_array($match_array['approve_registrations'], $active_mts, true)) {
777
+				$def_reg_status_actions['approve_and_notify_registrations'] = esc_html__(
778
+					'Approve and Notify Registrations',
779
+					'event_espresso'
780
+				);
781
+		}
782
+		$def_reg_status_actions['decline_registrations'] = esc_html__('Decline Registrations', 'event_espresso');
783
+		if ($can_send && in_array($match_array['decline_registrations'], $active_mts, true)) {
784
+				$def_reg_status_actions['decline_and_notify_registrations'] = esc_html__(
785
+					'Decline and Notify Registrations',
786
+					'event_espresso'
787
+				);
788
+		}
789
+		$def_reg_status_actions['pending_registrations'] = esc_html__(
790
+			'Set Registrations to Pending Payment',
791
+			'event_espresso'
792
+		);
793
+		if ($can_send && in_array($match_array['pending_registrations'], $active_mts, true)) {
794
+				$def_reg_status_actions['pending_and_notify_registrations'] = esc_html__(
795
+					'Set Registrations to Pending Payment and Notify',
796
+					'event_espresso'
797
+				);
798
+		}
799
+		$def_reg_status_actions['no_approve_registrations'] = esc_html__(
800
+			'Set Registrations to Not Approved',
801
+			'event_espresso'
802
+		);
803
+		if ($can_send && in_array($match_array['no_approve_registrations'], $active_mts, true)) {
804
+				$def_reg_status_actions['no_approve_and_notify_registrations'] = esc_html__(
805
+					'Set Registrations to Not Approved and Notify',
806
+					'event_espresso'
807
+				);
808
+		}
809
+		$def_reg_status_actions['cancel_registrations'] = esc_html__('Cancel Registrations', 'event_espresso');
810
+		if ($can_send && in_array($match_array['cancel_registrations'], $active_mts, true)) {
811
+				$def_reg_status_actions['cancel_and_notify_registrations'] = esc_html__(
812
+					'Cancel Registrations and Notify',
813
+					'event_espresso'
814
+				);
815
+		}
816
+		$def_reg_status_actions = apply_filters(
817
+			'FHEE__Registrations_Admin_Page___set_list_table_views_default__def_reg_status_actions_array',
818
+			$def_reg_status_actions,
819
+			$active_mts,
820
+			$can_send
821
+		);
822
+
823
+		$this->_views = array(
824
+			'all'   => array(
825
+				'slug'        => 'all',
826
+				'label'       => esc_html__('View All Registrations', 'event_espresso'),
827
+				'count'       => 0,
828
+				'bulk_action' => array_merge($def_reg_status_actions, array(
829
+					'trash_registrations' => esc_html__('Trash Registrations', 'event_espresso'),
830
+				)),
831
+			),
832
+			'month' => array(
833
+				'slug'        => 'month',
834
+				'label'       => esc_html__('This Month', 'event_espresso'),
835
+				'count'       => 0,
836
+				'bulk_action' => array_merge($def_reg_status_actions, array(
837
+					'trash_registrations' => esc_html__('Trash Registrations', 'event_espresso'),
838
+				)),
839
+			),
840
+			'today' => array(
841
+				'slug'        => 'today',
842
+				'label'       => sprintf(
843
+					esc_html__('Today - %s', 'event_espresso'),
844
+					date('M d, Y', current_time('timestamp'))
845
+				),
846
+				'count'       => 0,
847
+				'bulk_action' => array_merge($def_reg_status_actions, array(
848
+					'trash_registrations' => esc_html__('Trash Registrations', 'event_espresso'),
849
+				)),
850
+			),
851
+		);
852
+		if (EE_Registry::instance()->CAP->current_user_can(
853
+			'ee_delete_registrations',
854
+			'espresso_registrations_delete_registration'
855
+		)) {
856
+			$this->_views['incomplete'] = array(
857
+				'slug'        => 'incomplete',
858
+				'label'       => esc_html__('Incomplete', 'event_espresso'),
859
+				'count'       => 0,
860
+				'bulk_action' => array(
861
+					'trash_registrations' => esc_html__('Trash Registrations', 'event_espresso'),
862
+				),
863
+			);
864
+			$this->_views['trash']      = array(
865
+				'slug'        => 'trash',
866
+				'label'       => esc_html__('Trash', 'event_espresso'),
867
+				'count'       => 0,
868
+				'bulk_action' => array(
869
+					'restore_registrations' => esc_html__('Restore Registrations', 'event_espresso'),
870
+					'delete_registrations'  => esc_html__('Delete Registrations Permanently', 'event_espresso'),
871
+				),
872
+			);
873
+		}
874
+	}
875
+
876
+
877
+	protected function _set_list_table_views_contact_list()
878
+	{
879
+		$this->_views = array(
880
+			'in_use' => array(
881
+				'slug'        => 'in_use',
882
+				'label'       => esc_html__('In Use', 'event_espresso'),
883
+				'count'       => 0,
884
+				'bulk_action' => array(
885
+					'trash_attendees' => esc_html__('Move to Trash', 'event_espresso'),
886
+				),
887
+			),
888
+		);
889
+		if (EE_Registry::instance()->CAP->current_user_can('ee_delete_contacts',
890
+			'espresso_registrations_trash_attendees')
891
+		) {
892
+			$this->_views['trash'] = array(
893
+				'slug'        => 'trash',
894
+				'label'       => esc_html__('Trash', 'event_espresso'),
895
+				'count'       => 0,
896
+				'bulk_action' => array(
897
+					'restore_attendees' => esc_html__('Restore from Trash', 'event_espresso'),
898
+				),
899
+			);
900
+		}
901
+	}
902
+
903
+
904
+	protected function _registration_legend_items()
905
+	{
906
+		$fc_items = array(
907
+			'star-icon'        => array(
908
+				'class' => 'dashicons dashicons-star-filled lt-blue-icon ee-icon-size-8',
909
+				'desc'  => esc_html__('This is the Primary Registrant', 'event_espresso'),
910
+			),
911
+			'view_details'     => array(
912
+				'class' => 'dashicons dashicons-clipboard',
913
+				'desc'  => esc_html__('View Registration Details', 'event_espresso'),
914
+			),
915
+			'edit_attendee'    => array(
916
+				'class' => 'ee-icon ee-icon-user-edit ee-icon-size-16',
917
+				'desc'  => esc_html__('Edit Contact Details', 'event_espresso'),
918
+			),
919
+			'view_transaction' => array(
920
+				'class' => 'dashicons dashicons-cart',
921
+				'desc'  => esc_html__('View Transaction Details', 'event_espresso'),
922
+			),
923
+			'view_invoice'     => array(
924
+				'class' => 'dashicons dashicons-media-spreadsheet',
925
+				'desc'  => esc_html__('View Transaction Invoice', 'event_espresso'),
926
+			),
927
+		);
928
+		if (EE_Registry::instance()->CAP->current_user_can(
929
+			'ee_send_message',
930
+			'espresso_registrations_resend_registration'
931
+		)) {
932
+			$fc_items['resend_registration'] = array(
933
+				'class' => 'dashicons dashicons-email-alt',
934
+				'desc'  => esc_html__('Resend Registration Details', 'event_espresso'),
935
+			);
936
+		} else {
937
+			$fc_items['blank'] = array('class' => 'blank', 'desc' => '');
938
+		}
939
+		if (EE_Registry::instance()->CAP->current_user_can(
940
+			'ee_read_global_messages',
941
+			'view_filtered_messages'
942
+		)) {
943
+			$related_for_icon = EEH_MSG_Template::get_message_action_icon('see_notifications_for');
944
+			if (isset($related_for_icon['css_class']) && isset($related_for_icon['label'])) {
945
+				$fc_items['view_related_messages'] = array(
946
+					'class' => $related_for_icon['css_class'],
947
+					'desc'  => $related_for_icon['label'],
948
+				);
949
+			}
950
+		}
951
+		$sc_items = array(
952
+			'approved_status'   => array(
953
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_approved,
954
+				'desc'  => EEH_Template::pretty_status(
955
+					EEM_Registration::status_id_approved,
956
+					false,
957
+					'sentence'
958
+				),
959
+			),
960
+			'pending_status'    => array(
961
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_pending_payment,
962
+				'desc'  => EEH_Template::pretty_status(
963
+					EEM_Registration::status_id_pending_payment,
964
+					false,
965
+					'sentence'
966
+				),
967
+			),
968
+			'wait_list'         => array(
969
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_wait_list,
970
+				'desc'  => EEH_Template::pretty_status(
971
+					EEM_Registration::status_id_wait_list,
972
+					false,
973
+					'sentence'
974
+				),
975
+			),
976
+			'incomplete_status' => array(
977
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_incomplete,
978
+				'desc'  => EEH_Template::pretty_status(
979
+					EEM_Registration::status_id_incomplete,
980
+					false,
981
+					'sentence'
982
+				),
983
+			),
984
+			'not_approved'      => array(
985
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_not_approved,
986
+				'desc'  => EEH_Template::pretty_status(
987
+					EEM_Registration::status_id_not_approved,
988
+					false,
989
+					'sentence'
990
+				),
991
+			),
992
+			'declined_status'   => array(
993
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_declined,
994
+				'desc'  => EEH_Template::pretty_status(
995
+					EEM_Registration::status_id_declined,
996
+					false,
997
+					'sentence'
998
+				),
999
+			),
1000
+			'cancelled_status'  => array(
1001
+				'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_cancelled,
1002
+				'desc'  => EEH_Template::pretty_status(
1003
+					EEM_Registration::status_id_cancelled,
1004
+					false,
1005
+					'sentence'
1006
+				),
1007
+			),
1008
+		);
1009
+		return array_merge($fc_items, $sc_items);
1010
+	}
1011
+
1012
+
1013
+
1014
+	/***************************************        REGISTRATION OVERVIEW        **************************************/
1015
+	/**
1016
+	 * @throws \EE_Error
1017
+	 */
1018
+	protected function _registrations_overview_list_table()
1019
+	{
1020
+		$this->_template_args['admin_page_header'] = '';
1021
+		$EVT_ID                                    = ! empty($this->_req_data['event_id'])
1022
+			? absint($this->_req_data['event_id'])
1023
+			: 0;
1024
+		if ($EVT_ID) {
1025
+			if (EE_Registry::instance()->CAP->current_user_can(
1026
+				'ee_edit_registrations',
1027
+				'espresso_registrations_new_registration',
1028
+				$EVT_ID
1029
+			)) {
1030
+				$this->_admin_page_title .= ' ' . $this->get_action_link_or_button(
1031
+					'new_registration',
1032
+					'add-registrant',
1033
+					array('event_id' => $EVT_ID),
1034
+					'add-new-h2'
1035
+				);
1036
+			}
1037
+			$event = EEM_Event::instance()->get_one_by_ID($EVT_ID);
1038
+			if ($event instanceof EE_Event) {
1039
+				$this->_template_args['admin_page_header'] = sprintf(
1040
+					esc_html__(
1041
+						'%s Viewing registrations for the event: %s%s',
1042
+						'event_espresso'
1043
+					),
1044
+					'<h3 style="line-height:1.5em;">',
1045
+					'<br /><a href="'
1046
+						. EE_Admin_Page::add_query_args_and_nonce(
1047
+							array(
1048
+								'action' => 'edit',
1049
+								'post'   => $event->ID(),
1050
+							),
1051
+							EVENTS_ADMIN_URL
1052
+						)
1053
+						. '">&nbsp;'
1054
+						. $event->get('EVT_name')
1055
+						. '&nbsp;</a>&nbsp;',
1056
+					'</h3>'
1057
+				);
1058
+			}
1059
+			$DTT_ID   = ! empty($this->_req_data['datetime_id']) ? absint($this->_req_data['datetime_id']) : 0;
1060
+			$datetime = EEM_Datetime::instance()->get_one_by_ID($DTT_ID);
1061
+			if ($datetime instanceof EE_Datetime && $this->_template_args['admin_page_header'] !== '') {
1062
+				$this->_template_args['admin_page_header'] = substr(
1063
+					$this->_template_args['admin_page_header'],
1064
+					0,
1065
+					-5
1066
+				);
1067
+				$this->_template_args['admin_page_header'] .= ' &nbsp;<span class="drk-grey-text">';
1068
+				$this->_template_args['admin_page_header'] .= '<span class="dashicons dashicons-calendar"></span>';
1069
+				$this->_template_args['admin_page_header'] .= $datetime->name();
1070
+				$this->_template_args['admin_page_header'] .= ' ( ' . $datetime->start_date() . ' )';
1071
+				$this->_template_args['admin_page_header'] .= '</span></h3>';
1072
+			}
1073
+		}
1074
+		$this->_template_args['after_list_table'] = $this->_display_legend($this->_registration_legend_items());
1075
+		$this->display_admin_list_table_page_with_no_sidebar();
1076
+	}
1077
+
1078
+
1079
+	/**
1080
+	 * This sets the _registration property for the registration details screen
1081
+	 *
1082
+	 * @access private
1083
+	 * @return bool
1084
+	 * @throws EE_Error
1085
+	 * @throws InvalidArgumentException
1086
+	 * @throws InvalidDataTypeException
1087
+	 * @throws InvalidInterfaceException
1088
+	 */
1089
+	private function _set_registration_object()
1090
+	{
1091
+		//get out if we've already set the object
1092
+		if ($this->_registration instanceof EE_Registration) {
1093
+			return true;
1094
+		}
1095
+		$REG    = EEM_Registration::instance();
1096
+		$REG_ID = ( ! empty($this->_req_data['_REG_ID'])) ? absint($this->_req_data['_REG_ID']) : false;
1097
+		if ($this->_registration = $REG->get_one_by_ID($REG_ID)) {
1098
+			return true;
1099
+		} else {
1100
+			$error_msg = sprintf(
1101
+				esc_html__(
1102
+					'An error occurred and the details for Registration ID #%s could not be retrieved.',
1103
+					'event_espresso'
1104
+				),
1105
+				$REG_ID
1106
+			);
1107
+			EE_Error::add_error($error_msg, __FILE__, __FUNCTION__, __LINE__);
1108
+			$this->_registration = null;
1109
+			return false;
1110
+		}
1111
+	}
1112
+
1113
+
1114
+	/**
1115
+	 * Used to retrieve registrations for the list table.
1116
+	 *
1117
+	 * @param int  $per_page
1118
+	 * @param bool $count
1119
+	 * @param bool $this_month
1120
+	 * @param bool $today
1121
+	 * @return EE_Registration[]|int
1122
+	 * @throws EE_Error
1123
+	 * @throws InvalidArgumentException
1124
+	 * @throws InvalidDataTypeException
1125
+	 * @throws InvalidInterfaceException
1126
+	 */
1127
+	public function get_registrations(
1128
+		$per_page = 10,
1129
+		$count = false,
1130
+		$this_month = false,
1131
+		$today = false
1132
+	) {
1133
+		if ($this_month) {
1134
+			$this->_req_data['status'] = 'month';
1135
+		}
1136
+		if ($today) {
1137
+			$this->_req_data['status'] = 'today';
1138
+		}
1139
+		$query_params = $this->_get_registration_query_parameters($this->_req_data, $per_page, $count);
1140
+		/**
1141
+		 * Override the default groupby added by EEM_Base so that sorts with multiple order bys work as expected
1142
+		 * @link https://events.codebasehq.com/projects/event-espresso/tickets/10093
1143
+		 * @see EEM_Base::get_all()
1144
+		 */
1145
+		$query_params['group_by'] = '';
1146
+
1147
+		return $count
1148
+			? EEM_Registration::instance()->count($query_params)
1149
+			/** @type EE_Registration[] */
1150
+			: EEM_Registration::instance()->get_all($query_params);
1151
+	}
1152
+
1153
+
1154
+	/**
1155
+	 * Retrieves the query parameters to be used by the Registration model for getting registrations.
1156
+	 * Note: this listens to values on the request for some of the query parameters.
1157
+	 *
1158
+	 * @param array $request
1159
+	 * @param int   $per_page
1160
+	 * @param bool  $count
1161
+	 * @return array
1162
+	 * @throws EE_Error
1163
+	 */
1164
+	protected function _get_registration_query_parameters(
1165
+		$request = array(),
1166
+		$per_page = 10,
1167
+		$count = false
1168
+	) {
1169
+
1170
+		$query_params = array(
1171
+			0                          => $this->_get_where_conditions_for_registrations_query(
1172
+				$request
1173
+			),
1174
+			'caps'                     => EEM_Registration::caps_read_admin,
1175
+			'default_where_conditions' => 'this_model_only',
1176
+		);
1177
+		if (! $count) {
1178
+			$query_params = array_merge(
1179
+				$query_params,
1180
+				$this->_get_orderby_for_registrations_query(),
1181
+				$this->_get_limit($per_page)
1182
+			);
1183
+		}
1184
+
1185
+		return $query_params;
1186
+	}
1187
+
1188
+
1189
+	/**
1190
+	 * This will add EVT_ID to the provided $where array for EE model query parameters.
1191
+	 *
1192
+	 * @param array $request usually the same as $this->_req_data but not necessarily
1193
+	 * @return array
1194
+	 */
1195
+	protected function _add_event_id_to_where_conditions(array $request)
1196
+	{
1197
+		$where = array();
1198
+		if (! empty($request['event_id'])) {
1199
+			$where['EVT_ID'] = absint($request['event_id']);
1200
+		}
1201
+		return $where;
1202
+	}
1203
+
1204
+
1205
+	/**
1206
+	 * Adds category ID if it exists in the request to the where conditions for the registrations query.
1207
+	 *
1208
+	 * @param array $request usually the same as $this->_req_data but not necessarily
1209
+	 * @return array
1210
+	 */
1211
+	protected function _add_category_id_to_where_conditions(array $request)
1212
+	{
1213
+		$where = array();
1214
+		if (! empty($request['EVT_CAT']) && (int)$request['EVT_CAT'] !== -1) {
1215
+			$where['Event.Term_Taxonomy.term_id'] = absint($request['EVT_CAT']);
1216
+		}
1217
+		return $where;
1218
+	}
1219
+
1220
+
1221
+	/**
1222
+	 * Adds the datetime ID if it exists in the request to the where conditions for the registrations query.
1223
+	 *
1224
+	 * @param array $request usually the same as $this->_req_data but not necessarily
1225
+	 * @return array
1226
+	 */
1227
+	protected function _add_datetime_id_to_where_conditions(array $request)
1228
+	{
1229
+		$where = array();
1230
+		if (! empty($request['datetime_id'])) {
1231
+			$where['Ticket.Datetime.DTT_ID'] = absint($request['datetime_id']);
1232
+		}
1233
+		if (! empty($request['DTT_ID'])) {
1234
+			$where['Ticket.Datetime.DTT_ID'] = absint($request['DTT_ID']);
1235
+		}
1236
+		return $where;
1237
+	}
1238
+
1239
+
1240
+	/**
1241
+	 * Adds the correct registration status to the where conditions for the registrations query.
1242
+	 *
1243
+	 * @param array $request usually the same as $this->_req_data but not necessarily
1244
+	 * @return array
1245
+	 */
1246
+	protected function _add_registration_status_to_where_conditions(array $request)
1247
+	{
1248
+		$where = array();
1249
+		$view = EEH_Array::is_set($request, 'status', '');
1250
+		$registration_status = ! empty($request['_reg_status'])
1251
+			? sanitize_text_field($request['_reg_status'])
1252
+			: '';
1253
+
1254
+		/*
1255 1255
          * If filtering by registration status, then we show registrations matching that status.
1256 1256
          * If not filtering by specified status, then we show all registrations excluding incomplete registrations
1257 1257
          * UNLESS viewing trashed registrations.
1258 1258
          */
1259
-        if (! empty($registration_status)) {
1260
-            $where['STS_ID'] = $registration_status;
1261
-        } else {
1262
-            //make sure we exclude incomplete registrations, but only if not trashed.
1263
-            if ($view === 'trash') {
1264
-                $where['REG_deleted'] = true;
1265
-            } elseif ($view === 'incomplete') {
1266
-                $where['STS_ID'] = EEM_Registration::status_id_incomplete;
1267
-            } else {
1268
-                $where['STS_ID'] = array('!=', EEM_Registration::status_id_incomplete);
1269
-            }
1270
-        }
1271
-        return $where;
1272
-    }
1273
-
1274
-
1275
-    /**
1276
-     * Adds any provided date restraints to the where conditions for the registrations query.
1277
-     *
1278
-     * @param array $request usually the same as $this->_req_data but not necessarily
1279
-     * @return array
1280
-     * @throws EE_Error
1281
-     * @throws InvalidArgumentException
1282
-     * @throws InvalidDataTypeException
1283
-     * @throws InvalidInterfaceException
1284
-     */
1285
-    protected function _add_date_to_where_conditions(array $request)
1286
-    {
1287
-        $where = array();
1288
-        $view = EEH_Array::is_set($request, 'status', '');
1289
-        $month_range             = ! empty($request['month_range'])
1290
-            ? sanitize_text_field($request['month_range'])
1291
-            : '';
1292
-        $retrieve_for_today      = $view === 'today';
1293
-        $retrieve_for_this_month = $view === 'month';
1294
-
1295
-        if ($retrieve_for_today) {
1296
-            $now               = date('Y-m-d', current_time('timestamp'));
1297
-            $where['REG_date'] = array(
1298
-                'BETWEEN',
1299
-                array(
1300
-                    EEM_Registration::instance()->convert_datetime_for_query(
1301
-                        'REG_date',
1302
-                        $now . ' 00:00:00',
1303
-                        'Y-m-d H:i:s'
1304
-                    ),
1305
-                    EEM_Registration::instance()->convert_datetime_for_query(
1306
-                        'REG_date',
1307
-                        $now . ' 23:59:59',
1308
-                        'Y-m-d H:i:s'
1309
-                    ),
1310
-                ),
1311
-            );
1312
-        } elseif ($retrieve_for_this_month) {
1313
-            $current_year_and_month = date('Y-m', current_time('timestamp'));
1314
-            $days_this_month        = date('t', current_time('timestamp'));
1315
-            $where['REG_date']      = array(
1316
-                'BETWEEN',
1317
-                array(
1318
-                    EEM_Registration::instance()->convert_datetime_for_query(
1319
-                        'REG_date',
1320
-                        $current_year_and_month . '-01 00:00:00',
1321
-                        'Y-m-d H:i:s'
1322
-                    ),
1323
-                    EEM_Registration::instance()->convert_datetime_for_query(
1324
-                        'REG_date',
1325
-                        $current_year_and_month . '-' . $days_this_month . ' 23:59:59',
1326
-                        'Y-m-d H:i:s'
1327
-                    ),
1328
-                ),
1329
-            );
1330
-        } elseif ($month_range) {
1331
-            $pieces          = explode(' ', $month_range, 3);
1332
-            $month_requested = ! empty($pieces[0])
1333
-                ? date('m', \EEH_DTT_Helper::first_of_month_timestamp($pieces[0]))
1334
-                : '';
1335
-            $year_requested  = ! empty($pieces[1])
1336
-                ? $pieces[1]
1337
-                : '';
1338
-            //if there is not a month or year then we can't go further
1339
-            if ($month_requested && $year_requested) {
1340
-                $days_in_month     = date('t', strtotime($year_requested . '-' . $month_requested . '-' . '01'));
1341
-                $where['REG_date'] = array(
1342
-                    'BETWEEN',
1343
-                    array(
1344
-                        EEM_Registration::instance()->convert_datetime_for_query(
1345
-                            'REG_date',
1346
-                            $year_requested . '-' . $month_requested . '-01 00:00:00',
1347
-                            'Y-m-d H:i:s'
1348
-                        ),
1349
-                        EEM_Registration::instance()->convert_datetime_for_query(
1350
-                            'REG_date',
1351
-                            $year_requested . '-' . $month_requested . '-' . $days_in_month . ' 23:59:59',
1352
-                            'Y-m-d H:i:s'
1353
-                        ),
1354
-                    ),
1355
-                );
1356
-            }
1357
-        }
1358
-        return $where;
1359
-    }
1360
-
1361
-
1362
-    /**
1363
-     * Adds any provided search restraints to the where conditions for the registrations query
1364
-     *
1365
-     * @param array $request usually the same as $this->_req_data but not necessarily
1366
-     * @return array
1367
-     */
1368
-    protected function _add_search_to_where_conditions(array $request)
1369
-    {
1370
-        $where = array();
1371
-        if (! empty($request['s'])) {
1372
-            $search_string = '%' . sanitize_text_field($request['s']) . '%';
1373
-            $where['OR*search_conditions'] = array(
1374
-                'Event.EVT_name'                          => array('LIKE', $search_string),
1375
-                'Event.EVT_desc'                          => array('LIKE', $search_string),
1376
-                'Event.EVT_short_desc'                    => array('LIKE', $search_string),
1377
-                'Attendee.ATT_full_name'                  => array('LIKE', $search_string),
1378
-                'Attendee.ATT_fname'                      => array('LIKE', $search_string),
1379
-                'Attendee.ATT_lname'                      => array('LIKE', $search_string),
1380
-                'Attendee.ATT_short_bio'                  => array('LIKE', $search_string),
1381
-                'Attendee.ATT_email'                      => array('LIKE', $search_string),
1382
-                'Attendee.ATT_address'                    => array('LIKE', $search_string),
1383
-                'Attendee.ATT_address2'                   => array('LIKE', $search_string),
1384
-                'Attendee.ATT_city'                       => array('LIKE', $search_string),
1385
-                'REG_final_price'                         => array('LIKE', $search_string),
1386
-                'REG_code'                                => array('LIKE', $search_string),
1387
-                'REG_count'                               => array('LIKE', $search_string),
1388
-                'REG_group_size'                          => array('LIKE', $search_string),
1389
-                'Ticket.TKT_name'                         => array('LIKE', $search_string),
1390
-                'Ticket.TKT_description'                  => array('LIKE', $search_string),
1391
-                'Transaction.Payment.PAY_txn_id_chq_nmbr' => array('LIKE', $search_string),
1392
-            );
1393
-        }
1394
-        return $where;
1395
-    }
1396
-
1397
-
1398
-    /**
1399
-     * Sets up the where conditions for the registrations query.
1400
-     *
1401
-     * @param array $request
1402
-     * @return array
1403
-     * @throws EE_Error
1404
-     */
1405
-    protected function _get_where_conditions_for_registrations_query($request)
1406
-    {
1407
-        return apply_filters(
1408
-            'FHEE__Registrations_Admin_Page___get_where_conditions_for_registrations_query',
1409
-            array_merge(
1410
-                $this->_add_event_id_to_where_conditions($request),
1411
-                $this->_add_category_id_to_where_conditions($request),
1412
-                $this->_add_datetime_id_to_where_conditions($request),
1413
-                $this->_add_registration_status_to_where_conditions($request),
1414
-                $this->_add_date_to_where_conditions($request),
1415
-                $this->_add_search_to_where_conditions($request)
1416
-            ),
1417
-            $request
1418
-        );
1419
-    }
1420
-
1421
-
1422
-    /**
1423
-     * Sets up the orderby for the registrations query.
1424
-     *
1425
-     * @return array
1426
-     */
1427
-    protected function _get_orderby_for_registrations_query()
1428
-    {
1429
-        $orderby_field = ! empty($this->_req_data['orderby'])
1430
-            ? sanitize_text_field($this->_req_data['orderby'])
1431
-            : '';
1432
-        switch ($orderby_field) {
1433
-            case '_REG_ID':
1434
-                $orderby_field = 'REG_ID';
1435
-                break;
1436
-            case '_Reg_status':
1437
-                $orderby_field = 'STS_ID';
1438
-                break;
1439
-            case 'ATT_fname':
1440
-                $orderby_field = array('Attendee.ATT_fname', 'Attendee.ATT_lname');
1441
-                break;
1442
-            case 'ATT_lname':
1443
-                $orderby_field = array('Attendee.ATT_lname', 'Attendee.ATT_fname');
1444
-                break;
1445
-            case 'event_name':
1446
-                $orderby_field = 'Event.EVT_name';
1447
-                break;
1448
-            case 'DTT_EVT_start':
1449
-                $orderby_field = 'Event.Datetime.DTT_EVT_start';
1450
-                break;
1451
-            default: //'REG_date'
1452
-                $orderby_field = 'REG_date';
1453
-        }
1454
-
1455
-        //order
1456
-        $order = ! empty($this->_req_data['order'])
1457
-            ? sanitize_text_field($this->_req_data['order'])
1458
-            : 'DESC';
1459
-
1460
-        //mutate orderby_field
1461
-        $orderby_field = array_combine(
1462
-            (array) $orderby_field,
1463
-            array_fill(0, count($orderby_field), $order)
1464
-        );
1465
-        //because there are many registrations with the same date, define
1466
-        //a secondary way to order them, otherwise MySQL seems to be a bit random
1467
-        if (empty($order['REG_ID'])) {
1468
-            $orderby_field['REG_ID'] = $order;
1469
-        }
1470
-        return array('order_by' => $orderby_field);
1471
-    }
1472
-
1473
-
1474
-    /**
1475
-     * Sets up the limit for the registrations query.
1476
-     *
1477
-     * @param $per_page
1478
-     * @return array
1479
-     */
1480
-    protected function _get_limit($per_page)
1481
-    {
1482
-        $current_page = ! empty($this->_req_data['paged'])
1483
-            ? absint($this->_req_data['paged'])
1484
-            : 1;
1485
-        $per_page     = ! empty($this->_req_data['perpage'])
1486
-            ? $this->_req_data['perpage']
1487
-            : $per_page;
1488
-
1489
-        //-1 means return all results so get out if that's set.
1490
-        if ((int)$per_page === -1) {
1491
-            return array();
1492
-        }
1493
-        $per_page = absint($per_page);
1494
-        $offset   = ($current_page - 1) * $per_page;
1495
-        return array('limit' => array($offset, $per_page));
1496
-    }
1497
-
1498
-
1499
-    public function get_registration_status_array()
1500
-    {
1501
-        return self::$_reg_status;
1502
-    }
1503
-
1504
-
1505
-
1506
-
1507
-    /***************************************        REGISTRATION DETAILS        ***************************************/
1508
-    /**
1509
-     *        generates HTML for the View Registration Details Admin page
1510
-     *
1511
-     * @access protected
1512
-     * @return void
1513
-     * @throws DomainException
1514
-     * @throws EE_Error
1515
-     * @throws InvalidArgumentException
1516
-     * @throws InvalidDataTypeException
1517
-     * @throws InvalidInterfaceException
1518
-     * @throws EntityNotFoundException
1519
-     */
1520
-    protected function _registration_details()
1521
-    {
1522
-        $this->_template_args = array();
1523
-        $this->_set_registration_object();
1524
-        if (is_object($this->_registration)) {
1525
-            $transaction                                   = $this->_registration->transaction()
1526
-                ? $this->_registration->transaction()
1527
-                : EE_Transaction::new_instance();
1528
-            $this->_session                                = $transaction->session_data();
1529
-            $event_id                                      = $this->_registration->event_ID();
1530
-            $this->_template_args['reg_nmbr']['value']     = $this->_registration->ID();
1531
-            $this->_template_args['reg_nmbr']['label']     = esc_html__('Registration Number', 'event_espresso');
1532
-            $this->_template_args['reg_datetime']['value'] = $this->_registration->get_i18n_datetime('REG_date');
1533
-            $this->_template_args['reg_datetime']['label'] = esc_html__('Date', 'event_espresso');
1534
-            $this->_template_args['grand_total']           = $transaction->total();
1535
-            $this->_template_args['currency_sign']         = EE_Registry::instance()->CFG->currency->sign;
1536
-            // link back to overview
1537
-            $this->_template_args['reg_overview_url']            = REG_ADMIN_URL;
1538
-            $this->_template_args['registration']                = $this->_registration;
1539
-            $this->_template_args['filtered_registrations_link'] = EE_Admin_Page::add_query_args_and_nonce(
1540
-                array(
1541
-                    'action'   => 'default',
1542
-                    'event_id' => $event_id,
1543
-                ),
1544
-                REG_ADMIN_URL
1545
-            );
1546
-            $this->_template_args['filtered_transactions_link']  = EE_Admin_Page::add_query_args_and_nonce(
1547
-                array(
1548
-                    'action' => 'default',
1549
-                    'EVT_ID' => $event_id,
1550
-                    'page'   => 'espresso_transactions',
1551
-                ),
1552
-                admin_url('admin.php')
1553
-            );
1554
-            $this->_template_args['event_link']                  = EE_Admin_Page::add_query_args_and_nonce(
1555
-                array(
1556
-                    'page'   => 'espresso_events',
1557
-                    'action' => 'edit',
1558
-                    'post'   => $event_id,
1559
-                ),
1560
-                admin_url('admin.php')
1561
-            );
1562
-            //next and previous links
1563
-            $next_reg                                      = $this->_registration->next(
1564
-                null,
1565
-                array(),
1566
-                'REG_ID'
1567
-            );
1568
-            $this->_template_args['next_registration']     = $next_reg
1569
-                ? $this->_next_link(
1570
-                    EE_Admin_Page::add_query_args_and_nonce(
1571
-                        array(
1572
-                            'action'  => 'view_registration',
1573
-                            '_REG_ID' => $next_reg['REG_ID'],
1574
-                        ),
1575
-                        REG_ADMIN_URL
1576
-                    ),
1577
-                    'dashicons dashicons-arrow-right ee-icon-size-22'
1578
-                )
1579
-                : '';
1580
-            $previous_reg                                  = $this->_registration->previous(
1581
-                null,
1582
-                array(),
1583
-                'REG_ID'
1584
-            );
1585
-            $this->_template_args['previous_registration'] = $previous_reg
1586
-                ? $this->_previous_link(
1587
-                    EE_Admin_Page::add_query_args_and_nonce(
1588
-                        array(
1589
-                            'action'  => 'view_registration',
1590
-                            '_REG_ID' => $previous_reg['REG_ID'],
1591
-                        ),
1592
-                        REG_ADMIN_URL
1593
-                    ),
1594
-                    'dashicons dashicons-arrow-left ee-icon-size-22'
1595
-                )
1596
-                : '';
1597
-            // grab header
1598
-            $template_path                             = REG_TEMPLATE_PATH . 'reg_admin_details_header.template.php';
1599
-            $this->_template_args['REG_ID']            = $this->_registration->ID();
1600
-            $this->_template_args['admin_page_header'] = EEH_Template::display_template(
1601
-                $template_path,
1602
-                $this->_template_args,
1603
-                true
1604
-            );
1605
-        } else {
1606
-            $this->_template_args['admin_page_header'] = $this->display_espresso_notices();
1607
-        }
1608
-        // the details template wrapper
1609
-        $this->display_admin_page_with_sidebar();
1610
-    }
1611
-
1612
-
1613
-    protected function _registration_details_metaboxes()
1614
-    {
1615
-        do_action('AHEE__Registrations_Admin_Page___registration_details_metabox__start', $this);
1616
-        $this->_set_registration_object();
1617
-        $attendee = $this->_registration instanceof EE_Registration ? $this->_registration->attendee() : null;
1618
-        add_meta_box('edit-reg-status-mbox', esc_html__('Registration Status', 'event_espresso'),
1619
-            array($this, 'set_reg_status_buttons_metabox'), $this->wp_page_slug, 'normal', 'high');
1620
-        add_meta_box('edit-reg-details-mbox', esc_html__('Registration Details', 'event_espresso'),
1621
-            array($this, '_reg_details_meta_box'), $this->wp_page_slug, 'normal', 'high');
1622
-        if ($attendee instanceof EE_Attendee
1623
-            && EE_Registry::instance()->CAP->current_user_can(
1624
-                'ee_edit_registration',
1625
-                'edit-reg-questions-mbox',
1626
-                $this->_registration->ID()
1627
-            )
1628
-        ) {
1629
-            add_meta_box(
1630
-                'edit-reg-questions-mbox',
1631
-                esc_html__('Registration Form Answers', 'event_espresso'),
1632
-                array($this, '_reg_questions_meta_box'),
1633
-                $this->wp_page_slug,
1634
-                'normal',
1635
-                'high'
1636
-            );
1637
-        }
1638
-        add_meta_box(
1639
-            'edit-reg-registrant-mbox',
1640
-            esc_html__('Contact Details', 'event_espresso'),
1641
-            array($this, '_reg_registrant_side_meta_box'),
1642
-            $this->wp_page_slug,
1643
-            'side',
1644
-            'high'
1645
-        );
1646
-        if ($this->_registration->group_size() > 1) {
1647
-            add_meta_box(
1648
-                'edit-reg-attendees-mbox',
1649
-                esc_html__('Other Registrations in this Transaction', 'event_espresso'),
1650
-                array($this, '_reg_attendees_meta_box'),
1651
-                $this->wp_page_slug,
1652
-                'normal',
1653
-                'high'
1654
-            );
1655
-        }
1656
-    }
1657
-
1658
-
1659
-    /**
1660
-     * set_reg_status_buttons_metabox
1661
-     *
1662
-     * @access protected
1663
-     * @return string
1664
-     * @throws \EE_Error
1665
-     */
1666
-    public function set_reg_status_buttons_metabox()
1667
-    {
1668
-        $this->_set_registration_object();
1669
-        $change_reg_status_form = $this->_generate_reg_status_change_form();
1670
-        echo $change_reg_status_form->form_open(
1671
-            self::add_query_args_and_nonce(
1672
-                array(
1673
-                    'action' => 'change_reg_status',
1674
-                ),
1675
-                REG_ADMIN_URL
1676
-            )
1677
-        );
1678
-        echo $change_reg_status_form->get_html();
1679
-        echo $change_reg_status_form->form_close();
1680
-    }
1681
-
1682
-
1683
-    /**
1684
-     * @return EE_Form_Section_Proper
1685
-     * @throws EE_Error
1686
-     * @throws InvalidArgumentException
1687
-     * @throws InvalidDataTypeException
1688
-     * @throws InvalidInterfaceException
1689
-     * @throws \EventEspresso\core\exceptions\EntityNotFoundException
1690
-     */
1691
-    protected function _generate_reg_status_change_form()
1692
-    {
1693
-        return new EE_Form_Section_Proper(array(
1694
-            'name'            => 'reg_status_change_form',
1695
-            'html_id'         => 'reg-status-change-form',
1696
-            'layout_strategy' => new EE_Admin_Two_Column_Layout(),
1697
-            'subsections'     => array(
1698
-                'return'             => new EE_Hidden_Input(array(
1699
-                    'name'    => 'return',
1700
-                    'default' => 'view_registration',
1701
-                )),
1702
-                'REG_ID'             => new EE_Hidden_Input(array(
1703
-                    'name'    => 'REG_ID',
1704
-                    'default' => $this->_registration->ID(),
1705
-                )),
1706
-                'current_status'     => new EE_Form_Section_HTML(
1707
-                    EEH_HTML::tr(
1708
-                        EEH_HTML::th(
1709
-                            EEH_HTML::label(
1710
-                                EEH_HTML::strong(esc_html__('Current Registration Status', 'event_espresso')
1711
-                                )
1712
-                            )
1713
-                        )
1714
-                        . EEH_HTML::td(
1715
-                            EEH_HTML::strong(
1716
-                                $this->_registration->pretty_status(),
1717
-                                '',
1718
-                                'status-' . $this->_registration->status_ID(),
1719
-                                'line-height: 1em; font-size: 1.5em; font-weight: bold;'
1720
-                            )
1721
-                        )
1722
-                    )
1723
-                ),
1724
-                'reg_status'         => new EE_Select_Input(
1725
-                    $this->_get_reg_statuses(),
1726
-                    array(
1727
-                        'html_label_text' => esc_html__('Change Registration Status to', 'event_espresso'),
1728
-                        'default'         => $this->_registration->status_ID(),
1729
-                    )
1730
-                ),
1731
-                'send_notifications' => new EE_Yes_No_Input(
1732
-                    array(
1733
-                        'html_label_text' => esc_html__('Send Related Messages', 'event_espresso'),
1734
-                        'default'         => false,
1735
-                        'html_help_text'  => esc_html__(
1736
-                            'If set to "Yes", then the related messages will be sent to the registrant.',
1737
-                            'event_espresso'
1738
-                        ),
1739
-                    )
1740
-                ),
1741
-                'submit'             => new EE_Submit_Input(
1742
-                    array(
1743
-                        'html_class'      => 'button-primary',
1744
-                        'html_label_text' => '&nbsp;',
1745
-                        'default'         => esc_html__('Update Registration Status', 'event_espresso'),
1746
-                    )
1747
-                ),
1748
-            ),
1749
-        ));
1750
-    }
1751
-
1752
-
1753
-    /**
1754
-     * Returns an array of all the buttons for the various statuses and switch status actions
1755
-     *
1756
-     * @return array
1757
-     * @throws EE_Error
1758
-     * @throws InvalidArgumentException
1759
-     * @throws InvalidDataTypeException
1760
-     * @throws InvalidInterfaceException
1761
-     * @throws EntityNotFoundException
1762
-     */
1763
-    protected function _get_reg_statuses()
1764
-    {
1765
-        $reg_status_array = EEM_Registration::instance()->reg_status_array();
1766
-        unset ($reg_status_array[EEM_Registration::status_id_incomplete]);
1767
-        // get current reg status
1768
-        $current_status = $this->_registration->status_ID();
1769
-        // is registration for free event? This will determine whether to display the pending payment option
1770
-        if (
1771
-            $current_status !== EEM_Registration::status_id_pending_payment
1772
-            && EEH_Money::compare_floats($this->_registration->ticket()->price(), 0.00)
1773
-        ) {
1774
-            unset($reg_status_array[EEM_Registration::status_id_pending_payment]);
1775
-        }
1776
-        return EEM_Status::instance()->localized_status($reg_status_array, false, 'sentence');
1777
-    }
1778
-
1779
-
1780
-    /**
1781
-     * This method is used when using _REG_ID from request which may or may not be an array of reg_ids.
1782
-     *
1783
-     * @param bool $status REG status given for changing registrations to.
1784
-     * @param bool $notify Whether to send messages notifications or not.
1785
-     * @return array (array with reg_id(s) updated and whether update was successful.
1786
-     * @throws EE_Error
1787
-     * @throws InvalidArgumentException
1788
-     * @throws InvalidDataTypeException
1789
-     * @throws InvalidInterfaceException
1790
-     * @throws ReflectionException
1791
-     * @throws RuntimeException
1792
-     * @throws EntityNotFoundException
1793
-     */
1794
-    protected function _set_registration_status_from_request($status = false, $notify = false)
1795
-    {
1796
-        if (isset($this->_req_data['reg_status_change_form'])) {
1797
-            $REG_IDs = isset($this->_req_data['reg_status_change_form']['REG_ID'])
1798
-                ? (array)$this->_req_data['reg_status_change_form']['REG_ID']
1799
-                : array();
1800
-        } else {
1801
-            $REG_IDs = isset($this->_req_data['_REG_ID'])
1802
-                ? (array)$this->_req_data['_REG_ID']
1803
-                : array();
1804
-        }
1805
-        // sanitize $REG_IDs
1806
-        $REG_IDs = array_map('absint', $REG_IDs);
1807
-        // and remove empty entries
1808
-        $REG_IDs = array_filter($REG_IDs);
1809
-
1810
-        $result = $this->_set_registration_status($REG_IDs, $status, $notify);
1811
-
1812
-        /**
1813
-         * Set and filter $_req_data['_REG_ID'] for any potential future messages notifications.
1814
-         * Currently this value is used downstream by the _process_resend_registration method.
1815
-         *
1816
-         * @param int|array                $registration_ids The registration ids that have had their status changed successfully.
1817
-         * @param bool                     $status           The status registrations were changed to.
1818
-         * @param bool                     $success          If the status was changed successfully for all registrations.
1819
-         * @param Registrations_Admin_Page $admin_page_object
1820
-         */
1821
-        $this->_req_data['_REG_ID'] = apply_filters(
1822
-            'FHEE__Registrations_Admin_Page___set_registration_status_from_request__REG_IDs',
1823
-            $result['REG_ID'],
1824
-            $status,
1825
-            $result['success'],
1826
-            $this
1827
-        );
1828
-
1829
-        //notify?
1830
-        if ($notify
1831
-            && $result['success']
1832
-            && ! empty($this->_req_data['_REG_ID'])
1833
-            && EE_Registry::instance()->CAP->current_user_can(
1834
-                'ee_send_message',
1835
-                'espresso_registrations_resend_registration'
1836
-            )
1837
-        ) {
1838
-            $this->_process_resend_registration();
1839
-        }
1840
-        return $result;
1841
-    }
1842
-
1843
-
1844
-    /**
1845
-     * Set the registration status for the given reg_id (which may or may not be an array, it gets typecast to an
1846
-     * array). Note, this method does NOT take care of possible notifications.  That is required by calling code.
1847
-     *
1848
-     * @param array  $REG_IDs
1849
-     * @param string $status
1850
-     * @param bool   $notify  Used to indicate whether notification was requested or not.  This determines the context
1851
-     *                        slug sent with setting the registration status.
1852
-     * @return array (an array with 'success' key representing whether status change was successful, and 'REG_ID' as
1853
-     * @throws EE_Error
1854
-     * @throws InvalidArgumentException
1855
-     * @throws InvalidDataTypeException
1856
-     * @throws InvalidInterfaceException
1857
-     * @throws ReflectionException
1858
-     * @throws RuntimeException
1859
-     * @throws EntityNotFoundException
1860
-     */
1861
-    protected function _set_registration_status($REG_IDs = array(), $status = '', $notify = false)
1862
-    {
1863
-        $success = false;
1864
-        // typecast $REG_IDs
1865
-        $REG_IDs = (array)$REG_IDs;
1866
-        if ( ! empty($REG_IDs)) {
1867
-            $success = true;
1868
-            // set default status if none is passed
1869
-            $status = $status ? $status : EEM_Registration::status_id_pending_payment;
1870
-            $status_context = $notify
1871
-                ? Domain::CONTEXT_REGISTRATION_STATUS_CHANGE_REGISTRATION_ADMIN_NOTIFY
1872
-                : Domain::CONTEXT_REGISTRATION_STATUS_CHANGE_REGISTRATION_ADMIN;
1873
-            //loop through REG_ID's and change status
1874
-            foreach ($REG_IDs as $REG_ID) {
1875
-                $registration = EEM_Registration::instance()->get_one_by_ID($REG_ID);
1876
-                if ($registration instanceof EE_Registration) {
1877
-                    $registration->set_status(
1878
-                        $status,
1879
-                        false,
1880
-                        new Context(
1881
-                            $status_context,
1882
-                            esc_html__(
1883
-                                'Manually triggered status change on a Registration Admin Page route.',
1884
-                                'event_espresso'
1885
-                            )
1886
-                        )
1887
-                    );
1888
-                    $result = $registration->save();
1889
-                    // verifying explicit fails because update *may* just return 0 for 0 rows affected
1890
-                    $success = $result !== false ? $success : false;
1891
-                }
1892
-            }
1893
-        }
1894
-
1895
-        //return $success and processed registrations
1896
-        return array('REG_ID' => $REG_IDs, 'success' => $success);
1897
-    }
1898
-
1899
-
1900
-    /**
1901
-     * Common logic for setting up success message and redirecting to appropriate route
1902
-     *
1903
-     * @param  string $STS_ID status id for the registration changed to
1904
-     * @param   bool  $notify indicates whether the _set_registration_status_from_request does notifications or not.
1905
-     * @return void
1906
-     * @throws EE_Error
1907
-     */
1908
-    protected function _reg_status_change_return($STS_ID, $notify = false)
1909
-    {
1910
-        $result  = ! empty($STS_ID) ? $this->_set_registration_status_from_request($STS_ID, $notify)
1911
-            : array('success' => false);
1912
-        $success = isset($result['success']) && $result['success'];
1913
-        //setup success message
1914
-        if ($success) {
1915
-            if (is_array($result['REG_ID']) && count($result['REG_ID']) === 1) {
1916
-                $msg = sprintf(esc_html__('Registration status has been set to %s', 'event_espresso'),
1917
-                    EEH_Template::pretty_status($STS_ID, false, 'lower'));
1918
-            } else {
1919
-                $msg = sprintf(esc_html__('Registrations have been set to %s.', 'event_espresso'),
1920
-                    EEH_Template::pretty_status($STS_ID, false, 'lower'));
1921
-            }
1922
-            EE_Error::add_success($msg);
1923
-        } else {
1924
-            EE_Error::add_error(
1925
-                esc_html__(
1926
-                    'Something went wrong, and the status was not changed',
1927
-                    'event_espresso'
1928
-                ), __FILE__, __LINE__, __FUNCTION__
1929
-            );
1930
-        }
1931
-        if (isset($this->_req_data['return']) && $this->_req_data['return'] == 'view_registration') {
1932
-            $route = array('action' => 'view_registration', '_REG_ID' => reset($result['REG_ID']));
1933
-        } else {
1934
-            $route = array('action' => 'default');
1935
-        }
1936
-        //unset nonces
1937
-        foreach ($this->_req_data as $ref => $value) {
1938
-            if (strpos($ref, 'nonce') !== false) {
1939
-                unset($this->_req_data[$ref]);
1940
-                continue;
1941
-            }
1942
-            $value                 = is_array($value) ? array_map('urlencode', $value) : urlencode($value);
1943
-            $this->_req_data[$ref] = $value;
1944
-        }
1945
-        //merge request vars so that the reloaded list table contains any existing filter query params
1946
-        $route = array_merge($this->_req_data, $route);
1947
-        $this->_redirect_after_action($success, '', '', $route, true);
1948
-    }
1949
-
1950
-
1951
-    /**
1952
-     * incoming reg status change from reg details page.
1953
-     *
1954
-     * @return void
1955
-     */
1956
-    protected function _change_reg_status()
1957
-    {
1958
-        $this->_req_data['return'] = 'view_registration';
1959
-        //set notify based on whether the send notifications toggle is set or not
1960
-        $notify = ! empty($this->_req_data['reg_status_change_form']['send_notifications']);
1961
-        //$notify = ! empty( $this->_req_data['txn_reg_status_change']['send_notifications'] );
1962
-        $this->_req_data['reg_status_change_form']['reg_status'] = isset($this->_req_data['reg_status_change_form']['reg_status'])
1963
-            ? $this->_req_data['reg_status_change_form']['reg_status'] : '';
1964
-        switch ($this->_req_data['reg_status_change_form']['reg_status']) {
1965
-            case EEM_Registration::status_id_approved :
1966
-            case EEH_Template::pretty_status(EEM_Registration::status_id_approved, false, 'sentence') :
1967
-                $this->approve_registration($notify);
1968
-                break;
1969
-            case EEM_Registration::status_id_pending_payment :
1970
-            case EEH_Template::pretty_status(EEM_Registration::status_id_pending_payment, false, 'sentence') :
1971
-                $this->pending_registration($notify);
1972
-                break;
1973
-            case EEM_Registration::status_id_not_approved :
1974
-            case EEH_Template::pretty_status(EEM_Registration::status_id_not_approved, false, 'sentence') :
1975
-                $this->not_approve_registration($notify);
1976
-                break;
1977
-            case EEM_Registration::status_id_declined :
1978
-            case EEH_Template::pretty_status(EEM_Registration::status_id_declined, false, 'sentence') :
1979
-                $this->decline_registration($notify);
1980
-                break;
1981
-            case EEM_Registration::status_id_cancelled :
1982
-            case EEH_Template::pretty_status(EEM_Registration::status_id_cancelled, false, 'sentence') :
1983
-                $this->cancel_registration($notify);
1984
-                break;
1985
-            case EEM_Registration::status_id_wait_list :
1986
-            case EEH_Template::pretty_status(EEM_Registration::status_id_wait_list, false, 'sentence') :
1987
-                $this->wait_list_registration($notify);
1988
-                break;
1989
-            case EEM_Registration::status_id_incomplete :
1990
-            default :
1991
-                $result['success'] = false;
1992
-                unset($this->_req_data['return']);
1993
-                $this->_reg_status_change_return('', false);
1994
-                break;
1995
-        }
1996
-    }
1997
-
1998
-
1999
-    /**
2000
-     * Callback for bulk action routes.
2001
-     * Note: although we could just register the singular route callbacks for each bulk action route as well, this
2002
-     * method was chosen so there is one central place all the registration status bulk actions are going through.
2003
-     * Potentially, this provides an easier place to locate logic that is specific to these bulk actions (as opposed to
2004
-     * when an action is happening on just a single registration).
2005
-     * @param      $action
2006
-     * @param bool $notify
2007
-     */
2008
-    protected function bulk_action_on_registrations($action, $notify = false) {
2009
-        do_action(
2010
-            'AHEE__Registrations_Admin_Page__bulk_action_on_registrations__before_execution',
2011
-            $this,
2012
-            $action,
2013
-            $notify
2014
-        );
2015
-        $method = $action . '_registration';
2016
-        if (method_exists($this, $method)) {
2017
-            $this->$method($notify);
2018
-        }
2019
-    }
2020
-
2021
-
2022
-    /**
2023
-     * approve_registration
2024
-     *
2025
-     * @access protected
2026
-     * @param bool $notify whether or not to notify the registrant about their approval.
2027
-     * @return void
2028
-     */
2029
-    protected function approve_registration($notify = false)
2030
-    {
2031
-        $this->_reg_status_change_return(EEM_Registration::status_id_approved, $notify);
2032
-    }
2033
-
2034
-
2035
-    /**
2036
-     *        decline_registration
2037
-     *
2038
-     * @access protected
2039
-     * @param bool $notify whether or not to notify the registrant about their status change.
2040
-     * @return void
2041
-     */
2042
-    protected function decline_registration($notify = false)
2043
-    {
2044
-        $this->_reg_status_change_return(EEM_Registration::status_id_declined, $notify);
2045
-    }
2046
-
2047
-
2048
-    /**
2049
-     *        cancel_registration
2050
-     *
2051
-     * @access protected
2052
-     * @param bool $notify whether or not to notify the registrant about their status change.
2053
-     * @return void
2054
-     */
2055
-    protected function cancel_registration($notify = false)
2056
-    {
2057
-        $this->_reg_status_change_return(EEM_Registration::status_id_cancelled, $notify);
2058
-    }
2059
-
2060
-
2061
-    /**
2062
-     *        not_approve_registration
2063
-     *
2064
-     * @access protected
2065
-     * @param bool $notify whether or not to notify the registrant about their status change.
2066
-     * @return void
2067
-     */
2068
-    protected function not_approve_registration($notify = false)
2069
-    {
2070
-        $this->_reg_status_change_return(EEM_Registration::status_id_not_approved, $notify);
2071
-    }
2072
-
2073
-
2074
-    /**
2075
-     *        decline_registration
2076
-     *
2077
-     * @access protected
2078
-     * @param bool $notify whether or not to notify the registrant about their status change.
2079
-     * @return void
2080
-     */
2081
-    protected function pending_registration($notify = false)
2082
-    {
2083
-        $this->_reg_status_change_return(EEM_Registration::status_id_pending_payment, $notify);
2084
-    }
2085
-
2086
-
2087
-    /**
2088
-     * waitlist_registration
2089
-     *
2090
-     * @access protected
2091
-     * @param bool $notify whether or not to notify the registrant about their status change.
2092
-     * @return void
2093
-     */
2094
-    protected function wait_list_registration($notify = false)
2095
-    {
2096
-        $this->_reg_status_change_return(EEM_Registration::status_id_wait_list, $notify);
2097
-    }
2098
-
2099
-
2100
-    /**
2101
-     *        generates HTML for the Registration main meta box
2102
-     *
2103
-     * @access public
2104
-     * @return void
2105
-     * @throws DomainException
2106
-     * @throws EE_Error
2107
-     * @throws InvalidArgumentException
2108
-     * @throws InvalidDataTypeException
2109
-     * @throws InvalidInterfaceException
2110
-     * @throws ReflectionException
2111
-     * @throws EntityNotFoundException
2112
-     */
2113
-    public function _reg_details_meta_box()
2114
-    {
2115
-        EEH_Autoloader::register_line_item_display_autoloaders();
2116
-        EEH_Autoloader::register_line_item_filter_autoloaders();
2117
-        EE_Registry::instance()->load_helper('Line_Item');
2118
-        $transaction    = $this->_registration->transaction() ? $this->_registration->transaction()
2119
-            : EE_Transaction::new_instance();
2120
-        $this->_session = $transaction->session_data();
2121
-        $filters        = new EE_Line_Item_Filter_Collection();
2122
-        //$filters->add( new EE_Non_Zero_Line_Item_Filter() );
2123
-        $filters->add(new EE_Single_Registration_Line_Item_Filter($this->_registration));
2124
-        $line_item_filter_processor              = new EE_Line_Item_Filter_Processor($filters,
2125
-            $transaction->total_line_item());
2126
-        $filtered_line_item_tree                 = $line_item_filter_processor->process();
2127
-        $line_item_display                       = new EE_Line_Item_Display('reg_admin_table',
2128
-            'EE_Admin_Table_Registration_Line_Item_Display_Strategy');
2129
-        $this->_template_args['line_item_table'] = $line_item_display->display_line_item(
2130
-            $filtered_line_item_tree,
2131
-            array('EE_Registration' => $this->_registration)
2132
-        );
2133
-        $attendee                                = $this->_registration->attendee();
2134
-        if (EE_Registry::instance()->CAP->current_user_can(
2135
-            'ee_read_transaction',
2136
-            'espresso_transactions_view_transaction'
2137
-        )) {
2138
-            $this->_template_args['view_transaction_button'] = EEH_Template::get_button_or_link(
2139
-                EE_Admin_Page::add_query_args_and_nonce(
2140
-                    array(
2141
-                        'action' => 'view_transaction',
2142
-                        'TXN_ID' => $transaction->ID(),
2143
-                    ),
2144
-                    TXN_ADMIN_URL
2145
-                ),
2146
-                esc_html__(' View Transaction', 'event_espresso'),
2147
-                'button secondary-button right',
2148
-                'dashicons dashicons-cart'
2149
-            );
2150
-        } else {
2151
-            $this->_template_args['view_transaction_button'] = '';
2152
-        }
2153
-        if ($attendee instanceof EE_Attendee
2154
-            && EE_Registry::instance()->CAP->current_user_can(
2155
-                'ee_send_message',
2156
-                'espresso_registrations_resend_registration'
2157
-            )
2158
-        ) {
2159
-            $this->_template_args['resend_registration_button'] = EEH_Template::get_button_or_link(
2160
-                EE_Admin_Page::add_query_args_and_nonce(
2161
-                    array(
2162
-                        'action'      => 'resend_registration',
2163
-                        '_REG_ID'     => $this->_registration->ID(),
2164
-                        'redirect_to' => 'view_registration',
2165
-                    ),
2166
-                    REG_ADMIN_URL
2167
-                ),
2168
-                esc_html__(' Resend Registration', 'event_espresso'),
2169
-                'button secondary-button right',
2170
-                'dashicons dashicons-email-alt'
2171
-            );
2172
-        } else {
2173
-            $this->_template_args['resend_registration_button'] = '';
2174
-        }
2175
-        $this->_template_args['currency_sign'] = EE_Registry::instance()->CFG->currency->sign;
2176
-        $payment                               = $transaction->get_first_related('Payment');
2177
-        $payment                               = ! $payment instanceof EE_Payment
2178
-            ? EE_Payment::new_instance()
2179
-            : $payment;
2180
-        $payment_method                        = $payment->get_first_related('Payment_Method');
2181
-        $payment_method                        = ! $payment_method instanceof EE_Payment_Method
2182
-            ? EE_Payment_Method::new_instance()
2183
-            : $payment_method;
2184
-        $reg_details                           = array(
2185
-            'payment_method'       => $payment_method->name(),
2186
-            'response_msg'         => $payment->gateway_response(),
2187
-            'registration_id'      => $this->_registration->get('REG_code'),
2188
-            'registration_session' => $this->_registration->session_ID(),
2189
-            'ip_address'           => isset($this->_session['ip_address']) ? $this->_session['ip_address'] : '',
2190
-            'user_agent'           => isset($this->_session['user_agent']) ? $this->_session['user_agent'] : '',
2191
-        );
2192
-        if (isset($reg_details['registration_id'])) {
2193
-            $this->_template_args['reg_details']['registration_id']['value'] = $reg_details['registration_id'];
2194
-            $this->_template_args['reg_details']['registration_id']['label'] = esc_html__(
2195
-                'Registration ID',
2196
-                'event_espresso'
2197
-            );
2198
-            $this->_template_args['reg_details']['registration_id']['class'] = 'regular-text';
2199
-        }
2200
-        if (isset($reg_details['payment_method'])) {
2201
-            $this->_template_args['reg_details']['payment_method']['value'] = $reg_details['payment_method'];
2202
-            $this->_template_args['reg_details']['payment_method']['label'] = esc_html__(
2203
-                'Most Recent Payment Method',
2204
-                'event_espresso'
2205
-            );
2206
-            $this->_template_args['reg_details']['payment_method']['class'] = 'regular-text';
2207
-            $this->_template_args['reg_details']['response_msg']['value']   = $reg_details['response_msg'];
2208
-            $this->_template_args['reg_details']['response_msg']['label']   = esc_html__(
2209
-                'Payment method response',
2210
-                'event_espresso'
2211
-            );
2212
-            $this->_template_args['reg_details']['response_msg']['class']   = 'regular-text';
2213
-        }
2214
-        $this->_template_args['reg_details']['registration_session']['value'] = $reg_details['registration_session'];
2215
-        $this->_template_args['reg_details']['registration_session']['label'] = esc_html__(
2216
-            'Registration Session',
2217
-            'event_espresso'
2218
-        );
2219
-        $this->_template_args['reg_details']['registration_session']['class'] = 'regular-text';
2220
-        $this->_template_args['reg_details']['ip_address']['value']           = $reg_details['ip_address'];
2221
-        $this->_template_args['reg_details']['ip_address']['label']           = esc_html__(
2222
-            'Registration placed from IP',
2223
-            'event_espresso'
2224
-        );
2225
-        $this->_template_args['reg_details']['ip_address']['class']           = 'regular-text';
2226
-        $this->_template_args['reg_details']['user_agent']['value']           = $reg_details['user_agent'];
2227
-        $this->_template_args['reg_details']['user_agent']['label']           = esc_html__('Registrant User Agent',
2228
-            'event_espresso');
2229
-        $this->_template_args['reg_details']['user_agent']['class']           = 'large-text';
2230
-        $this->_template_args['event_link']                                   = EE_Admin_Page::add_query_args_and_nonce(
2231
-            array(
2232
-                'action'   => 'default',
2233
-                'event_id' => $this->_registration->event_ID(),
2234
-            ),
2235
-            REG_ADMIN_URL
2236
-        );
2237
-        $this->_template_args['REG_ID']                                       = $this->_registration->ID();
2238
-        $this->_template_args['event_id']                                     = $this->_registration->event_ID();
2239
-        $template_path                                                        =
2240
-            REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_reg_details.template.php';
2241
-        echo EEH_Template::display_template($template_path, $this->_template_args, true);
2242
-    }
2243
-
2244
-
2245
-    /**
2246
-     * generates HTML for the Registration Questions meta box.
2247
-     * If pre-4.8.32.rc.000 hooks are used, uses old methods (with its filters),
2248
-     * otherwise uses new forms system
2249
-     *
2250
-     * @access public
2251
-     * @return void
2252
-     * @throws DomainException
2253
-     * @throws EE_Error
2254
-     */
2255
-    public function _reg_questions_meta_box()
2256
-    {
2257
-        //allow someone to override this method entirely
2258
-        if (apply_filters('FHEE__Registrations_Admin_Page___reg_questions_meta_box__do_default', true, $this,
2259
-            $this->_registration)) {
2260
-            $form                                              = $this->_get_reg_custom_questions_form(
2261
-                $this->_registration->ID()
2262
-            );
2263
-            $this->_template_args['att_questions']             = count($form->subforms()) > 0
2264
-                ? $form->get_html_and_js()
2265
-                : '';
2266
-            $this->_template_args['reg_questions_form_action'] = 'edit_registration';
2267
-            $this->_template_args['REG_ID']                    = $this->_registration->ID();
2268
-            $template_path                                     =
2269
-                REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_reg_questions.template.php';
2270
-            echo EEH_Template::display_template($template_path, $this->_template_args, true);
2271
-        }
2272
-    }
2273
-
2274
-
2275
-    /**
2276
-     * form_before_question_group
2277
-     *
2278
-     * @deprecated    as of 4.8.32.rc.000
2279
-     * @access        public
2280
-     * @param        string $output
2281
-     * @return        string
2282
-     */
2283
-    public function form_before_question_group($output)
2284
-    {
2285
-        EE_Error::doing_it_wrong(
2286
-            __CLASS__ . '::' . __FUNCTION__,
2287
-            esc_html__(
2288
-                'This method would have been protected but was used on a filter callback so needed to be public. Please discontinue usage as it will be removed soon.',
2289
-                'event_espresso'
2290
-            ),
2291
-            '4.8.32.rc.000'
2292
-        );
2293
-        return '
1259
+		if (! empty($registration_status)) {
1260
+			$where['STS_ID'] = $registration_status;
1261
+		} else {
1262
+			//make sure we exclude incomplete registrations, but only if not trashed.
1263
+			if ($view === 'trash') {
1264
+				$where['REG_deleted'] = true;
1265
+			} elseif ($view === 'incomplete') {
1266
+				$where['STS_ID'] = EEM_Registration::status_id_incomplete;
1267
+			} else {
1268
+				$where['STS_ID'] = array('!=', EEM_Registration::status_id_incomplete);
1269
+			}
1270
+		}
1271
+		return $where;
1272
+	}
1273
+
1274
+
1275
+	/**
1276
+	 * Adds any provided date restraints to the where conditions for the registrations query.
1277
+	 *
1278
+	 * @param array $request usually the same as $this->_req_data but not necessarily
1279
+	 * @return array
1280
+	 * @throws EE_Error
1281
+	 * @throws InvalidArgumentException
1282
+	 * @throws InvalidDataTypeException
1283
+	 * @throws InvalidInterfaceException
1284
+	 */
1285
+	protected function _add_date_to_where_conditions(array $request)
1286
+	{
1287
+		$where = array();
1288
+		$view = EEH_Array::is_set($request, 'status', '');
1289
+		$month_range             = ! empty($request['month_range'])
1290
+			? sanitize_text_field($request['month_range'])
1291
+			: '';
1292
+		$retrieve_for_today      = $view === 'today';
1293
+		$retrieve_for_this_month = $view === 'month';
1294
+
1295
+		if ($retrieve_for_today) {
1296
+			$now               = date('Y-m-d', current_time('timestamp'));
1297
+			$where['REG_date'] = array(
1298
+				'BETWEEN',
1299
+				array(
1300
+					EEM_Registration::instance()->convert_datetime_for_query(
1301
+						'REG_date',
1302
+						$now . ' 00:00:00',
1303
+						'Y-m-d H:i:s'
1304
+					),
1305
+					EEM_Registration::instance()->convert_datetime_for_query(
1306
+						'REG_date',
1307
+						$now . ' 23:59:59',
1308
+						'Y-m-d H:i:s'
1309
+					),
1310
+				),
1311
+			);
1312
+		} elseif ($retrieve_for_this_month) {
1313
+			$current_year_and_month = date('Y-m', current_time('timestamp'));
1314
+			$days_this_month        = date('t', current_time('timestamp'));
1315
+			$where['REG_date']      = array(
1316
+				'BETWEEN',
1317
+				array(
1318
+					EEM_Registration::instance()->convert_datetime_for_query(
1319
+						'REG_date',
1320
+						$current_year_and_month . '-01 00:00:00',
1321
+						'Y-m-d H:i:s'
1322
+					),
1323
+					EEM_Registration::instance()->convert_datetime_for_query(
1324
+						'REG_date',
1325
+						$current_year_and_month . '-' . $days_this_month . ' 23:59:59',
1326
+						'Y-m-d H:i:s'
1327
+					),
1328
+				),
1329
+			);
1330
+		} elseif ($month_range) {
1331
+			$pieces          = explode(' ', $month_range, 3);
1332
+			$month_requested = ! empty($pieces[0])
1333
+				? date('m', \EEH_DTT_Helper::first_of_month_timestamp($pieces[0]))
1334
+				: '';
1335
+			$year_requested  = ! empty($pieces[1])
1336
+				? $pieces[1]
1337
+				: '';
1338
+			//if there is not a month or year then we can't go further
1339
+			if ($month_requested && $year_requested) {
1340
+				$days_in_month     = date('t', strtotime($year_requested . '-' . $month_requested . '-' . '01'));
1341
+				$where['REG_date'] = array(
1342
+					'BETWEEN',
1343
+					array(
1344
+						EEM_Registration::instance()->convert_datetime_for_query(
1345
+							'REG_date',
1346
+							$year_requested . '-' . $month_requested . '-01 00:00:00',
1347
+							'Y-m-d H:i:s'
1348
+						),
1349
+						EEM_Registration::instance()->convert_datetime_for_query(
1350
+							'REG_date',
1351
+							$year_requested . '-' . $month_requested . '-' . $days_in_month . ' 23:59:59',
1352
+							'Y-m-d H:i:s'
1353
+						),
1354
+					),
1355
+				);
1356
+			}
1357
+		}
1358
+		return $where;
1359
+	}
1360
+
1361
+
1362
+	/**
1363
+	 * Adds any provided search restraints to the where conditions for the registrations query
1364
+	 *
1365
+	 * @param array $request usually the same as $this->_req_data but not necessarily
1366
+	 * @return array
1367
+	 */
1368
+	protected function _add_search_to_where_conditions(array $request)
1369
+	{
1370
+		$where = array();
1371
+		if (! empty($request['s'])) {
1372
+			$search_string = '%' . sanitize_text_field($request['s']) . '%';
1373
+			$where['OR*search_conditions'] = array(
1374
+				'Event.EVT_name'                          => array('LIKE', $search_string),
1375
+				'Event.EVT_desc'                          => array('LIKE', $search_string),
1376
+				'Event.EVT_short_desc'                    => array('LIKE', $search_string),
1377
+				'Attendee.ATT_full_name'                  => array('LIKE', $search_string),
1378
+				'Attendee.ATT_fname'                      => array('LIKE', $search_string),
1379
+				'Attendee.ATT_lname'                      => array('LIKE', $search_string),
1380
+				'Attendee.ATT_short_bio'                  => array('LIKE', $search_string),
1381
+				'Attendee.ATT_email'                      => array('LIKE', $search_string),
1382
+				'Attendee.ATT_address'                    => array('LIKE', $search_string),
1383
+				'Attendee.ATT_address2'                   => array('LIKE', $search_string),
1384
+				'Attendee.ATT_city'                       => array('LIKE', $search_string),
1385
+				'REG_final_price'                         => array('LIKE', $search_string),
1386
+				'REG_code'                                => array('LIKE', $search_string),
1387
+				'REG_count'                               => array('LIKE', $search_string),
1388
+				'REG_group_size'                          => array('LIKE', $search_string),
1389
+				'Ticket.TKT_name'                         => array('LIKE', $search_string),
1390
+				'Ticket.TKT_description'                  => array('LIKE', $search_string),
1391
+				'Transaction.Payment.PAY_txn_id_chq_nmbr' => array('LIKE', $search_string),
1392
+			);
1393
+		}
1394
+		return $where;
1395
+	}
1396
+
1397
+
1398
+	/**
1399
+	 * Sets up the where conditions for the registrations query.
1400
+	 *
1401
+	 * @param array $request
1402
+	 * @return array
1403
+	 * @throws EE_Error
1404
+	 */
1405
+	protected function _get_where_conditions_for_registrations_query($request)
1406
+	{
1407
+		return apply_filters(
1408
+			'FHEE__Registrations_Admin_Page___get_where_conditions_for_registrations_query',
1409
+			array_merge(
1410
+				$this->_add_event_id_to_where_conditions($request),
1411
+				$this->_add_category_id_to_where_conditions($request),
1412
+				$this->_add_datetime_id_to_where_conditions($request),
1413
+				$this->_add_registration_status_to_where_conditions($request),
1414
+				$this->_add_date_to_where_conditions($request),
1415
+				$this->_add_search_to_where_conditions($request)
1416
+			),
1417
+			$request
1418
+		);
1419
+	}
1420
+
1421
+
1422
+	/**
1423
+	 * Sets up the orderby for the registrations query.
1424
+	 *
1425
+	 * @return array
1426
+	 */
1427
+	protected function _get_orderby_for_registrations_query()
1428
+	{
1429
+		$orderby_field = ! empty($this->_req_data['orderby'])
1430
+			? sanitize_text_field($this->_req_data['orderby'])
1431
+			: '';
1432
+		switch ($orderby_field) {
1433
+			case '_REG_ID':
1434
+				$orderby_field = 'REG_ID';
1435
+				break;
1436
+			case '_Reg_status':
1437
+				$orderby_field = 'STS_ID';
1438
+				break;
1439
+			case 'ATT_fname':
1440
+				$orderby_field = array('Attendee.ATT_fname', 'Attendee.ATT_lname');
1441
+				break;
1442
+			case 'ATT_lname':
1443
+				$orderby_field = array('Attendee.ATT_lname', 'Attendee.ATT_fname');
1444
+				break;
1445
+			case 'event_name':
1446
+				$orderby_field = 'Event.EVT_name';
1447
+				break;
1448
+			case 'DTT_EVT_start':
1449
+				$orderby_field = 'Event.Datetime.DTT_EVT_start';
1450
+				break;
1451
+			default: //'REG_date'
1452
+				$orderby_field = 'REG_date';
1453
+		}
1454
+
1455
+		//order
1456
+		$order = ! empty($this->_req_data['order'])
1457
+			? sanitize_text_field($this->_req_data['order'])
1458
+			: 'DESC';
1459
+
1460
+		//mutate orderby_field
1461
+		$orderby_field = array_combine(
1462
+			(array) $orderby_field,
1463
+			array_fill(0, count($orderby_field), $order)
1464
+		);
1465
+		//because there are many registrations with the same date, define
1466
+		//a secondary way to order them, otherwise MySQL seems to be a bit random
1467
+		if (empty($order['REG_ID'])) {
1468
+			$orderby_field['REG_ID'] = $order;
1469
+		}
1470
+		return array('order_by' => $orderby_field);
1471
+	}
1472
+
1473
+
1474
+	/**
1475
+	 * Sets up the limit for the registrations query.
1476
+	 *
1477
+	 * @param $per_page
1478
+	 * @return array
1479
+	 */
1480
+	protected function _get_limit($per_page)
1481
+	{
1482
+		$current_page = ! empty($this->_req_data['paged'])
1483
+			? absint($this->_req_data['paged'])
1484
+			: 1;
1485
+		$per_page     = ! empty($this->_req_data['perpage'])
1486
+			? $this->_req_data['perpage']
1487
+			: $per_page;
1488
+
1489
+		//-1 means return all results so get out if that's set.
1490
+		if ((int)$per_page === -1) {
1491
+			return array();
1492
+		}
1493
+		$per_page = absint($per_page);
1494
+		$offset   = ($current_page - 1) * $per_page;
1495
+		return array('limit' => array($offset, $per_page));
1496
+	}
1497
+
1498
+
1499
+	public function get_registration_status_array()
1500
+	{
1501
+		return self::$_reg_status;
1502
+	}
1503
+
1504
+
1505
+
1506
+
1507
+	/***************************************        REGISTRATION DETAILS        ***************************************/
1508
+	/**
1509
+	 *        generates HTML for the View Registration Details Admin page
1510
+	 *
1511
+	 * @access protected
1512
+	 * @return void
1513
+	 * @throws DomainException
1514
+	 * @throws EE_Error
1515
+	 * @throws InvalidArgumentException
1516
+	 * @throws InvalidDataTypeException
1517
+	 * @throws InvalidInterfaceException
1518
+	 * @throws EntityNotFoundException
1519
+	 */
1520
+	protected function _registration_details()
1521
+	{
1522
+		$this->_template_args = array();
1523
+		$this->_set_registration_object();
1524
+		if (is_object($this->_registration)) {
1525
+			$transaction                                   = $this->_registration->transaction()
1526
+				? $this->_registration->transaction()
1527
+				: EE_Transaction::new_instance();
1528
+			$this->_session                                = $transaction->session_data();
1529
+			$event_id                                      = $this->_registration->event_ID();
1530
+			$this->_template_args['reg_nmbr']['value']     = $this->_registration->ID();
1531
+			$this->_template_args['reg_nmbr']['label']     = esc_html__('Registration Number', 'event_espresso');
1532
+			$this->_template_args['reg_datetime']['value'] = $this->_registration->get_i18n_datetime('REG_date');
1533
+			$this->_template_args['reg_datetime']['label'] = esc_html__('Date', 'event_espresso');
1534
+			$this->_template_args['grand_total']           = $transaction->total();
1535
+			$this->_template_args['currency_sign']         = EE_Registry::instance()->CFG->currency->sign;
1536
+			// link back to overview
1537
+			$this->_template_args['reg_overview_url']            = REG_ADMIN_URL;
1538
+			$this->_template_args['registration']                = $this->_registration;
1539
+			$this->_template_args['filtered_registrations_link'] = EE_Admin_Page::add_query_args_and_nonce(
1540
+				array(
1541
+					'action'   => 'default',
1542
+					'event_id' => $event_id,
1543
+				),
1544
+				REG_ADMIN_URL
1545
+			);
1546
+			$this->_template_args['filtered_transactions_link']  = EE_Admin_Page::add_query_args_and_nonce(
1547
+				array(
1548
+					'action' => 'default',
1549
+					'EVT_ID' => $event_id,
1550
+					'page'   => 'espresso_transactions',
1551
+				),
1552
+				admin_url('admin.php')
1553
+			);
1554
+			$this->_template_args['event_link']                  = EE_Admin_Page::add_query_args_and_nonce(
1555
+				array(
1556
+					'page'   => 'espresso_events',
1557
+					'action' => 'edit',
1558
+					'post'   => $event_id,
1559
+				),
1560
+				admin_url('admin.php')
1561
+			);
1562
+			//next and previous links
1563
+			$next_reg                                      = $this->_registration->next(
1564
+				null,
1565
+				array(),
1566
+				'REG_ID'
1567
+			);
1568
+			$this->_template_args['next_registration']     = $next_reg
1569
+				? $this->_next_link(
1570
+					EE_Admin_Page::add_query_args_and_nonce(
1571
+						array(
1572
+							'action'  => 'view_registration',
1573
+							'_REG_ID' => $next_reg['REG_ID'],
1574
+						),
1575
+						REG_ADMIN_URL
1576
+					),
1577
+					'dashicons dashicons-arrow-right ee-icon-size-22'
1578
+				)
1579
+				: '';
1580
+			$previous_reg                                  = $this->_registration->previous(
1581
+				null,
1582
+				array(),
1583
+				'REG_ID'
1584
+			);
1585
+			$this->_template_args['previous_registration'] = $previous_reg
1586
+				? $this->_previous_link(
1587
+					EE_Admin_Page::add_query_args_and_nonce(
1588
+						array(
1589
+							'action'  => 'view_registration',
1590
+							'_REG_ID' => $previous_reg['REG_ID'],
1591
+						),
1592
+						REG_ADMIN_URL
1593
+					),
1594
+					'dashicons dashicons-arrow-left ee-icon-size-22'
1595
+				)
1596
+				: '';
1597
+			// grab header
1598
+			$template_path                             = REG_TEMPLATE_PATH . 'reg_admin_details_header.template.php';
1599
+			$this->_template_args['REG_ID']            = $this->_registration->ID();
1600
+			$this->_template_args['admin_page_header'] = EEH_Template::display_template(
1601
+				$template_path,
1602
+				$this->_template_args,
1603
+				true
1604
+			);
1605
+		} else {
1606
+			$this->_template_args['admin_page_header'] = $this->display_espresso_notices();
1607
+		}
1608
+		// the details template wrapper
1609
+		$this->display_admin_page_with_sidebar();
1610
+	}
1611
+
1612
+
1613
+	protected function _registration_details_metaboxes()
1614
+	{
1615
+		do_action('AHEE__Registrations_Admin_Page___registration_details_metabox__start', $this);
1616
+		$this->_set_registration_object();
1617
+		$attendee = $this->_registration instanceof EE_Registration ? $this->_registration->attendee() : null;
1618
+		add_meta_box('edit-reg-status-mbox', esc_html__('Registration Status', 'event_espresso'),
1619
+			array($this, 'set_reg_status_buttons_metabox'), $this->wp_page_slug, 'normal', 'high');
1620
+		add_meta_box('edit-reg-details-mbox', esc_html__('Registration Details', 'event_espresso'),
1621
+			array($this, '_reg_details_meta_box'), $this->wp_page_slug, 'normal', 'high');
1622
+		if ($attendee instanceof EE_Attendee
1623
+			&& EE_Registry::instance()->CAP->current_user_can(
1624
+				'ee_edit_registration',
1625
+				'edit-reg-questions-mbox',
1626
+				$this->_registration->ID()
1627
+			)
1628
+		) {
1629
+			add_meta_box(
1630
+				'edit-reg-questions-mbox',
1631
+				esc_html__('Registration Form Answers', 'event_espresso'),
1632
+				array($this, '_reg_questions_meta_box'),
1633
+				$this->wp_page_slug,
1634
+				'normal',
1635
+				'high'
1636
+			);
1637
+		}
1638
+		add_meta_box(
1639
+			'edit-reg-registrant-mbox',
1640
+			esc_html__('Contact Details', 'event_espresso'),
1641
+			array($this, '_reg_registrant_side_meta_box'),
1642
+			$this->wp_page_slug,
1643
+			'side',
1644
+			'high'
1645
+		);
1646
+		if ($this->_registration->group_size() > 1) {
1647
+			add_meta_box(
1648
+				'edit-reg-attendees-mbox',
1649
+				esc_html__('Other Registrations in this Transaction', 'event_espresso'),
1650
+				array($this, '_reg_attendees_meta_box'),
1651
+				$this->wp_page_slug,
1652
+				'normal',
1653
+				'high'
1654
+			);
1655
+		}
1656
+	}
1657
+
1658
+
1659
+	/**
1660
+	 * set_reg_status_buttons_metabox
1661
+	 *
1662
+	 * @access protected
1663
+	 * @return string
1664
+	 * @throws \EE_Error
1665
+	 */
1666
+	public function set_reg_status_buttons_metabox()
1667
+	{
1668
+		$this->_set_registration_object();
1669
+		$change_reg_status_form = $this->_generate_reg_status_change_form();
1670
+		echo $change_reg_status_form->form_open(
1671
+			self::add_query_args_and_nonce(
1672
+				array(
1673
+					'action' => 'change_reg_status',
1674
+				),
1675
+				REG_ADMIN_URL
1676
+			)
1677
+		);
1678
+		echo $change_reg_status_form->get_html();
1679
+		echo $change_reg_status_form->form_close();
1680
+	}
1681
+
1682
+
1683
+	/**
1684
+	 * @return EE_Form_Section_Proper
1685
+	 * @throws EE_Error
1686
+	 * @throws InvalidArgumentException
1687
+	 * @throws InvalidDataTypeException
1688
+	 * @throws InvalidInterfaceException
1689
+	 * @throws \EventEspresso\core\exceptions\EntityNotFoundException
1690
+	 */
1691
+	protected function _generate_reg_status_change_form()
1692
+	{
1693
+		return new EE_Form_Section_Proper(array(
1694
+			'name'            => 'reg_status_change_form',
1695
+			'html_id'         => 'reg-status-change-form',
1696
+			'layout_strategy' => new EE_Admin_Two_Column_Layout(),
1697
+			'subsections'     => array(
1698
+				'return'             => new EE_Hidden_Input(array(
1699
+					'name'    => 'return',
1700
+					'default' => 'view_registration',
1701
+				)),
1702
+				'REG_ID'             => new EE_Hidden_Input(array(
1703
+					'name'    => 'REG_ID',
1704
+					'default' => $this->_registration->ID(),
1705
+				)),
1706
+				'current_status'     => new EE_Form_Section_HTML(
1707
+					EEH_HTML::tr(
1708
+						EEH_HTML::th(
1709
+							EEH_HTML::label(
1710
+								EEH_HTML::strong(esc_html__('Current Registration Status', 'event_espresso')
1711
+								)
1712
+							)
1713
+						)
1714
+						. EEH_HTML::td(
1715
+							EEH_HTML::strong(
1716
+								$this->_registration->pretty_status(),
1717
+								'',
1718
+								'status-' . $this->_registration->status_ID(),
1719
+								'line-height: 1em; font-size: 1.5em; font-weight: bold;'
1720
+							)
1721
+						)
1722
+					)
1723
+				),
1724
+				'reg_status'         => new EE_Select_Input(
1725
+					$this->_get_reg_statuses(),
1726
+					array(
1727
+						'html_label_text' => esc_html__('Change Registration Status to', 'event_espresso'),
1728
+						'default'         => $this->_registration->status_ID(),
1729
+					)
1730
+				),
1731
+				'send_notifications' => new EE_Yes_No_Input(
1732
+					array(
1733
+						'html_label_text' => esc_html__('Send Related Messages', 'event_espresso'),
1734
+						'default'         => false,
1735
+						'html_help_text'  => esc_html__(
1736
+							'If set to "Yes", then the related messages will be sent to the registrant.',
1737
+							'event_espresso'
1738
+						),
1739
+					)
1740
+				),
1741
+				'submit'             => new EE_Submit_Input(
1742
+					array(
1743
+						'html_class'      => 'button-primary',
1744
+						'html_label_text' => '&nbsp;',
1745
+						'default'         => esc_html__('Update Registration Status', 'event_espresso'),
1746
+					)
1747
+				),
1748
+			),
1749
+		));
1750
+	}
1751
+
1752
+
1753
+	/**
1754
+	 * Returns an array of all the buttons for the various statuses and switch status actions
1755
+	 *
1756
+	 * @return array
1757
+	 * @throws EE_Error
1758
+	 * @throws InvalidArgumentException
1759
+	 * @throws InvalidDataTypeException
1760
+	 * @throws InvalidInterfaceException
1761
+	 * @throws EntityNotFoundException
1762
+	 */
1763
+	protected function _get_reg_statuses()
1764
+	{
1765
+		$reg_status_array = EEM_Registration::instance()->reg_status_array();
1766
+		unset ($reg_status_array[EEM_Registration::status_id_incomplete]);
1767
+		// get current reg status
1768
+		$current_status = $this->_registration->status_ID();
1769
+		// is registration for free event? This will determine whether to display the pending payment option
1770
+		if (
1771
+			$current_status !== EEM_Registration::status_id_pending_payment
1772
+			&& EEH_Money::compare_floats($this->_registration->ticket()->price(), 0.00)
1773
+		) {
1774
+			unset($reg_status_array[EEM_Registration::status_id_pending_payment]);
1775
+		}
1776
+		return EEM_Status::instance()->localized_status($reg_status_array, false, 'sentence');
1777
+	}
1778
+
1779
+
1780
+	/**
1781
+	 * This method is used when using _REG_ID from request which may or may not be an array of reg_ids.
1782
+	 *
1783
+	 * @param bool $status REG status given for changing registrations to.
1784
+	 * @param bool $notify Whether to send messages notifications or not.
1785
+	 * @return array (array with reg_id(s) updated and whether update was successful.
1786
+	 * @throws EE_Error
1787
+	 * @throws InvalidArgumentException
1788
+	 * @throws InvalidDataTypeException
1789
+	 * @throws InvalidInterfaceException
1790
+	 * @throws ReflectionException
1791
+	 * @throws RuntimeException
1792
+	 * @throws EntityNotFoundException
1793
+	 */
1794
+	protected function _set_registration_status_from_request($status = false, $notify = false)
1795
+	{
1796
+		if (isset($this->_req_data['reg_status_change_form'])) {
1797
+			$REG_IDs = isset($this->_req_data['reg_status_change_form']['REG_ID'])
1798
+				? (array)$this->_req_data['reg_status_change_form']['REG_ID']
1799
+				: array();
1800
+		} else {
1801
+			$REG_IDs = isset($this->_req_data['_REG_ID'])
1802
+				? (array)$this->_req_data['_REG_ID']
1803
+				: array();
1804
+		}
1805
+		// sanitize $REG_IDs
1806
+		$REG_IDs = array_map('absint', $REG_IDs);
1807
+		// and remove empty entries
1808
+		$REG_IDs = array_filter($REG_IDs);
1809
+
1810
+		$result = $this->_set_registration_status($REG_IDs, $status, $notify);
1811
+
1812
+		/**
1813
+		 * Set and filter $_req_data['_REG_ID'] for any potential future messages notifications.
1814
+		 * Currently this value is used downstream by the _process_resend_registration method.
1815
+		 *
1816
+		 * @param int|array                $registration_ids The registration ids that have had their status changed successfully.
1817
+		 * @param bool                     $status           The status registrations were changed to.
1818
+		 * @param bool                     $success          If the status was changed successfully for all registrations.
1819
+		 * @param Registrations_Admin_Page $admin_page_object
1820
+		 */
1821
+		$this->_req_data['_REG_ID'] = apply_filters(
1822
+			'FHEE__Registrations_Admin_Page___set_registration_status_from_request__REG_IDs',
1823
+			$result['REG_ID'],
1824
+			$status,
1825
+			$result['success'],
1826
+			$this
1827
+		);
1828
+
1829
+		//notify?
1830
+		if ($notify
1831
+			&& $result['success']
1832
+			&& ! empty($this->_req_data['_REG_ID'])
1833
+			&& EE_Registry::instance()->CAP->current_user_can(
1834
+				'ee_send_message',
1835
+				'espresso_registrations_resend_registration'
1836
+			)
1837
+		) {
1838
+			$this->_process_resend_registration();
1839
+		}
1840
+		return $result;
1841
+	}
1842
+
1843
+
1844
+	/**
1845
+	 * Set the registration status for the given reg_id (which may or may not be an array, it gets typecast to an
1846
+	 * array). Note, this method does NOT take care of possible notifications.  That is required by calling code.
1847
+	 *
1848
+	 * @param array  $REG_IDs
1849
+	 * @param string $status
1850
+	 * @param bool   $notify  Used to indicate whether notification was requested or not.  This determines the context
1851
+	 *                        slug sent with setting the registration status.
1852
+	 * @return array (an array with 'success' key representing whether status change was successful, and 'REG_ID' as
1853
+	 * @throws EE_Error
1854
+	 * @throws InvalidArgumentException
1855
+	 * @throws InvalidDataTypeException
1856
+	 * @throws InvalidInterfaceException
1857
+	 * @throws ReflectionException
1858
+	 * @throws RuntimeException
1859
+	 * @throws EntityNotFoundException
1860
+	 */
1861
+	protected function _set_registration_status($REG_IDs = array(), $status = '', $notify = false)
1862
+	{
1863
+		$success = false;
1864
+		// typecast $REG_IDs
1865
+		$REG_IDs = (array)$REG_IDs;
1866
+		if ( ! empty($REG_IDs)) {
1867
+			$success = true;
1868
+			// set default status if none is passed
1869
+			$status = $status ? $status : EEM_Registration::status_id_pending_payment;
1870
+			$status_context = $notify
1871
+				? Domain::CONTEXT_REGISTRATION_STATUS_CHANGE_REGISTRATION_ADMIN_NOTIFY
1872
+				: Domain::CONTEXT_REGISTRATION_STATUS_CHANGE_REGISTRATION_ADMIN;
1873
+			//loop through REG_ID's and change status
1874
+			foreach ($REG_IDs as $REG_ID) {
1875
+				$registration = EEM_Registration::instance()->get_one_by_ID($REG_ID);
1876
+				if ($registration instanceof EE_Registration) {
1877
+					$registration->set_status(
1878
+						$status,
1879
+						false,
1880
+						new Context(
1881
+							$status_context,
1882
+							esc_html__(
1883
+								'Manually triggered status change on a Registration Admin Page route.',
1884
+								'event_espresso'
1885
+							)
1886
+						)
1887
+					);
1888
+					$result = $registration->save();
1889
+					// verifying explicit fails because update *may* just return 0 for 0 rows affected
1890
+					$success = $result !== false ? $success : false;
1891
+				}
1892
+			}
1893
+		}
1894
+
1895
+		//return $success and processed registrations
1896
+		return array('REG_ID' => $REG_IDs, 'success' => $success);
1897
+	}
1898
+
1899
+
1900
+	/**
1901
+	 * Common logic for setting up success message and redirecting to appropriate route
1902
+	 *
1903
+	 * @param  string $STS_ID status id for the registration changed to
1904
+	 * @param   bool  $notify indicates whether the _set_registration_status_from_request does notifications or not.
1905
+	 * @return void
1906
+	 * @throws EE_Error
1907
+	 */
1908
+	protected function _reg_status_change_return($STS_ID, $notify = false)
1909
+	{
1910
+		$result  = ! empty($STS_ID) ? $this->_set_registration_status_from_request($STS_ID, $notify)
1911
+			: array('success' => false);
1912
+		$success = isset($result['success']) && $result['success'];
1913
+		//setup success message
1914
+		if ($success) {
1915
+			if (is_array($result['REG_ID']) && count($result['REG_ID']) === 1) {
1916
+				$msg = sprintf(esc_html__('Registration status has been set to %s', 'event_espresso'),
1917
+					EEH_Template::pretty_status($STS_ID, false, 'lower'));
1918
+			} else {
1919
+				$msg = sprintf(esc_html__('Registrations have been set to %s.', 'event_espresso'),
1920
+					EEH_Template::pretty_status($STS_ID, false, 'lower'));
1921
+			}
1922
+			EE_Error::add_success($msg);
1923
+		} else {
1924
+			EE_Error::add_error(
1925
+				esc_html__(
1926
+					'Something went wrong, and the status was not changed',
1927
+					'event_espresso'
1928
+				), __FILE__, __LINE__, __FUNCTION__
1929
+			);
1930
+		}
1931
+		if (isset($this->_req_data['return']) && $this->_req_data['return'] == 'view_registration') {
1932
+			$route = array('action' => 'view_registration', '_REG_ID' => reset($result['REG_ID']));
1933
+		} else {
1934
+			$route = array('action' => 'default');
1935
+		}
1936
+		//unset nonces
1937
+		foreach ($this->_req_data as $ref => $value) {
1938
+			if (strpos($ref, 'nonce') !== false) {
1939
+				unset($this->_req_data[$ref]);
1940
+				continue;
1941
+			}
1942
+			$value                 = is_array($value) ? array_map('urlencode', $value) : urlencode($value);
1943
+			$this->_req_data[$ref] = $value;
1944
+		}
1945
+		//merge request vars so that the reloaded list table contains any existing filter query params
1946
+		$route = array_merge($this->_req_data, $route);
1947
+		$this->_redirect_after_action($success, '', '', $route, true);
1948
+	}
1949
+
1950
+
1951
+	/**
1952
+	 * incoming reg status change from reg details page.
1953
+	 *
1954
+	 * @return void
1955
+	 */
1956
+	protected function _change_reg_status()
1957
+	{
1958
+		$this->_req_data['return'] = 'view_registration';
1959
+		//set notify based on whether the send notifications toggle is set or not
1960
+		$notify = ! empty($this->_req_data['reg_status_change_form']['send_notifications']);
1961
+		//$notify = ! empty( $this->_req_data['txn_reg_status_change']['send_notifications'] );
1962
+		$this->_req_data['reg_status_change_form']['reg_status'] = isset($this->_req_data['reg_status_change_form']['reg_status'])
1963
+			? $this->_req_data['reg_status_change_form']['reg_status'] : '';
1964
+		switch ($this->_req_data['reg_status_change_form']['reg_status']) {
1965
+			case EEM_Registration::status_id_approved :
1966
+			case EEH_Template::pretty_status(EEM_Registration::status_id_approved, false, 'sentence') :
1967
+				$this->approve_registration($notify);
1968
+				break;
1969
+			case EEM_Registration::status_id_pending_payment :
1970
+			case EEH_Template::pretty_status(EEM_Registration::status_id_pending_payment, false, 'sentence') :
1971
+				$this->pending_registration($notify);
1972
+				break;
1973
+			case EEM_Registration::status_id_not_approved :
1974
+			case EEH_Template::pretty_status(EEM_Registration::status_id_not_approved, false, 'sentence') :
1975
+				$this->not_approve_registration($notify);
1976
+				break;
1977
+			case EEM_Registration::status_id_declined :
1978
+			case EEH_Template::pretty_status(EEM_Registration::status_id_declined, false, 'sentence') :
1979
+				$this->decline_registration($notify);
1980
+				break;
1981
+			case EEM_Registration::status_id_cancelled :
1982
+			case EEH_Template::pretty_status(EEM_Registration::status_id_cancelled, false, 'sentence') :
1983
+				$this->cancel_registration($notify);
1984
+				break;
1985
+			case EEM_Registration::status_id_wait_list :
1986
+			case EEH_Template::pretty_status(EEM_Registration::status_id_wait_list, false, 'sentence') :
1987
+				$this->wait_list_registration($notify);
1988
+				break;
1989
+			case EEM_Registration::status_id_incomplete :
1990
+			default :
1991
+				$result['success'] = false;
1992
+				unset($this->_req_data['return']);
1993
+				$this->_reg_status_change_return('', false);
1994
+				break;
1995
+		}
1996
+	}
1997
+
1998
+
1999
+	/**
2000
+	 * Callback for bulk action routes.
2001
+	 * Note: although we could just register the singular route callbacks for each bulk action route as well, this
2002
+	 * method was chosen so there is one central place all the registration status bulk actions are going through.
2003
+	 * Potentially, this provides an easier place to locate logic that is specific to these bulk actions (as opposed to
2004
+	 * when an action is happening on just a single registration).
2005
+	 * @param      $action
2006
+	 * @param bool $notify
2007
+	 */
2008
+	protected function bulk_action_on_registrations($action, $notify = false) {
2009
+		do_action(
2010
+			'AHEE__Registrations_Admin_Page__bulk_action_on_registrations__before_execution',
2011
+			$this,
2012
+			$action,
2013
+			$notify
2014
+		);
2015
+		$method = $action . '_registration';
2016
+		if (method_exists($this, $method)) {
2017
+			$this->$method($notify);
2018
+		}
2019
+	}
2020
+
2021
+
2022
+	/**
2023
+	 * approve_registration
2024
+	 *
2025
+	 * @access protected
2026
+	 * @param bool $notify whether or not to notify the registrant about their approval.
2027
+	 * @return void
2028
+	 */
2029
+	protected function approve_registration($notify = false)
2030
+	{
2031
+		$this->_reg_status_change_return(EEM_Registration::status_id_approved, $notify);
2032
+	}
2033
+
2034
+
2035
+	/**
2036
+	 *        decline_registration
2037
+	 *
2038
+	 * @access protected
2039
+	 * @param bool $notify whether or not to notify the registrant about their status change.
2040
+	 * @return void
2041
+	 */
2042
+	protected function decline_registration($notify = false)
2043
+	{
2044
+		$this->_reg_status_change_return(EEM_Registration::status_id_declined, $notify);
2045
+	}
2046
+
2047
+
2048
+	/**
2049
+	 *        cancel_registration
2050
+	 *
2051
+	 * @access protected
2052
+	 * @param bool $notify whether or not to notify the registrant about their status change.
2053
+	 * @return void
2054
+	 */
2055
+	protected function cancel_registration($notify = false)
2056
+	{
2057
+		$this->_reg_status_change_return(EEM_Registration::status_id_cancelled, $notify);
2058
+	}
2059
+
2060
+
2061
+	/**
2062
+	 *        not_approve_registration
2063
+	 *
2064
+	 * @access protected
2065
+	 * @param bool $notify whether or not to notify the registrant about their status change.
2066
+	 * @return void
2067
+	 */
2068
+	protected function not_approve_registration($notify = false)
2069
+	{
2070
+		$this->_reg_status_change_return(EEM_Registration::status_id_not_approved, $notify);
2071
+	}
2072
+
2073
+
2074
+	/**
2075
+	 *        decline_registration
2076
+	 *
2077
+	 * @access protected
2078
+	 * @param bool $notify whether or not to notify the registrant about their status change.
2079
+	 * @return void
2080
+	 */
2081
+	protected function pending_registration($notify = false)
2082
+	{
2083
+		$this->_reg_status_change_return(EEM_Registration::status_id_pending_payment, $notify);
2084
+	}
2085
+
2086
+
2087
+	/**
2088
+	 * waitlist_registration
2089
+	 *
2090
+	 * @access protected
2091
+	 * @param bool $notify whether or not to notify the registrant about their status change.
2092
+	 * @return void
2093
+	 */
2094
+	protected function wait_list_registration($notify = false)
2095
+	{
2096
+		$this->_reg_status_change_return(EEM_Registration::status_id_wait_list, $notify);
2097
+	}
2098
+
2099
+
2100
+	/**
2101
+	 *        generates HTML for the Registration main meta box
2102
+	 *
2103
+	 * @access public
2104
+	 * @return void
2105
+	 * @throws DomainException
2106
+	 * @throws EE_Error
2107
+	 * @throws InvalidArgumentException
2108
+	 * @throws InvalidDataTypeException
2109
+	 * @throws InvalidInterfaceException
2110
+	 * @throws ReflectionException
2111
+	 * @throws EntityNotFoundException
2112
+	 */
2113
+	public function _reg_details_meta_box()
2114
+	{
2115
+		EEH_Autoloader::register_line_item_display_autoloaders();
2116
+		EEH_Autoloader::register_line_item_filter_autoloaders();
2117
+		EE_Registry::instance()->load_helper('Line_Item');
2118
+		$transaction    = $this->_registration->transaction() ? $this->_registration->transaction()
2119
+			: EE_Transaction::new_instance();
2120
+		$this->_session = $transaction->session_data();
2121
+		$filters        = new EE_Line_Item_Filter_Collection();
2122
+		//$filters->add( new EE_Non_Zero_Line_Item_Filter() );
2123
+		$filters->add(new EE_Single_Registration_Line_Item_Filter($this->_registration));
2124
+		$line_item_filter_processor              = new EE_Line_Item_Filter_Processor($filters,
2125
+			$transaction->total_line_item());
2126
+		$filtered_line_item_tree                 = $line_item_filter_processor->process();
2127
+		$line_item_display                       = new EE_Line_Item_Display('reg_admin_table',
2128
+			'EE_Admin_Table_Registration_Line_Item_Display_Strategy');
2129
+		$this->_template_args['line_item_table'] = $line_item_display->display_line_item(
2130
+			$filtered_line_item_tree,
2131
+			array('EE_Registration' => $this->_registration)
2132
+		);
2133
+		$attendee                                = $this->_registration->attendee();
2134
+		if (EE_Registry::instance()->CAP->current_user_can(
2135
+			'ee_read_transaction',
2136
+			'espresso_transactions_view_transaction'
2137
+		)) {
2138
+			$this->_template_args['view_transaction_button'] = EEH_Template::get_button_or_link(
2139
+				EE_Admin_Page::add_query_args_and_nonce(
2140
+					array(
2141
+						'action' => 'view_transaction',
2142
+						'TXN_ID' => $transaction->ID(),
2143
+					),
2144
+					TXN_ADMIN_URL
2145
+				),
2146
+				esc_html__(' View Transaction', 'event_espresso'),
2147
+				'button secondary-button right',
2148
+				'dashicons dashicons-cart'
2149
+			);
2150
+		} else {
2151
+			$this->_template_args['view_transaction_button'] = '';
2152
+		}
2153
+		if ($attendee instanceof EE_Attendee
2154
+			&& EE_Registry::instance()->CAP->current_user_can(
2155
+				'ee_send_message',
2156
+				'espresso_registrations_resend_registration'
2157
+			)
2158
+		) {
2159
+			$this->_template_args['resend_registration_button'] = EEH_Template::get_button_or_link(
2160
+				EE_Admin_Page::add_query_args_and_nonce(
2161
+					array(
2162
+						'action'      => 'resend_registration',
2163
+						'_REG_ID'     => $this->_registration->ID(),
2164
+						'redirect_to' => 'view_registration',
2165
+					),
2166
+					REG_ADMIN_URL
2167
+				),
2168
+				esc_html__(' Resend Registration', 'event_espresso'),
2169
+				'button secondary-button right',
2170
+				'dashicons dashicons-email-alt'
2171
+			);
2172
+		} else {
2173
+			$this->_template_args['resend_registration_button'] = '';
2174
+		}
2175
+		$this->_template_args['currency_sign'] = EE_Registry::instance()->CFG->currency->sign;
2176
+		$payment                               = $transaction->get_first_related('Payment');
2177
+		$payment                               = ! $payment instanceof EE_Payment
2178
+			? EE_Payment::new_instance()
2179
+			: $payment;
2180
+		$payment_method                        = $payment->get_first_related('Payment_Method');
2181
+		$payment_method                        = ! $payment_method instanceof EE_Payment_Method
2182
+			? EE_Payment_Method::new_instance()
2183
+			: $payment_method;
2184
+		$reg_details                           = array(
2185
+			'payment_method'       => $payment_method->name(),
2186
+			'response_msg'         => $payment->gateway_response(),
2187
+			'registration_id'      => $this->_registration->get('REG_code'),
2188
+			'registration_session' => $this->_registration->session_ID(),
2189
+			'ip_address'           => isset($this->_session['ip_address']) ? $this->_session['ip_address'] : '',
2190
+			'user_agent'           => isset($this->_session['user_agent']) ? $this->_session['user_agent'] : '',
2191
+		);
2192
+		if (isset($reg_details['registration_id'])) {
2193
+			$this->_template_args['reg_details']['registration_id']['value'] = $reg_details['registration_id'];
2194
+			$this->_template_args['reg_details']['registration_id']['label'] = esc_html__(
2195
+				'Registration ID',
2196
+				'event_espresso'
2197
+			);
2198
+			$this->_template_args['reg_details']['registration_id']['class'] = 'regular-text';
2199
+		}
2200
+		if (isset($reg_details['payment_method'])) {
2201
+			$this->_template_args['reg_details']['payment_method']['value'] = $reg_details['payment_method'];
2202
+			$this->_template_args['reg_details']['payment_method']['label'] = esc_html__(
2203
+				'Most Recent Payment Method',
2204
+				'event_espresso'
2205
+			);
2206
+			$this->_template_args['reg_details']['payment_method']['class'] = 'regular-text';
2207
+			$this->_template_args['reg_details']['response_msg']['value']   = $reg_details['response_msg'];
2208
+			$this->_template_args['reg_details']['response_msg']['label']   = esc_html__(
2209
+				'Payment method response',
2210
+				'event_espresso'
2211
+			);
2212
+			$this->_template_args['reg_details']['response_msg']['class']   = 'regular-text';
2213
+		}
2214
+		$this->_template_args['reg_details']['registration_session']['value'] = $reg_details['registration_session'];
2215
+		$this->_template_args['reg_details']['registration_session']['label'] = esc_html__(
2216
+			'Registration Session',
2217
+			'event_espresso'
2218
+		);
2219
+		$this->_template_args['reg_details']['registration_session']['class'] = 'regular-text';
2220
+		$this->_template_args['reg_details']['ip_address']['value']           = $reg_details['ip_address'];
2221
+		$this->_template_args['reg_details']['ip_address']['label']           = esc_html__(
2222
+			'Registration placed from IP',
2223
+			'event_espresso'
2224
+		);
2225
+		$this->_template_args['reg_details']['ip_address']['class']           = 'regular-text';
2226
+		$this->_template_args['reg_details']['user_agent']['value']           = $reg_details['user_agent'];
2227
+		$this->_template_args['reg_details']['user_agent']['label']           = esc_html__('Registrant User Agent',
2228
+			'event_espresso');
2229
+		$this->_template_args['reg_details']['user_agent']['class']           = 'large-text';
2230
+		$this->_template_args['event_link']                                   = EE_Admin_Page::add_query_args_and_nonce(
2231
+			array(
2232
+				'action'   => 'default',
2233
+				'event_id' => $this->_registration->event_ID(),
2234
+			),
2235
+			REG_ADMIN_URL
2236
+		);
2237
+		$this->_template_args['REG_ID']                                       = $this->_registration->ID();
2238
+		$this->_template_args['event_id']                                     = $this->_registration->event_ID();
2239
+		$template_path                                                        =
2240
+			REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_reg_details.template.php';
2241
+		echo EEH_Template::display_template($template_path, $this->_template_args, true);
2242
+	}
2243
+
2244
+
2245
+	/**
2246
+	 * generates HTML for the Registration Questions meta box.
2247
+	 * If pre-4.8.32.rc.000 hooks are used, uses old methods (with its filters),
2248
+	 * otherwise uses new forms system
2249
+	 *
2250
+	 * @access public
2251
+	 * @return void
2252
+	 * @throws DomainException
2253
+	 * @throws EE_Error
2254
+	 */
2255
+	public function _reg_questions_meta_box()
2256
+	{
2257
+		//allow someone to override this method entirely
2258
+		if (apply_filters('FHEE__Registrations_Admin_Page___reg_questions_meta_box__do_default', true, $this,
2259
+			$this->_registration)) {
2260
+			$form                                              = $this->_get_reg_custom_questions_form(
2261
+				$this->_registration->ID()
2262
+			);
2263
+			$this->_template_args['att_questions']             = count($form->subforms()) > 0
2264
+				? $form->get_html_and_js()
2265
+				: '';
2266
+			$this->_template_args['reg_questions_form_action'] = 'edit_registration';
2267
+			$this->_template_args['REG_ID']                    = $this->_registration->ID();
2268
+			$template_path                                     =
2269
+				REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_reg_questions.template.php';
2270
+			echo EEH_Template::display_template($template_path, $this->_template_args, true);
2271
+		}
2272
+	}
2273
+
2274
+
2275
+	/**
2276
+	 * form_before_question_group
2277
+	 *
2278
+	 * @deprecated    as of 4.8.32.rc.000
2279
+	 * @access        public
2280
+	 * @param        string $output
2281
+	 * @return        string
2282
+	 */
2283
+	public function form_before_question_group($output)
2284
+	{
2285
+		EE_Error::doing_it_wrong(
2286
+			__CLASS__ . '::' . __FUNCTION__,
2287
+			esc_html__(
2288
+				'This method would have been protected but was used on a filter callback so needed to be public. Please discontinue usage as it will be removed soon.',
2289
+				'event_espresso'
2290
+			),
2291
+			'4.8.32.rc.000'
2292
+		);
2293
+		return '
2294 2294
 	<table class="form-table ee-width-100">
2295 2295
 		<tbody>
2296 2296
 			';
2297
-    }
2298
-
2299
-
2300
-    /**
2301
-     * form_after_question_group
2302
-     *
2303
-     * @deprecated    as of 4.8.32.rc.000
2304
-     * @access        public
2305
-     * @param        string $output
2306
-     * @return        string
2307
-     */
2308
-    public function form_after_question_group($output)
2309
-    {
2310
-        EE_Error::doing_it_wrong(
2311
-            __CLASS__ . '::' . __FUNCTION__,
2312
-            esc_html__(
2313
-                'This method would have been protected but was used on a filter callback so needed to be public. Please discontinue usage as it will be removed soon.',
2314
-                'event_espresso'
2315
-            ),
2316
-            '4.8.32.rc.000'
2317
-        );
2318
-        return '
2297
+	}
2298
+
2299
+
2300
+	/**
2301
+	 * form_after_question_group
2302
+	 *
2303
+	 * @deprecated    as of 4.8.32.rc.000
2304
+	 * @access        public
2305
+	 * @param        string $output
2306
+	 * @return        string
2307
+	 */
2308
+	public function form_after_question_group($output)
2309
+	{
2310
+		EE_Error::doing_it_wrong(
2311
+			__CLASS__ . '::' . __FUNCTION__,
2312
+			esc_html__(
2313
+				'This method would have been protected but was used on a filter callback so needed to be public. Please discontinue usage as it will be removed soon.',
2314
+				'event_espresso'
2315
+			),
2316
+			'4.8.32.rc.000'
2317
+		);
2318
+		return '
2319 2319
 			<tr class="hide-if-no-js">
2320 2320
 				<th> </th>
2321 2321
 				<td class="reg-admin-edit-attendee-question-td">
2322 2322
 					<a class="reg-admin-edit-attendee-question-lnk" href="#" title="'
2323
-               . esc_attr__('click to edit question', 'event_espresso')
2324
-               . '">
2323
+			   . esc_attr__('click to edit question', 'event_espresso')
2324
+			   . '">
2325 2325
 						<span class="reg-admin-edit-question-group-spn lt-grey-txt">'
2326
-               . esc_html__('edit the above question group', 'event_espresso')
2327
-               . '</span>
2326
+			   . esc_html__('edit the above question group', 'event_espresso')
2327
+			   . '</span>
2328 2328
 						<div class="dashicons dashicons-edit"></div>
2329 2329
 					</a>
2330 2330
 				</td>
@@ -2332,579 +2332,579 @@  discard block
 block discarded – undo
2332 2332
 		</tbody>
2333 2333
 	</table>
2334 2334
 ';
2335
-    }
2336
-
2337
-
2338
-    /**
2339
-     * form_form_field_label_wrap
2340
-     *
2341
-     * @deprecated    as of 4.8.32.rc.000
2342
-     * @access        public
2343
-     * @param        string $label
2344
-     * @return        string
2345
-     */
2346
-    public function form_form_field_label_wrap($label)
2347
-    {
2348
-        EE_Error::doing_it_wrong(
2349
-            __CLASS__ . '::' . __FUNCTION__,
2350
-            esc_html__(
2351
-                'This method would have been protected but was used on a filter callback so needed to be public. Please discontinue usage as it will be removed soon.',
2352
-                'event_espresso'
2353
-            ),
2354
-            '4.8.32.rc.000'
2355
-        );
2356
-        return '
2335
+	}
2336
+
2337
+
2338
+	/**
2339
+	 * form_form_field_label_wrap
2340
+	 *
2341
+	 * @deprecated    as of 4.8.32.rc.000
2342
+	 * @access        public
2343
+	 * @param        string $label
2344
+	 * @return        string
2345
+	 */
2346
+	public function form_form_field_label_wrap($label)
2347
+	{
2348
+		EE_Error::doing_it_wrong(
2349
+			__CLASS__ . '::' . __FUNCTION__,
2350
+			esc_html__(
2351
+				'This method would have been protected but was used on a filter callback so needed to be public. Please discontinue usage as it will be removed soon.',
2352
+				'event_espresso'
2353
+			),
2354
+			'4.8.32.rc.000'
2355
+		);
2356
+		return '
2357 2357
 			<tr>
2358 2358
 				<th>
2359 2359
 					' . $label . '
2360 2360
 				</th>';
2361
-    }
2362
-
2363
-
2364
-    /**
2365
-     * form_form_field_input__wrap
2366
-     *
2367
-     * @deprecated    as of 4.8.32.rc.000
2368
-     * @access        public
2369
-     * @param        string $input
2370
-     * @return        string
2371
-     */
2372
-    public function form_form_field_input__wrap($input)
2373
-    {
2374
-        EE_Error::doing_it_wrong(
2375
-            __CLASS__ . '::' . __FUNCTION__,
2376
-            esc_html__(
2377
-                'This method would have been protected but was used on a filter callback so needed to be public. Please discontinue usage as it will be removed soon.',
2378
-                'event_espresso'
2379
-            ),
2380
-            '4.8.32.rc.000'
2381
-        );
2382
-        return '
2361
+	}
2362
+
2363
+
2364
+	/**
2365
+	 * form_form_field_input__wrap
2366
+	 *
2367
+	 * @deprecated    as of 4.8.32.rc.000
2368
+	 * @access        public
2369
+	 * @param        string $input
2370
+	 * @return        string
2371
+	 */
2372
+	public function form_form_field_input__wrap($input)
2373
+	{
2374
+		EE_Error::doing_it_wrong(
2375
+			__CLASS__ . '::' . __FUNCTION__,
2376
+			esc_html__(
2377
+				'This method would have been protected but was used on a filter callback so needed to be public. Please discontinue usage as it will be removed soon.',
2378
+				'event_espresso'
2379
+			),
2380
+			'4.8.32.rc.000'
2381
+		);
2382
+		return '
2383 2383
 				<td class="reg-admin-attendee-questions-input-td disabled-input">
2384 2384
 					' . $input . '
2385 2385
 				</td>
2386 2386
 			</tr>';
2387
-    }
2388
-
2389
-
2390
-    /**
2391
-     * Updates the registration's custom questions according to the form info, if the form is submitted.
2392
-     * If it's not a post, the "view_registrations" route will be called next on the SAME request
2393
-     * to display the page
2394
-     *
2395
-     * @access protected
2396
-     * @return void
2397
-     * @throws EE_Error
2398
-     */
2399
-    protected function _update_attendee_registration_form()
2400
-    {
2401
-        do_action('AHEE__Registrations_Admin_Page___update_attendee_registration_form__start', $this);
2402
-        if ($_SERVER['REQUEST_METHOD'] == 'POST') {
2403
-            $REG_ID  = isset($this->_req_data['_REG_ID']) ? absint($this->_req_data['_REG_ID']) : false;
2404
-            $success = $this->_save_reg_custom_questions_form($REG_ID);
2405
-            if ($success) {
2406
-                $what  = esc_html__('Registration Form', 'event_espresso');
2407
-                $route = $REG_ID ? array('action' => 'view_registration', '_REG_ID' => $REG_ID)
2408
-                    : array('action' => 'default');
2409
-                $this->_redirect_after_action($success, $what, esc_html__('updated', 'event_espresso'), $route);
2410
-            }
2411
-        }
2412
-    }
2413
-
2414
-
2415
-    /**
2416
-     * Gets the form for saving registrations custom questions (if done
2417
-     * previously retrieves the cached form object, which may have validation errors in it)
2418
-     *
2419
-     * @param int $REG_ID
2420
-     * @return EE_Registration_Custom_Questions_Form
2421
-     * @throws EE_Error
2422
-     * @throws InvalidArgumentException
2423
-     * @throws InvalidDataTypeException
2424
-     * @throws InvalidInterfaceException
2425
-     */
2426
-    protected function _get_reg_custom_questions_form($REG_ID)
2427
-    {
2428
-        if ( ! $this->_reg_custom_questions_form) {
2429
-            require_once(REG_ADMIN . 'form_sections' . DS . 'EE_Registration_Custom_Questions_Form.form.php');
2430
-            $this->_reg_custom_questions_form = new EE_Registration_Custom_Questions_Form(
2431
-                EEM_Registration::instance()->get_one_by_ID($REG_ID)
2432
-            );
2433
-            $this->_reg_custom_questions_form->_construct_finalize(null, null);
2434
-        }
2435
-        return $this->_reg_custom_questions_form;
2436
-    }
2437
-
2438
-
2439
-    /**
2440
-     * Saves
2441
-     *
2442
-     * @access private
2443
-     * @param bool $REG_ID
2444
-     * @return bool
2445
-     * @throws EE_Error
2446
-     * @throws InvalidArgumentException
2447
-     * @throws InvalidDataTypeException
2448
-     * @throws InvalidInterfaceException
2449
-     */
2450
-    private function _save_reg_custom_questions_form($REG_ID = false)
2451
-    {
2452
-        if ( ! $REG_ID) {
2453
-            EE_Error::add_error(
2454
-                esc_html__(
2455
-                    'An error occurred. No registration ID was received.', 'event_espresso'),
2456
-                __FILE__, __FUNCTION__, __LINE__
2457
-            );
2458
-        }
2459
-        $form = $this->_get_reg_custom_questions_form($REG_ID);
2460
-        $form->receive_form_submission($this->_req_data);
2461
-        $success = false;
2462
-        if ($form->is_valid()) {
2463
-            foreach ($form->subforms() as $question_group_id => $question_group_form) {
2464
-                foreach ($question_group_form->inputs() as $question_id => $input) {
2465
-                    $where_conditions    = array(
2466
-                        'QST_ID' => $question_id,
2467
-                        'REG_ID' => $REG_ID,
2468
-                    );
2469
-                    $possibly_new_values = array(
2470
-                        'ANS_value' => $input->normalized_value(),
2471
-                    );
2472
-                    $answer              = EEM_Answer::instance()->get_one(array($where_conditions));
2473
-                    if ($answer instanceof EE_Answer) {
2474
-                        $success = $answer->save($possibly_new_values);
2475
-                    } else {
2476
-                        //insert it then
2477
-                        $cols_n_vals = array_merge($where_conditions, $possibly_new_values);
2478
-                        $answer      = EE_Answer::new_instance($cols_n_vals);
2479
-                        $success     = $answer->save();
2480
-                    }
2481
-                }
2482
-            }
2483
-        } else {
2484
-            EE_Error::add_error($form->get_validation_error_string(), __FILE__, __FUNCTION__, __LINE__);
2485
-        }
2486
-        return $success;
2487
-    }
2488
-
2489
-
2490
-    /**
2491
-     *        generates HTML for the Registration main meta box
2492
-     *
2493
-     * @access public
2494
-     * @return void
2495
-     * @throws DomainException
2496
-     * @throws EE_Error
2497
-     * @throws InvalidArgumentException
2498
-     * @throws InvalidDataTypeException
2499
-     * @throws InvalidInterfaceException
2500
-     */
2501
-    public function _reg_attendees_meta_box()
2502
-    {
2503
-        $REG = EEM_Registration::instance();
2504
-        //get all other registrations on this transaction, and cache
2505
-        //the attendees for them so we don't have to run another query using force_join
2506
-        $registrations                           = $REG->get_all(array(
2507
-            array(
2508
-                'TXN_ID' => $this->_registration->transaction_ID(),
2509
-                'REG_ID' => array('!=', $this->_registration->ID()),
2510
-            ),
2511
-            'force_join' => array('Attendee'),
2512
-        ));
2513
-        $this->_template_args['attendees']       = array();
2514
-        $this->_template_args['attendee_notice'] = '';
2515
-        if (empty($registrations)
2516
-            || (is_array($registrations)
2517
-                && ! EEH_Array::get_one_item_from_array($registrations))
2518
-        ) {
2519
-            EE_Error::add_error(
2520
-                esc_html__(
2521
-                    'There are no records attached to this registration. Something may have gone wrong with the registration',
2522
-                    'event_espresso'
2523
-                ), __FILE__, __FUNCTION__, __LINE__
2524
-            );
2525
-            $this->_template_args['attendee_notice'] = EE_Error::get_notices();
2526
-        } else {
2527
-            $att_nmbr = 1;
2528
-            foreach ($registrations as $registration) {
2529
-                /* @var $registration EE_Registration */
2530
-                $attendee                                                    = $registration->attendee()
2531
-                    ? $registration->attendee()
2532
-                    : EEM_Attendee::instance()
2533
-                                  ->create_default_object();
2534
-                $this->_template_args['attendees'][$att_nmbr]['STS_ID']      = $registration->status_ID();
2535
-                $this->_template_args['attendees'][$att_nmbr]['fname']       = $attendee->fname();
2536
-                $this->_template_args['attendees'][$att_nmbr]['lname']       = $attendee->lname();
2537
-                $this->_template_args['attendees'][$att_nmbr]['email']       = $attendee->email();
2538
-                $this->_template_args['attendees'][$att_nmbr]['final_price'] = $registration->final_price();
2539
-                $this->_template_args['attendees'][$att_nmbr]['address']     = implode(
2540
-                    ', ',
2541
-                    $attendee->full_address_as_array()
2542
-                );
2543
-                $this->_template_args['attendees'][$att_nmbr]['att_link']    = self::add_query_args_and_nonce(
2544
-                    array(
2545
-                        'action' => 'edit_attendee',
2546
-                        'post'   => $attendee->ID(),
2547
-                    ),
2548
-                    REG_ADMIN_URL
2549
-                );
2550
-                $this->_template_args['attendees'][$att_nmbr]['event_name']  = $registration->event_obj()->name();
2551
-                $att_nmbr++;
2552
-            }
2553
-            $this->_template_args['currency_sign'] = EE_Registry::instance()->CFG->currency->sign;
2554
-        }
2555
-        $template_path = REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_attendees.template.php';
2556
-        echo EEH_Template::display_template($template_path, $this->_template_args, true);
2557
-    }
2558
-
2559
-
2560
-    /**
2561
-     *        generates HTML for the Edit Registration side meta box
2562
-     *
2563
-     * @access public
2564
-     * @return void
2565
-     * @throws DomainException
2566
-     * @throws EE_Error
2567
-     * @throws InvalidArgumentException
2568
-     * @throws InvalidDataTypeException
2569
-     * @throws InvalidInterfaceException
2570
-     */
2571
-    public function _reg_registrant_side_meta_box()
2572
-    {
2573
-        /*@var $attendee EE_Attendee */
2574
-        $att_check = $this->_registration->attendee();
2575
-        $attendee  = $att_check instanceof EE_Attendee ? $att_check : EEM_Attendee::instance()->create_default_object();
2576
-        //now let's determine if this is not the primary registration.  If it isn't then we set the
2577
-        //primary_registration object for reference BUT ONLY if the Attendee object loaded is not the same as the
2578
-        //primary registration object (that way we know if we need to show create button or not)
2579
-        if ( ! $this->_registration->is_primary_registrant()) {
2580
-            $primary_registration = $this->_registration->get_primary_registration();
2581
-            $primary_attendee     = $primary_registration instanceof EE_Registration ? $primary_registration->attendee()
2582
-                : null;
2583
-            if ( ! $primary_attendee instanceof EE_Attendee || $attendee->ID() !== $primary_attendee->ID()) {
2584
-                //in here?  This means the displayed registration is not the primary registrant but ALREADY HAS its own
2585
-                //custom attendee object so let's not worry about the primary reg.
2586
-                $primary_registration = null;
2587
-            }
2588
-        } else {
2589
-            $primary_registration = null;
2590
-        }
2591
-        $this->_template_args['ATT_ID']            = $attendee->ID();
2592
-        $this->_template_args['fname']             = $attendee->fname();
2593
-        $this->_template_args['lname']             = $attendee->lname();
2594
-        $this->_template_args['email']             = $attendee->email();
2595
-        $this->_template_args['phone']             = $attendee->phone();
2596
-        $this->_template_args['formatted_address'] = EEH_Address::format($attendee);
2597
-        //edit link
2598
-        $this->_template_args['att_edit_link']  = EE_Admin_Page::add_query_args_and_nonce(array(
2599
-            'action' => 'edit_attendee',
2600
-            'post'   => $attendee->ID(),
2601
-        ), REG_ADMIN_URL);
2602
-        $this->_template_args['att_edit_label'] = esc_html__('View/Edit Contact', 'event_espresso');
2603
-        //create link
2604
-        $this->_template_args['create_link']  = $primary_registration instanceof EE_Registration
2605
-            ? EE_Admin_Page::add_query_args_and_nonce(array(
2606
-                'action'  => 'duplicate_attendee',
2607
-                '_REG_ID' => $this->_registration->ID(),
2608
-            ), REG_ADMIN_URL) : '';
2609
-        $this->_template_args['create_label'] = esc_html__('Create Contact', 'event_espresso');
2610
-        $this->_template_args['att_check']    = $att_check;
2611
-        $template_path                        = REG_TEMPLATE_PATH . 'reg_admin_details_side_meta_box_registrant.template.php';
2612
-        echo EEH_Template::display_template($template_path, $this->_template_args, true);
2613
-    }
2614
-
2615
-
2616
-    /**
2617
-     * trash or restore registrations
2618
-     *
2619
-     * @param  boolean $trash whether to archive or restore
2620
-     * @return void
2621
-     * @throws EE_Error
2622
-     * @throws InvalidArgumentException
2623
-     * @throws InvalidDataTypeException
2624
-     * @throws InvalidInterfaceException
2625
-     * @throws RuntimeException
2626
-     * @access protected
2627
-     */
2628
-    protected function _trash_or_restore_registrations($trash = true)
2629
-    {
2630
-        //if empty _REG_ID then get out because there's nothing to do
2631
-        if (empty($this->_req_data['_REG_ID'])) {
2632
-            EE_Error::add_error(
2633
-                sprintf(
2634
-                    esc_html__(
2635
-                        'In order to %1$s registrations you must select which ones you wish to %1$s by clicking the checkboxes.',
2636
-                        'event_espresso'
2637
-                    ),
2638
-                    $trash ? 'trash' : 'restore'
2639
-                ),
2640
-                __FILE__, __LINE__, __FUNCTION__
2641
-            );
2642
-            $this->_redirect_after_action(false, '', '', array(), true);
2643
-        }
2644
-        $success = 0;
2645
-        $overwrite_msgs = false;
2646
-        //Checkboxes
2647
-        if ( ! is_array($this->_req_data['_REG_ID'])) {
2648
-            $this->_req_data['_REG_ID'] = array($this->_req_data['_REG_ID']);
2649
-        }
2650
-        $reg_count = count($this->_req_data['_REG_ID']);
2651
-        // cycle thru checkboxes
2652
-        foreach ($this->_req_data['_REG_ID'] as $REG_ID) {
2653
-            /** @var EE_Registration $REG */
2654
-            $REG = EEM_Registration::instance()->get_one_by_ID($REG_ID);
2655
-            $payments = $REG->registration_payments();
2656
-            if (! empty($payments)) {
2657
-                $name = $REG->attendee() instanceof EE_Attendee
2658
-                    ? $REG->attendee()->full_name()
2659
-                    : esc_html__('Unknown Attendee', 'event_espresso');
2660
-                $overwrite_msgs = true;
2661
-                EE_Error::add_error(
2662
-                    sprintf(
2663
-                        esc_html__(
2664
-                            '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.',
2665
-                            'event_espresso'
2666
-                        ),
2667
-                        $name
2668
-                    ),
2669
-                    __FILE__, __FUNCTION__, __LINE__
2670
-                );
2671
-                //can't trash this registration because it has payments.
2672
-                continue;
2673
-            }
2674
-            $updated = $trash ? $REG->delete() : $REG->restore();
2675
-            if ($updated) {
2676
-                $success++;
2677
-            }
2678
-        }
2679
-        $this->_redirect_after_action(
2680
-            $success === $reg_count, // were ALL registrations affected?
2681
-            $success > 1
2682
-                ? esc_html__('Registrations', 'event_espresso')
2683
-                : esc_html__('Registration', 'event_espresso'),
2684
-            $trash
2685
-                ? esc_html__('moved to the trash', 'event_espresso')
2686
-                : esc_html__('restored', 'event_espresso'),
2687
-            array('action' => 'default'),
2688
-            $overwrite_msgs
2689
-        );
2690
-    }
2691
-
2692
-
2693
-    /**
2694
-     * This is used to permanently delete registrations.  Note, this will handle not only deleting permanently the
2695
-     * registration but also.
2696
-     * 1. Removing relations to EE_Attendee
2697
-     * 2. Deleting permanently the related transaction, but ONLY if all related registrations to the transaction are
2698
-     * ALSO trashed.
2699
-     * 3. Deleting permanently any related Line items but only if the above conditions are met.
2700
-     * 4. Removing relationships between all tickets and the related registrations
2701
-     * 5. Deleting permanently any related Answers (and the answers for other related registrations that were deleted.)
2702
-     * 6. Deleting permanently any related Checkins.
2703
-     *
2704
-     * @return void
2705
-     * @throws EE_Error
2706
-     * @throws InvalidArgumentException
2707
-     * @throws InvalidDataTypeException
2708
-     * @throws InvalidInterfaceException
2709
-     */
2710
-    protected function _delete_registrations()
2711
-    {
2712
-        $REG_MDL = EEM_Registration::instance();
2713
-        $success = 1;
2714
-        //Checkboxes
2715
-        if ( ! empty($this->_req_data['_REG_ID']) && is_array($this->_req_data['_REG_ID'])) {
2716
-            // if array has more than one element than success message should be plural
2717
-            $success = count($this->_req_data['_REG_ID']) > 1 ? 2 : 1;
2718
-            // cycle thru checkboxes
2719
-            while (list($ind, $REG_ID) = each($this->_req_data['_REG_ID'])) {
2720
-                $REG = $REG_MDL->get_one_by_ID($REG_ID);
2721
-                if ( ! $REG instanceof EE_Registration) {
2722
-                    continue;
2723
-                }
2724
-                $deleted = $this->_delete_registration($REG);
2725
-                if ( ! $deleted) {
2726
-                    $success = 0;
2727
-                }
2728
-            }
2729
-        } else {
2730
-            // grab single id and delete
2731
-            $REG_ID  = $this->_req_data['_REG_ID'];
2732
-            $REG     = $REG_MDL->get_one_by_ID($REG_ID);
2733
-            $deleted = $this->_delete_registration($REG);
2734
-            if ( ! $deleted) {
2735
-                $success = 0;
2736
-            }
2737
-        }
2738
-        $what        = $success > 1
2739
-            ? esc_html__('Registrations', 'event_espresso')
2740
-            : esc_html__('Registration', 'event_espresso');
2741
-        $action_desc = esc_html__('permanently deleted.', 'event_espresso');
2742
-        $this->_redirect_after_action(
2743
-            $success,
2744
-            $what,
2745
-            $action_desc,
2746
-            array('action' => 'default'),
2747
-            true
2748
-        );
2749
-    }
2750
-
2751
-
2752
-    /**
2753
-     * handles the permanent deletion of a registration.  See comments with _delete_registrations() for details on what
2754
-     * models get affected.
2755
-     *
2756
-     * @param  EE_Registration $REG registration to be deleted permenantly
2757
-     * @return bool true = successful deletion, false = fail.
2758
-     * @throws EE_Error
2759
-     */
2760
-    protected function _delete_registration(EE_Registration $REG)
2761
-    {
2762
-        //first we start with the transaction... ultimately, we WILL not delete permanently if there are any related
2763
-        //registrations on the transaction that are NOT trashed.
2764
-        $TXN         = $REG->get_first_related('Transaction');
2765
-        $REGS        = $TXN->get_many_related('Registration');
2766
-        $all_trashed = true;
2767
-        foreach ($REGS as $registration) {
2768
-            if ( ! $registration->get('REG_deleted')) {
2769
-                $all_trashed = false;
2770
-            }
2771
-        }
2772
-        if ( ! $all_trashed) {
2773
-            EE_Error::add_error(
2774
-                esc_html__(
2775
-                    '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.',
2776
-                    'event_espresso'
2777
-                ),
2778
-                __FILE__, __FUNCTION__, __LINE__
2779
-            );
2780
-            return false;
2781
-        }
2782
-        //k made it here so that means we can delete all the related transactions and their answers (but let's do them
2783
-        //separately from THIS one).
2784
-        foreach ($REGS as $registration) {
2785
-            //delete related answers
2786
-            $registration->delete_related_permanently('Answer');
2787
-            //remove relationship to EE_Attendee (but we ALWAYS leave the contact record intact)
2788
-            $attendee = $registration->get_first_related('Attendee');
2789
-            if ($attendee instanceof EE_Attendee) {
2790
-                $registration->_remove_relation_to($attendee, 'Attendee');
2791
-            }
2792
-            //now remove relationships to tickets on this registration.
2793
-            $registration->_remove_relations('Ticket');
2794
-            //now delete permanently the checkins related to this registration.
2795
-            $registration->delete_related_permanently('Checkin');
2796
-            if ($registration->ID() === $REG->ID()) {
2797
-                continue;
2798
-            } //we don't want to delete permanently the existing registration just yet.
2799
-            //remove relation to transaction for these registrations if NOT the existing registrations
2800
-            $registration->_remove_relations('Transaction');
2801
-            //delete permanently any related messages.
2802
-            $registration->delete_related_permanently('Message');
2803
-            //now delete this registration permanently
2804
-            $registration->delete_permanently();
2805
-        }
2806
-        //now all related registrations on the transaction are handled.  So let's just handle this registration itself
2807
-        // (the transaction and line items should be all that's left).
2808
-        // delete the line items related to the transaction for this registration.
2809
-        $TXN->delete_related_permanently('Line_Item');
2810
-        //we need to remove all the relationships on the transaction
2811
-        $TXN->delete_related_permanently('Payment');
2812
-        $TXN->delete_related_permanently('Extra_Meta');
2813
-        $TXN->delete_related_permanently('Message');
2814
-        //now we can delete this REG permanently (and the transaction of course)
2815
-        $REG->delete_related_permanently('Transaction');
2816
-        return $REG->delete_permanently();
2817
-    }
2818
-
2819
-
2820
-    /**
2821
-     *    generates HTML for the Register New Attendee Admin page
2822
-     *
2823
-     * @access private
2824
-     * @throws DomainException
2825
-     * @throws EE_Error
2826
-     */
2827
-    public function new_registration()
2828
-    {
2829
-        if ( ! $this->_set_reg_event()) {
2830
-            throw new EE_Error(
2831
-                esc_html__(
2832
-                    'Unable to continue with registering because there is no Event ID in the request',
2833
-                    'event_espresso'
2834
-                )
2835
-            );
2836
-        }
2837
-        EE_Registry::instance()->REQ->set_espresso_page(true);
2838
-        // gotta start with a clean slate if we're not coming here via ajax
2839
-        if ( ! defined('DOING_AJAX')
2840
-             && ( ! isset($this->_req_data['processing_registration']) || isset($this->_req_data['step_error']))
2841
-        ) {
2842
-            EE_Registry::instance()->SSN->clear_session(__CLASS__, __FUNCTION__);
2843
-        }
2844
-        $this->_template_args['event_name'] = '';
2845
-        // event name
2846
-        if ($this->_reg_event) {
2847
-            $this->_template_args['event_name'] = $this->_reg_event->name();
2848
-            $edit_event_url                     = self::add_query_args_and_nonce(array(
2849
-                'action' => 'edit',
2850
-                'post'   => $this->_reg_event->ID(),
2851
-            ), EVENTS_ADMIN_URL);
2852
-            $edit_event_lnk                     = '<a href="'
2853
-                                                  . $edit_event_url
2854
-                                                  . '" title="'
2855
-                                                  . esc_attr__('Edit ', 'event_espresso')
2856
-                                                  . $this->_reg_event->name()
2857
-                                                  . '">'
2858
-                                                  . esc_html__('Edit Event', 'event_espresso')
2859
-                                                  . '</a>';
2860
-            $this->_template_args['event_name'] .= ' <span class="admin-page-header-edit-lnk not-bold">'
2861
-                                                   . $edit_event_lnk
2862
-                                                   . '</span>';
2863
-        }
2864
-        $this->_template_args['step_content'] = $this->_get_registration_step_content();
2865
-        if (defined('DOING_AJAX')) {
2866
-            $this->_return_json();
2867
-        }
2868
-        // grab header
2869
-        $template_path                              =
2870
-            REG_TEMPLATE_PATH . 'reg_admin_register_new_attendee.template.php';
2871
-        $this->_template_args['admin_page_content'] = EEH_Template::display_template($template_path,
2872
-            $this->_template_args, true);
2873
-        //$this->_set_publish_post_box_vars( NULL, FALSE, FALSE, NULL, FALSE );
2874
-        // the details template wrapper
2875
-        $this->display_admin_page_with_sidebar();
2876
-    }
2877
-
2878
-
2879
-    /**
2880
-     * This returns the content for a registration step
2881
-     *
2882
-     * @access protected
2883
-     * @return string html
2884
-     * @throws DomainException
2885
-     * @throws EE_Error
2886
-     * @throws InvalidArgumentException
2887
-     * @throws InvalidDataTypeException
2888
-     * @throws InvalidInterfaceException
2889
-     */
2890
-    protected function _get_registration_step_content()
2891
-    {
2892
-        if (isset($_COOKIE['ee_registration_added']) && $_COOKIE['ee_registration_added']) {
2893
-            $warning_msg = sprintf(
2894
-                esc_html__(
2895
-                    '%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',
2896
-                    'event_espresso'
2897
-                ),
2898
-                '<br />',
2899
-                '<h3 class="important-notice">',
2900
-                '</h3>',
2901
-                '<div class="float-right">',
2902
-                '<span id="redirect_timer" class="important-notice">30</span>',
2903
-                '</div>',
2904
-                '<b>',
2905
-                '</b>'
2906
-            );
2907
-            return '
2387
+	}
2388
+
2389
+
2390
+	/**
2391
+	 * Updates the registration's custom questions according to the form info, if the form is submitted.
2392
+	 * If it's not a post, the "view_registrations" route will be called next on the SAME request
2393
+	 * to display the page
2394
+	 *
2395
+	 * @access protected
2396
+	 * @return void
2397
+	 * @throws EE_Error
2398
+	 */
2399
+	protected function _update_attendee_registration_form()
2400
+	{
2401
+		do_action('AHEE__Registrations_Admin_Page___update_attendee_registration_form__start', $this);
2402
+		if ($_SERVER['REQUEST_METHOD'] == 'POST') {
2403
+			$REG_ID  = isset($this->_req_data['_REG_ID']) ? absint($this->_req_data['_REG_ID']) : false;
2404
+			$success = $this->_save_reg_custom_questions_form($REG_ID);
2405
+			if ($success) {
2406
+				$what  = esc_html__('Registration Form', 'event_espresso');
2407
+				$route = $REG_ID ? array('action' => 'view_registration', '_REG_ID' => $REG_ID)
2408
+					: array('action' => 'default');
2409
+				$this->_redirect_after_action($success, $what, esc_html__('updated', 'event_espresso'), $route);
2410
+			}
2411
+		}
2412
+	}
2413
+
2414
+
2415
+	/**
2416
+	 * Gets the form for saving registrations custom questions (if done
2417
+	 * previously retrieves the cached form object, which may have validation errors in it)
2418
+	 *
2419
+	 * @param int $REG_ID
2420
+	 * @return EE_Registration_Custom_Questions_Form
2421
+	 * @throws EE_Error
2422
+	 * @throws InvalidArgumentException
2423
+	 * @throws InvalidDataTypeException
2424
+	 * @throws InvalidInterfaceException
2425
+	 */
2426
+	protected function _get_reg_custom_questions_form($REG_ID)
2427
+	{
2428
+		if ( ! $this->_reg_custom_questions_form) {
2429
+			require_once(REG_ADMIN . 'form_sections' . DS . 'EE_Registration_Custom_Questions_Form.form.php');
2430
+			$this->_reg_custom_questions_form = new EE_Registration_Custom_Questions_Form(
2431
+				EEM_Registration::instance()->get_one_by_ID($REG_ID)
2432
+			);
2433
+			$this->_reg_custom_questions_form->_construct_finalize(null, null);
2434
+		}
2435
+		return $this->_reg_custom_questions_form;
2436
+	}
2437
+
2438
+
2439
+	/**
2440
+	 * Saves
2441
+	 *
2442
+	 * @access private
2443
+	 * @param bool $REG_ID
2444
+	 * @return bool
2445
+	 * @throws EE_Error
2446
+	 * @throws InvalidArgumentException
2447
+	 * @throws InvalidDataTypeException
2448
+	 * @throws InvalidInterfaceException
2449
+	 */
2450
+	private function _save_reg_custom_questions_form($REG_ID = false)
2451
+	{
2452
+		if ( ! $REG_ID) {
2453
+			EE_Error::add_error(
2454
+				esc_html__(
2455
+					'An error occurred. No registration ID was received.', 'event_espresso'),
2456
+				__FILE__, __FUNCTION__, __LINE__
2457
+			);
2458
+		}
2459
+		$form = $this->_get_reg_custom_questions_form($REG_ID);
2460
+		$form->receive_form_submission($this->_req_data);
2461
+		$success = false;
2462
+		if ($form->is_valid()) {
2463
+			foreach ($form->subforms() as $question_group_id => $question_group_form) {
2464
+				foreach ($question_group_form->inputs() as $question_id => $input) {
2465
+					$where_conditions    = array(
2466
+						'QST_ID' => $question_id,
2467
+						'REG_ID' => $REG_ID,
2468
+					);
2469
+					$possibly_new_values = array(
2470
+						'ANS_value' => $input->normalized_value(),
2471
+					);
2472
+					$answer              = EEM_Answer::instance()->get_one(array($where_conditions));
2473
+					if ($answer instanceof EE_Answer) {
2474
+						$success = $answer->save($possibly_new_values);
2475
+					} else {
2476
+						//insert it then
2477
+						$cols_n_vals = array_merge($where_conditions, $possibly_new_values);
2478
+						$answer      = EE_Answer::new_instance($cols_n_vals);
2479
+						$success     = $answer->save();
2480
+					}
2481
+				}
2482
+			}
2483
+		} else {
2484
+			EE_Error::add_error($form->get_validation_error_string(), __FILE__, __FUNCTION__, __LINE__);
2485
+		}
2486
+		return $success;
2487
+	}
2488
+
2489
+
2490
+	/**
2491
+	 *        generates HTML for the Registration main meta box
2492
+	 *
2493
+	 * @access public
2494
+	 * @return void
2495
+	 * @throws DomainException
2496
+	 * @throws EE_Error
2497
+	 * @throws InvalidArgumentException
2498
+	 * @throws InvalidDataTypeException
2499
+	 * @throws InvalidInterfaceException
2500
+	 */
2501
+	public function _reg_attendees_meta_box()
2502
+	{
2503
+		$REG = EEM_Registration::instance();
2504
+		//get all other registrations on this transaction, and cache
2505
+		//the attendees for them so we don't have to run another query using force_join
2506
+		$registrations                           = $REG->get_all(array(
2507
+			array(
2508
+				'TXN_ID' => $this->_registration->transaction_ID(),
2509
+				'REG_ID' => array('!=', $this->_registration->ID()),
2510
+			),
2511
+			'force_join' => array('Attendee'),
2512
+		));
2513
+		$this->_template_args['attendees']       = array();
2514
+		$this->_template_args['attendee_notice'] = '';
2515
+		if (empty($registrations)
2516
+			|| (is_array($registrations)
2517
+				&& ! EEH_Array::get_one_item_from_array($registrations))
2518
+		) {
2519
+			EE_Error::add_error(
2520
+				esc_html__(
2521
+					'There are no records attached to this registration. Something may have gone wrong with the registration',
2522
+					'event_espresso'
2523
+				), __FILE__, __FUNCTION__, __LINE__
2524
+			);
2525
+			$this->_template_args['attendee_notice'] = EE_Error::get_notices();
2526
+		} else {
2527
+			$att_nmbr = 1;
2528
+			foreach ($registrations as $registration) {
2529
+				/* @var $registration EE_Registration */
2530
+				$attendee                                                    = $registration->attendee()
2531
+					? $registration->attendee()
2532
+					: EEM_Attendee::instance()
2533
+								  ->create_default_object();
2534
+				$this->_template_args['attendees'][$att_nmbr]['STS_ID']      = $registration->status_ID();
2535
+				$this->_template_args['attendees'][$att_nmbr]['fname']       = $attendee->fname();
2536
+				$this->_template_args['attendees'][$att_nmbr]['lname']       = $attendee->lname();
2537
+				$this->_template_args['attendees'][$att_nmbr]['email']       = $attendee->email();
2538
+				$this->_template_args['attendees'][$att_nmbr]['final_price'] = $registration->final_price();
2539
+				$this->_template_args['attendees'][$att_nmbr]['address']     = implode(
2540
+					', ',
2541
+					$attendee->full_address_as_array()
2542
+				);
2543
+				$this->_template_args['attendees'][$att_nmbr]['att_link']    = self::add_query_args_and_nonce(
2544
+					array(
2545
+						'action' => 'edit_attendee',
2546
+						'post'   => $attendee->ID(),
2547
+					),
2548
+					REG_ADMIN_URL
2549
+				);
2550
+				$this->_template_args['attendees'][$att_nmbr]['event_name']  = $registration->event_obj()->name();
2551
+				$att_nmbr++;
2552
+			}
2553
+			$this->_template_args['currency_sign'] = EE_Registry::instance()->CFG->currency->sign;
2554
+		}
2555
+		$template_path = REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_attendees.template.php';
2556
+		echo EEH_Template::display_template($template_path, $this->_template_args, true);
2557
+	}
2558
+
2559
+
2560
+	/**
2561
+	 *        generates HTML for the Edit Registration side meta box
2562
+	 *
2563
+	 * @access public
2564
+	 * @return void
2565
+	 * @throws DomainException
2566
+	 * @throws EE_Error
2567
+	 * @throws InvalidArgumentException
2568
+	 * @throws InvalidDataTypeException
2569
+	 * @throws InvalidInterfaceException
2570
+	 */
2571
+	public function _reg_registrant_side_meta_box()
2572
+	{
2573
+		/*@var $attendee EE_Attendee */
2574
+		$att_check = $this->_registration->attendee();
2575
+		$attendee  = $att_check instanceof EE_Attendee ? $att_check : EEM_Attendee::instance()->create_default_object();
2576
+		//now let's determine if this is not the primary registration.  If it isn't then we set the
2577
+		//primary_registration object for reference BUT ONLY if the Attendee object loaded is not the same as the
2578
+		//primary registration object (that way we know if we need to show create button or not)
2579
+		if ( ! $this->_registration->is_primary_registrant()) {
2580
+			$primary_registration = $this->_registration->get_primary_registration();
2581
+			$primary_attendee     = $primary_registration instanceof EE_Registration ? $primary_registration->attendee()
2582
+				: null;
2583
+			if ( ! $primary_attendee instanceof EE_Attendee || $attendee->ID() !== $primary_attendee->ID()) {
2584
+				//in here?  This means the displayed registration is not the primary registrant but ALREADY HAS its own
2585
+				//custom attendee object so let's not worry about the primary reg.
2586
+				$primary_registration = null;
2587
+			}
2588
+		} else {
2589
+			$primary_registration = null;
2590
+		}
2591
+		$this->_template_args['ATT_ID']            = $attendee->ID();
2592
+		$this->_template_args['fname']             = $attendee->fname();
2593
+		$this->_template_args['lname']             = $attendee->lname();
2594
+		$this->_template_args['email']             = $attendee->email();
2595
+		$this->_template_args['phone']             = $attendee->phone();
2596
+		$this->_template_args['formatted_address'] = EEH_Address::format($attendee);
2597
+		//edit link
2598
+		$this->_template_args['att_edit_link']  = EE_Admin_Page::add_query_args_and_nonce(array(
2599
+			'action' => 'edit_attendee',
2600
+			'post'   => $attendee->ID(),
2601
+		), REG_ADMIN_URL);
2602
+		$this->_template_args['att_edit_label'] = esc_html__('View/Edit Contact', 'event_espresso');
2603
+		//create link
2604
+		$this->_template_args['create_link']  = $primary_registration instanceof EE_Registration
2605
+			? EE_Admin_Page::add_query_args_and_nonce(array(
2606
+				'action'  => 'duplicate_attendee',
2607
+				'_REG_ID' => $this->_registration->ID(),
2608
+			), REG_ADMIN_URL) : '';
2609
+		$this->_template_args['create_label'] = esc_html__('Create Contact', 'event_espresso');
2610
+		$this->_template_args['att_check']    = $att_check;
2611
+		$template_path                        = REG_TEMPLATE_PATH . 'reg_admin_details_side_meta_box_registrant.template.php';
2612
+		echo EEH_Template::display_template($template_path, $this->_template_args, true);
2613
+	}
2614
+
2615
+
2616
+	/**
2617
+	 * trash or restore registrations
2618
+	 *
2619
+	 * @param  boolean $trash whether to archive or restore
2620
+	 * @return void
2621
+	 * @throws EE_Error
2622
+	 * @throws InvalidArgumentException
2623
+	 * @throws InvalidDataTypeException
2624
+	 * @throws InvalidInterfaceException
2625
+	 * @throws RuntimeException
2626
+	 * @access protected
2627
+	 */
2628
+	protected function _trash_or_restore_registrations($trash = true)
2629
+	{
2630
+		//if empty _REG_ID then get out because there's nothing to do
2631
+		if (empty($this->_req_data['_REG_ID'])) {
2632
+			EE_Error::add_error(
2633
+				sprintf(
2634
+					esc_html__(
2635
+						'In order to %1$s registrations you must select which ones you wish to %1$s by clicking the checkboxes.',
2636
+						'event_espresso'
2637
+					),
2638
+					$trash ? 'trash' : 'restore'
2639
+				),
2640
+				__FILE__, __LINE__, __FUNCTION__
2641
+			);
2642
+			$this->_redirect_after_action(false, '', '', array(), true);
2643
+		}
2644
+		$success = 0;
2645
+		$overwrite_msgs = false;
2646
+		//Checkboxes
2647
+		if ( ! is_array($this->_req_data['_REG_ID'])) {
2648
+			$this->_req_data['_REG_ID'] = array($this->_req_data['_REG_ID']);
2649
+		}
2650
+		$reg_count = count($this->_req_data['_REG_ID']);
2651
+		// cycle thru checkboxes
2652
+		foreach ($this->_req_data['_REG_ID'] as $REG_ID) {
2653
+			/** @var EE_Registration $REG */
2654
+			$REG = EEM_Registration::instance()->get_one_by_ID($REG_ID);
2655
+			$payments = $REG->registration_payments();
2656
+			if (! empty($payments)) {
2657
+				$name = $REG->attendee() instanceof EE_Attendee
2658
+					? $REG->attendee()->full_name()
2659
+					: esc_html__('Unknown Attendee', 'event_espresso');
2660
+				$overwrite_msgs = true;
2661
+				EE_Error::add_error(
2662
+					sprintf(
2663
+						esc_html__(
2664
+							'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.',
2665
+							'event_espresso'
2666
+						),
2667
+						$name
2668
+					),
2669
+					__FILE__, __FUNCTION__, __LINE__
2670
+				);
2671
+				//can't trash this registration because it has payments.
2672
+				continue;
2673
+			}
2674
+			$updated = $trash ? $REG->delete() : $REG->restore();
2675
+			if ($updated) {
2676
+				$success++;
2677
+			}
2678
+		}
2679
+		$this->_redirect_after_action(
2680
+			$success === $reg_count, // were ALL registrations affected?
2681
+			$success > 1
2682
+				? esc_html__('Registrations', 'event_espresso')
2683
+				: esc_html__('Registration', 'event_espresso'),
2684
+			$trash
2685
+				? esc_html__('moved to the trash', 'event_espresso')
2686
+				: esc_html__('restored', 'event_espresso'),
2687
+			array('action' => 'default'),
2688
+			$overwrite_msgs
2689
+		);
2690
+	}
2691
+
2692
+
2693
+	/**
2694
+	 * This is used to permanently delete registrations.  Note, this will handle not only deleting permanently the
2695
+	 * registration but also.
2696
+	 * 1. Removing relations to EE_Attendee
2697
+	 * 2. Deleting permanently the related transaction, but ONLY if all related registrations to the transaction are
2698
+	 * ALSO trashed.
2699
+	 * 3. Deleting permanently any related Line items but only if the above conditions are met.
2700
+	 * 4. Removing relationships between all tickets and the related registrations
2701
+	 * 5. Deleting permanently any related Answers (and the answers for other related registrations that were deleted.)
2702
+	 * 6. Deleting permanently any related Checkins.
2703
+	 *
2704
+	 * @return void
2705
+	 * @throws EE_Error
2706
+	 * @throws InvalidArgumentException
2707
+	 * @throws InvalidDataTypeException
2708
+	 * @throws InvalidInterfaceException
2709
+	 */
2710
+	protected function _delete_registrations()
2711
+	{
2712
+		$REG_MDL = EEM_Registration::instance();
2713
+		$success = 1;
2714
+		//Checkboxes
2715
+		if ( ! empty($this->_req_data['_REG_ID']) && is_array($this->_req_data['_REG_ID'])) {
2716
+			// if array has more than one element than success message should be plural
2717
+			$success = count($this->_req_data['_REG_ID']) > 1 ? 2 : 1;
2718
+			// cycle thru checkboxes
2719
+			while (list($ind, $REG_ID) = each($this->_req_data['_REG_ID'])) {
2720
+				$REG = $REG_MDL->get_one_by_ID($REG_ID);
2721
+				if ( ! $REG instanceof EE_Registration) {
2722
+					continue;
2723
+				}
2724
+				$deleted = $this->_delete_registration($REG);
2725
+				if ( ! $deleted) {
2726
+					$success = 0;
2727
+				}
2728
+			}
2729
+		} else {
2730
+			// grab single id and delete
2731
+			$REG_ID  = $this->_req_data['_REG_ID'];
2732
+			$REG     = $REG_MDL->get_one_by_ID($REG_ID);
2733
+			$deleted = $this->_delete_registration($REG);
2734
+			if ( ! $deleted) {
2735
+				$success = 0;
2736
+			}
2737
+		}
2738
+		$what        = $success > 1
2739
+			? esc_html__('Registrations', 'event_espresso')
2740
+			: esc_html__('Registration', 'event_espresso');
2741
+		$action_desc = esc_html__('permanently deleted.', 'event_espresso');
2742
+		$this->_redirect_after_action(
2743
+			$success,
2744
+			$what,
2745
+			$action_desc,
2746
+			array('action' => 'default'),
2747
+			true
2748
+		);
2749
+	}
2750
+
2751
+
2752
+	/**
2753
+	 * handles the permanent deletion of a registration.  See comments with _delete_registrations() for details on what
2754
+	 * models get affected.
2755
+	 *
2756
+	 * @param  EE_Registration $REG registration to be deleted permenantly
2757
+	 * @return bool true = successful deletion, false = fail.
2758
+	 * @throws EE_Error
2759
+	 */
2760
+	protected function _delete_registration(EE_Registration $REG)
2761
+	{
2762
+		//first we start with the transaction... ultimately, we WILL not delete permanently if there are any related
2763
+		//registrations on the transaction that are NOT trashed.
2764
+		$TXN         = $REG->get_first_related('Transaction');
2765
+		$REGS        = $TXN->get_many_related('Registration');
2766
+		$all_trashed = true;
2767
+		foreach ($REGS as $registration) {
2768
+			if ( ! $registration->get('REG_deleted')) {
2769
+				$all_trashed = false;
2770
+			}
2771
+		}
2772
+		if ( ! $all_trashed) {
2773
+			EE_Error::add_error(
2774
+				esc_html__(
2775
+					'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.',
2776
+					'event_espresso'
2777
+				),
2778
+				__FILE__, __FUNCTION__, __LINE__
2779
+			);
2780
+			return false;
2781
+		}
2782
+		//k made it here so that means we can delete all the related transactions and their answers (but let's do them
2783
+		//separately from THIS one).
2784
+		foreach ($REGS as $registration) {
2785
+			//delete related answers
2786
+			$registration->delete_related_permanently('Answer');
2787
+			//remove relationship to EE_Attendee (but we ALWAYS leave the contact record intact)
2788
+			$attendee = $registration->get_first_related('Attendee');
2789
+			if ($attendee instanceof EE_Attendee) {
2790
+				$registration->_remove_relation_to($attendee, 'Attendee');
2791
+			}
2792
+			//now remove relationships to tickets on this registration.
2793
+			$registration->_remove_relations('Ticket');
2794
+			//now delete permanently the checkins related to this registration.
2795
+			$registration->delete_related_permanently('Checkin');
2796
+			if ($registration->ID() === $REG->ID()) {
2797
+				continue;
2798
+			} //we don't want to delete permanently the existing registration just yet.
2799
+			//remove relation to transaction for these registrations if NOT the existing registrations
2800
+			$registration->_remove_relations('Transaction');
2801
+			//delete permanently any related messages.
2802
+			$registration->delete_related_permanently('Message');
2803
+			//now delete this registration permanently
2804
+			$registration->delete_permanently();
2805
+		}
2806
+		//now all related registrations on the transaction are handled.  So let's just handle this registration itself
2807
+		// (the transaction and line items should be all that's left).
2808
+		// delete the line items related to the transaction for this registration.
2809
+		$TXN->delete_related_permanently('Line_Item');
2810
+		//we need to remove all the relationships on the transaction
2811
+		$TXN->delete_related_permanently('Payment');
2812
+		$TXN->delete_related_permanently('Extra_Meta');
2813
+		$TXN->delete_related_permanently('Message');
2814
+		//now we can delete this REG permanently (and the transaction of course)
2815
+		$REG->delete_related_permanently('Transaction');
2816
+		return $REG->delete_permanently();
2817
+	}
2818
+
2819
+
2820
+	/**
2821
+	 *    generates HTML for the Register New Attendee Admin page
2822
+	 *
2823
+	 * @access private
2824
+	 * @throws DomainException
2825
+	 * @throws EE_Error
2826
+	 */
2827
+	public function new_registration()
2828
+	{
2829
+		if ( ! $this->_set_reg_event()) {
2830
+			throw new EE_Error(
2831
+				esc_html__(
2832
+					'Unable to continue with registering because there is no Event ID in the request',
2833
+					'event_espresso'
2834
+				)
2835
+			);
2836
+		}
2837
+		EE_Registry::instance()->REQ->set_espresso_page(true);
2838
+		// gotta start with a clean slate if we're not coming here via ajax
2839
+		if ( ! defined('DOING_AJAX')
2840
+			 && ( ! isset($this->_req_data['processing_registration']) || isset($this->_req_data['step_error']))
2841
+		) {
2842
+			EE_Registry::instance()->SSN->clear_session(__CLASS__, __FUNCTION__);
2843
+		}
2844
+		$this->_template_args['event_name'] = '';
2845
+		// event name
2846
+		if ($this->_reg_event) {
2847
+			$this->_template_args['event_name'] = $this->_reg_event->name();
2848
+			$edit_event_url                     = self::add_query_args_and_nonce(array(
2849
+				'action' => 'edit',
2850
+				'post'   => $this->_reg_event->ID(),
2851
+			), EVENTS_ADMIN_URL);
2852
+			$edit_event_lnk                     = '<a href="'
2853
+												  . $edit_event_url
2854
+												  . '" title="'
2855
+												  . esc_attr__('Edit ', 'event_espresso')
2856
+												  . $this->_reg_event->name()
2857
+												  . '">'
2858
+												  . esc_html__('Edit Event', 'event_espresso')
2859
+												  . '</a>';
2860
+			$this->_template_args['event_name'] .= ' <span class="admin-page-header-edit-lnk not-bold">'
2861
+												   . $edit_event_lnk
2862
+												   . '</span>';
2863
+		}
2864
+		$this->_template_args['step_content'] = $this->_get_registration_step_content();
2865
+		if (defined('DOING_AJAX')) {
2866
+			$this->_return_json();
2867
+		}
2868
+		// grab header
2869
+		$template_path                              =
2870
+			REG_TEMPLATE_PATH . 'reg_admin_register_new_attendee.template.php';
2871
+		$this->_template_args['admin_page_content'] = EEH_Template::display_template($template_path,
2872
+			$this->_template_args, true);
2873
+		//$this->_set_publish_post_box_vars( NULL, FALSE, FALSE, NULL, FALSE );
2874
+		// the details template wrapper
2875
+		$this->display_admin_page_with_sidebar();
2876
+	}
2877
+
2878
+
2879
+	/**
2880
+	 * This returns the content for a registration step
2881
+	 *
2882
+	 * @access protected
2883
+	 * @return string html
2884
+	 * @throws DomainException
2885
+	 * @throws EE_Error
2886
+	 * @throws InvalidArgumentException
2887
+	 * @throws InvalidDataTypeException
2888
+	 * @throws InvalidInterfaceException
2889
+	 */
2890
+	protected function _get_registration_step_content()
2891
+	{
2892
+		if (isset($_COOKIE['ee_registration_added']) && $_COOKIE['ee_registration_added']) {
2893
+			$warning_msg = sprintf(
2894
+				esc_html__(
2895
+					'%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',
2896
+					'event_espresso'
2897
+				),
2898
+				'<br />',
2899
+				'<h3 class="important-notice">',
2900
+				'</h3>',
2901
+				'<div class="float-right">',
2902
+				'<span id="redirect_timer" class="important-notice">30</span>',
2903
+				'</div>',
2904
+				'<b>',
2905
+				'</b>'
2906
+			);
2907
+			return '
2908 2908
 	<div id="ee-add-reg-back-button-dv"><p>' . $warning_msg . '</p></div>
2909 2909
 	<script >
2910 2910
 		// WHOAH !!! it appears that someone is using the back button from the Transaction admin page
@@ -2917,847 +2917,847 @@  discard block
 block discarded – undo
2917 2917
 	        }
2918 2918
 	    }, 800 );
2919 2919
 	</script >';
2920
-        }
2921
-        $template_args = array(
2922
-            'title'                    => '',
2923
-            'content'                  => '',
2924
-            'step_button_text'         => '',
2925
-            'show_notification_toggle' => false,
2926
-        );
2927
-        //to indicate we're processing a new registration
2928
-        $hidden_fields = array(
2929
-            'processing_registration' => array(
2930
-                'type'  => 'hidden',
2931
-                'value' => 0,
2932
-            ),
2933
-            'event_id'                => array(
2934
-                'type'  => 'hidden',
2935
-                'value' => $this->_reg_event->ID(),
2936
-            ),
2937
-        );
2938
-        //if the cart is empty then we know we're at step one so we'll display ticket selector
2939
-        $cart = EE_Registry::instance()->SSN->cart();
2940
-        $step = ! $cart instanceof EE_Cart ? 'ticket' : 'questions';
2941
-        switch ($step) {
2942
-            case 'ticket' :
2943
-                $hidden_fields['processing_registration']['value'] = 1;
2944
-                $template_args['title']                            = esc_html__(
2945
-                    'Step One: Select the Ticket for this registration',
2946
-                    'event_espresso'
2947
-                );
2948
-                $template_args['content']                          =
2949
-                    EED_Ticket_Selector::instance()->display_ticket_selector($this->_reg_event);
2950
-                $template_args['step_button_text']                 = esc_html__(
2951
-                    'Add Tickets and Continue to Registrant Details',
2952
-                    'event_espresso'
2953
-                );
2954
-                $template_args['show_notification_toggle']         = false;
2955
-                break;
2956
-            case 'questions' :
2957
-                $hidden_fields['processing_registration']['value'] = 2;
2958
-                $template_args['title']                            = esc_html__(
2959
-                    'Step Two: Add Registrant Details for this Registration',
2960
-                    'event_espresso'
2961
-                );
2962
-                //in theory we should be able to run EED_SPCO at this point because the cart should have been setup
2963
-                // properly by the first process_reg_step run.
2964
-                $template_args['content']                  =
2965
-                    EED_Single_Page_Checkout::registration_checkout_for_admin();
2966
-                $template_args['step_button_text']         = esc_html__(
2967
-                    'Save Registration and Continue to Details',
2968
-                    'event_espresso'
2969
-                );
2970
-                $template_args['show_notification_toggle'] = true;
2971
-                break;
2972
-        }
2973
-        //we come back to the process_registration_step route.
2974
-        $this->_set_add_edit_form_tags('process_reg_step', $hidden_fields);
2975
-        return EEH_Template::display_template(
2976
-            REG_TEMPLATE_PATH . 'reg_admin_register_new_attendee_step_content.template.php',
2977
-            $template_args,
2978
-            true
2979
-        );
2980
-    }
2981
-
2982
-
2983
-    /**
2984
-     *        set_reg_event
2985
-     *
2986
-     * @access private
2987
-     * @return bool
2988
-     * @throws EE_Error
2989
-     * @throws InvalidArgumentException
2990
-     * @throws InvalidDataTypeException
2991
-     * @throws InvalidInterfaceException
2992
-     */
2993
-    private function _set_reg_event()
2994
-    {
2995
-        if (is_object($this->_reg_event)) {
2996
-            return true;
2997
-        }
2998
-        $EVT_ID = (! empty($this->_req_data['event_id'])) ? absint($this->_req_data['event_id']) : false;
2999
-        if ( ! $EVT_ID) {
3000
-            return false;
3001
-        }
3002
-        $this->_reg_event = EEM_Event::instance()->get_one_by_ID($EVT_ID);
3003
-        return true;
3004
-    }
3005
-
3006
-
3007
-    /**
3008
-     * process_reg_step
3009
-     *
3010
-     * @access        public
3011
-     * @return string
3012
-     * @throws DomainException
3013
-     * @throws EE_Error
3014
-     * @throws InvalidArgumentException
3015
-     * @throws InvalidDataTypeException
3016
-     * @throws InvalidInterfaceException
3017
-     * @throws ReflectionException
3018
-     * @throws RuntimeException
3019
-     */
3020
-    public function process_reg_step()
3021
-    {
3022
-        EE_System::do_not_cache();
3023
-        $this->_set_reg_event();
3024
-        EE_Registry::instance()->REQ->set_espresso_page(true);
3025
-        EE_Registry::instance()->REQ->set('uts', time());
3026
-        //what step are we on?
3027
-        $cart = EE_Registry::instance()->SSN->cart();
3028
-        $step = ! $cart instanceof EE_Cart ? 'ticket' : 'questions';
3029
-        //if doing ajax then we need to verify the nonce
3030
-        if (defined('DOING_AJAX')) {
3031
-            $nonce = isset($this->_req_data[$this->_req_nonce])
3032
-                ? sanitize_text_field($this->_req_data[$this->_req_nonce]) : '';
3033
-            $this->_verify_nonce($nonce, $this->_req_nonce);
3034
-        }
3035
-        switch ($step) {
3036
-            case 'ticket' :
3037
-                //process ticket selection
3038
-                $success = EED_Ticket_Selector::instance()->process_ticket_selections();
3039
-                if ($success) {
3040
-                    EE_Error::add_success(
3041
-                        esc_html__(
3042
-                            'Tickets Selected. Now complete the registration.',
3043
-                            'event_espresso'
3044
-                        )
3045
-                    );
3046
-                } else {
3047
-                    $query_args['step_error'] = $this->_req_data['step_error'] = true;
3048
-                }
3049
-                if (defined('DOING_AJAX')) {
3050
-                    $this->new_registration(); //display next step
3051
-                } else {
3052
-                    $query_args = array(
3053
-                        'action'                  => 'new_registration',
3054
-                        'processing_registration' => 1,
3055
-                        'event_id'                => $this->_reg_event->ID(),
3056
-                        'uts'                     => time(),
3057
-                    );
3058
-                    $this->_redirect_after_action(
3059
-                        false,
3060
-                        '',
3061
-                        '',
3062
-                        $query_args,
3063
-                        true
3064
-                    );
3065
-                }
3066
-                break;
3067
-            case 'questions' :
3068
-                if (! isset(
3069
-                    $this->_req_data['txn_reg_status_change'],
3070
-                    $this->_req_data['txn_reg_status_change']['send_notifications'])
3071
-                ) {
3072
-                    add_filter('FHEE__EED_Messages___maybe_registration__deliver_notifications', '__return_false', 15);
3073
-                }
3074
-                //process registration
3075
-                $transaction = EED_Single_Page_Checkout::instance()->process_registration_from_admin();
3076
-                if ($cart instanceof EE_Cart) {
3077
-                    $grand_total = $cart->get_cart_grand_total();
3078
-                    if ($grand_total instanceof EE_Line_Item) {
3079
-                        $grand_total->save_this_and_descendants_to_txn();
3080
-                    }
3081
-                }
3082
-                if ( ! $transaction instanceof EE_Transaction) {
3083
-                    $query_args = array(
3084
-                        'action'                  => 'new_registration',
3085
-                        'processing_registration' => 2,
3086
-                        'event_id'                => $this->_reg_event->ID(),
3087
-                        'uts'                     => time(),
3088
-                    );
3089
-                    if (defined('DOING_AJAX')) {
3090
-                        //display registration form again because there are errors (maybe validation?)
3091
-                        $this->new_registration();
3092
-                        return;
3093
-                    } else {
3094
-                        $this->_redirect_after_action(
3095
-                            false,
3096
-                            '',
3097
-                            '',
3098
-                            $query_args,
3099
-                            true
3100
-                        );
3101
-                        return;
3102
-                    }
3103
-                }
3104
-                // maybe update status, and make sure to save transaction if not done already
3105
-                if ( ! $transaction->update_status_based_on_total_paid()) {
3106
-                    $transaction->save();
3107
-                }
3108
-                EE_Registry::instance()->SSN->clear_session(__CLASS__, __FUNCTION__);
3109
-                $this->_req_data = array();
3110
-                $query_args      = array(
3111
-                    'action'        => 'redirect_to_txn',
3112
-                    'TXN_ID'        => $transaction->ID(),
3113
-                    'EVT_ID'        => $this->_reg_event->ID(),
3114
-                    'event_name'    => urlencode($this->_reg_event->name()),
3115
-                    'redirect_from' => 'new_registration',
3116
-                );
3117
-                $this->_redirect_after_action(false, '', '', $query_args, true);
3118
-                break;
3119
-        }
3120
-        //what are you looking here for?  Should be nothing to do at this point.
3121
-    }
3122
-
3123
-
3124
-    /**
3125
-     * redirect_to_txn
3126
-     *
3127
-     * @access public
3128
-     * @return void
3129
-     * @throws EE_Error
3130
-     * @throws InvalidArgumentException
3131
-     * @throws InvalidDataTypeException
3132
-     * @throws InvalidInterfaceException
3133
-     */
3134
-    public function redirect_to_txn()
3135
-    {
3136
-        EE_System::do_not_cache();
3137
-        EE_Registry::instance()->SSN->clear_session(__CLASS__, __FUNCTION__);
3138
-        $query_args = array(
3139
-            'action' => 'view_transaction',
3140
-            'TXN_ID' => isset($this->_req_data['TXN_ID']) ? absint($this->_req_data['TXN_ID']) : 0,
3141
-            'page'   => 'espresso_transactions',
3142
-        );
3143
-        if (isset($this->_req_data['EVT_ID'], $this->_req_data['redirect_from'])) {
3144
-            $query_args['EVT_ID']        = $this->_req_data['EVT_ID'];
3145
-            $query_args['event_name']    = urlencode($this->_req_data['event_name']);
3146
-            $query_args['redirect_from'] = $this->_req_data['redirect_from'];
3147
-        }
3148
-        EE_Error::add_success(
3149
-            esc_html__(
3150
-                'Registration Created.  Please review the transaction and add any payments as necessary',
3151
-                'event_espresso'
3152
-            )
3153
-        );
3154
-        $this->_redirect_after_action(false, '', '', $query_args, true);
3155
-    }
3156
-
3157
-
3158
-    /**
3159
-     *        generates HTML for the Attendee Contact List
3160
-     *
3161
-     * @access protected
3162
-     * @return void
3163
-     */
3164
-    protected function _attendee_contact_list_table()
3165
-    {
3166
-        do_action('AHEE_log', __FILE__, __FUNCTION__, '');
3167
-        $this->_search_btn_label = esc_html__('Contacts', 'event_espresso');
3168
-        $this->display_admin_list_table_page_with_no_sidebar();
3169
-    }
3170
-
3171
-
3172
-    /**
3173
-     *        get_attendees
3174
-     *
3175
-     * @param      $per_page
3176
-     * @param bool $count whether to return count or data.
3177
-     * @param bool $trash
3178
-     * @return array
3179
-     * @throws EE_Error
3180
-     * @throws InvalidArgumentException
3181
-     * @throws InvalidDataTypeException
3182
-     * @throws InvalidInterfaceException
3183
-     * @access public
3184
-     */
3185
-    public function get_attendees($per_page, $count = false, $trash = false)
3186
-    {
3187
-        do_action('AHEE_log', __FILE__, __FUNCTION__, '');
3188
-        require_once(REG_ADMIN . 'EE_Attendee_Contact_List_Table.class.php');
3189
-        $ATT_MDL                    = EEM_Attendee::instance();
3190
-        $this->_req_data['orderby'] = ! empty($this->_req_data['orderby']) ? $this->_req_data['orderby'] : '';
3191
-        switch ($this->_req_data['orderby']) {
3192
-            case 'ATT_ID':
3193
-                $orderby = 'ATT_ID';
3194
-                break;
3195
-            case 'ATT_fname':
3196
-                $orderby = 'ATT_fname';
3197
-                break;
3198
-            case 'ATT_email':
3199
-                $orderby = 'ATT_email';
3200
-                break;
3201
-            case 'ATT_city':
3202
-                $orderby = 'ATT_city';
3203
-                break;
3204
-            case 'STA_ID':
3205
-                $orderby = 'STA_ID';
3206
-                break;
3207
-            case 'CNT_ID':
3208
-                $orderby = 'CNT_ID';
3209
-                break;
3210
-            default:
3211
-                $orderby = 'ATT_lname';
3212
-        }
3213
-        $sort         = (isset($this->_req_data['order']) && ! empty($this->_req_data['order']))
3214
-            ? $this->_req_data['order']
3215
-            : 'ASC';
3216
-        $current_page = isset($this->_req_data['paged']) && ! empty($this->_req_data['paged'])
3217
-            ? $this->_req_data['paged']
3218
-            : 1;
3219
-        $per_page     = isset($per_page) && ! empty($per_page) ? $per_page : 10;
3220
-        $per_page     = isset($this->_req_data['perpage']) && ! empty($this->_req_data['perpage'])
3221
-            ? $this->_req_data['perpage']
3222
-            : $per_page;
3223
-        $_where       = array();
3224
-        if ( ! empty($this->_req_data['s'])) {
3225
-            $sstr         = '%' . $this->_req_data['s'] . '%';
3226
-            $_where['OR'] = array(
3227
-                'Registration.Event.EVT_name'       => array('LIKE', $sstr),
3228
-                'Registration.Event.EVT_desc'       => array('LIKE', $sstr),
3229
-                'Registration.Event.EVT_short_desc' => array('LIKE', $sstr),
3230
-                'ATT_fname'                         => array('LIKE', $sstr),
3231
-                'ATT_lname'                         => array('LIKE', $sstr),
3232
-                'ATT_short_bio'                     => array('LIKE', $sstr),
3233
-                'ATT_email'                         => array('LIKE', $sstr),
3234
-                'ATT_address'                       => array('LIKE', $sstr),
3235
-                'ATT_address2'                      => array('LIKE', $sstr),
3236
-                'ATT_city'                          => array('LIKE', $sstr),
3237
-                'Country.CNT_name'                  => array('LIKE', $sstr),
3238
-                'State.STA_name'                    => array('LIKE', $sstr),
3239
-                'ATT_phone'                         => array('LIKE', $sstr),
3240
-                'Registration.REG_final_price'      => array('LIKE', $sstr),
3241
-                'Registration.REG_code'             => array('LIKE', $sstr),
3242
-                'Registration.REG_count'            => array('LIKE', $sstr),
3243
-                'Registration.REG_group_size'       => array('LIKE', $sstr),
3244
-            );
3245
-        }
3246
-        $offset = ($current_page - 1) * $per_page;
3247
-        $limit  = $count ? null : array($offset, $per_page);
3248
-        if ($trash) {
3249
-            $_where['status'] = array('!=', 'publish');
3250
-            $all_attendees    = $count
3251
-                ? $ATT_MDL->count(array(
3252
-                    $_where,
3253
-                    'order_by' => array($orderby => $sort),
3254
-                    'limit'    => $limit,
3255
-                ), 'ATT_ID', true)
3256
-                : $ATT_MDL->get_all(array(
3257
-                    $_where,
3258
-                    'order_by' => array($orderby => $sort),
3259
-                    'limit'    => $limit,
3260
-                ));
3261
-        } else {
3262
-            $_where['status'] = array('IN', array('publish'));
3263
-            $all_attendees    = $count
3264
-                ? $ATT_MDL->count(array(
3265
-                    $_where,
3266
-                    'order_by' => array($orderby => $sort),
3267
-                    'limit'    => $limit,
3268
-                ), 'ATT_ID', true)
3269
-                : $ATT_MDL->get_all(array(
3270
-                    $_where,
3271
-                    'order_by' => array($orderby => $sort),
3272
-                    'limit'    => $limit,
3273
-                ));
3274
-        }
3275
-        return $all_attendees;
3276
-    }
3277
-
3278
-
3279
-    /**
3280
-     * This is just taking care of resending the registration confirmation
3281
-     *
3282
-     * @access protected
3283
-     * @return void
3284
-     */
3285
-    protected function _resend_registration()
3286
-    {
3287
-        $this->_process_resend_registration();
3288
-        $query_args = isset($this->_req_data['redirect_to'])
3289
-            ? array('action' => $this->_req_data['redirect_to'], '_REG_ID' => $this->_req_data['_REG_ID'])
3290
-            : array('action' => 'default');
3291
-        $this->_redirect_after_action(false, '', '', $query_args, true);
3292
-    }
3293
-
3294
-    /**
3295
-     * Creates a registration report, but accepts the name of a method to use for preparing the query parameters
3296
-     * to use when selecting registrations
3297
-     * @param string $method_name_for_getting_query_params the name of the method (on this class) to use for preparing
3298
-     *                                                     the query parameters from the request
3299
-     * @return void ends the request with a redirect or download
3300
-     */
3301
-    public function _registrations_report_base( $method_name_for_getting_query_params )
3302
-    {
3303
-        if (! defined('EE_USE_OLD_CSV_REPORT_CLASS')) {
3304
-            wp_redirect(EE_Admin_Page::add_query_args_and_nonce(
3305
-                array(
3306
-                    'page'        => 'espresso_batch',
3307
-                    'batch'       => 'file',
3308
-                    'EVT_ID'      => isset($this->_req_data['EVT_ID']) ? $this->_req_data['EVT_ID'] : null,
3309
-                    'filters'     => urlencode(
3310
-                        serialize(
3311
-                            call_user_func(
3312
-                                array( $this, $method_name_for_getting_query_params ),
3313
-                                EEH_Array::is_set(
3314
-                                    $this->_req_data,
3315
-                                    'filters',
3316
-                                    array()
3317
-                                )
3318
-                            )
3319
-                        )
3320
-                ),
3321
-                'use_filters' => EEH_Array::is_set($this->_req_data, 'use_filters', false),
3322
-                'job_handler' => urlencode('EventEspressoBatchRequest\JobHandlers\RegistrationsReport'),
3323
-                'return_url'  => urlencode($this->_req_data['return_url']),
3324
-            )));
3325
-        } else {
3326
-            $new_request_args = array(
3327
-                'export' => 'report',
3328
-                'action' => 'registrations_report_for_event',
3329
-                'EVT_ID' => isset($this->_req_data['EVT_ID']) ? $this->_req_data['EVT_ID'] : null,
3330
-            );
3331
-            $this->_req_data = array_merge($this->_req_data, $new_request_args);
3332
-            if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
3333
-                require_once(EE_CLASSES . 'EE_Export.class.php');
3334
-                $EE_Export = EE_Export::instance($this->_req_data);
3335
-                $EE_Export->export();
3336
-            }
3337
-        }
3338
-    }
3339
-
3340
-
3341
-
3342
-    /**
3343
-     * Creates a registration report using only query parameters in the request
3344
-     * @return void
3345
-     */
3346
-    public function _registrations_report()
3347
-    {
3348
-        $this->_registrations_report_base('_get_registration_query_parameters');
3349
-    }
3350
-
3351
-
3352
-    public function _contact_list_export()
3353
-    {
3354
-        if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
3355
-            require_once(EE_CLASSES . 'EE_Export.class.php');
3356
-            $EE_Export = EE_Export::instance($this->_req_data);
3357
-            $EE_Export->export_attendees();
3358
-        }
3359
-    }
3360
-
3361
-
3362
-    public function _contact_list_report()
3363
-    {
3364
-        if ( ! defined('EE_USE_OLD_CSV_REPORT_CLASS')) {
3365
-            wp_redirect(EE_Admin_Page::add_query_args_and_nonce(array(
3366
-                'page'        => 'espresso_batch',
3367
-                'batch'       => 'file',
3368
-                'job_handler' => urlencode('EventEspressoBatchRequest\JobHandlers\AttendeesReport'),
3369
-                'return_url'  => urlencode($this->_req_data['return_url']),
3370
-            )));
3371
-        } else {
3372
-            if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
3373
-                require_once(EE_CLASSES . 'EE_Export.class.php');
3374
-                $EE_Export = EE_Export::instance($this->_req_data);
3375
-                $EE_Export->report_attendees();
3376
-            }
3377
-        }
3378
-    }
3379
-
3380
-
3381
-
3382
-
3383
-
3384
-    /***************************************        ATTENDEE DETAILS        ***************************************/
3385
-    /**
3386
-     * This duplicates the attendee object for the given incoming registration id and attendee_id.
3387
-     *
3388
-     * @return void
3389
-     * @throws EE_Error
3390
-     * @throws InvalidArgumentException
3391
-     * @throws InvalidDataTypeException
3392
-     * @throws InvalidInterfaceException
3393
-     */
3394
-    protected function _duplicate_attendee()
3395
-    {
3396
-        $action = ! empty($this->_req_data['return']) ? $this->_req_data['return'] : 'default';
3397
-        //verify we have necessary info
3398
-        if (empty($this->_req_data['_REG_ID'])) {
3399
-            EE_Error::add_error(
3400
-                esc_html__(
3401
-                    'Unable to create the contact for the registration because the required parameters are not present (_REG_ID )',
3402
-                    'event_espresso'
3403
-                ), __FILE__, __LINE__, __FUNCTION__
3404
-            );
3405
-            $query_args = array('action' => $action);
3406
-            $this->_redirect_after_action('', '', '', $query_args, true);
3407
-        }
3408
-        //okay necessary deets present... let's dupe the incoming attendee and attach to incoming registration.
3409
-        $registration = EEM_Registration::instance()->get_one_by_ID($this->_req_data['_REG_ID']);
3410
-        $attendee     = $registration->attendee();
3411
-        //remove relation of existing attendee on registration
3412
-        $registration->_remove_relation_to($attendee, 'Attendee');
3413
-        //new attendee
3414
-        $new_attendee = clone $attendee;
3415
-        $new_attendee->set('ATT_ID', 0);
3416
-        $new_attendee->save();
3417
-        //add new attendee to reg
3418
-        $registration->_add_relation_to($new_attendee, 'Attendee');
3419
-        EE_Error::add_success(
3420
-            esc_html__(
3421
-                'New Contact record created.  Now make any edits you wish to make for this contact.',
3422
-                'event_espresso'
3423
-            )
3424
-        );
3425
-        //redirect to edit page for attendee
3426
-        $query_args = array('post' => $new_attendee->ID(), 'action' => 'edit_attendee');
3427
-        $this->_redirect_after_action('', '', '', $query_args, true);
3428
-    }
3429
-
3430
-
3431
-    /**
3432
-     * Callback invoked by parent EE_Admin_CPT class hooked in on `save_post` wp hook.
3433
-     * @param int      $post_id
3434
-     * @param WP_POST $post
3435
-     * @throws DomainException
3436
-     * @throws EE_Error
3437
-     * @throws InvalidArgumentException
3438
-     * @throws InvalidDataTypeException
3439
-     * @throws InvalidInterfaceException
3440
-     * @throws LogicException
3441
-     * @throws InvalidFormSubmissionException
3442
-     */
3443
-    protected function _insert_update_cpt_item($post_id, $post)
3444
-    {
3445
-        $success  = true;
3446
-        $attendee = $post instanceof WP_Post && $post->post_type === 'espresso_attendees'
3447
-            ? EEM_Attendee::instance()->get_one_by_ID($post_id)
3448
-            : null;
3449
-        //for attendee updates
3450
-        if ($attendee instanceof EE_Attendee) {
3451
-            //note we should only be UPDATING attendees at this point.
3452
-            $updated_fields = array(
3453
-                'ATT_fname'     => $this->_req_data['ATT_fname'],
3454
-                'ATT_lname'     => $this->_req_data['ATT_lname'],
3455
-                'ATT_full_name' => $this->_req_data['ATT_fname'] . ' ' . $this->_req_data['ATT_lname'],
3456
-                'ATT_address'   => isset($this->_req_data['ATT_address']) ? $this->_req_data['ATT_address'] : '',
3457
-                'ATT_address2'  => isset($this->_req_data['ATT_address2']) ? $this->_req_data['ATT_address2'] : '',
3458
-                'ATT_city'      => isset($this->_req_data['ATT_city']) ? $this->_req_data['ATT_city'] : '',
3459
-                'STA_ID'        => isset($this->_req_data['STA_ID']) ? $this->_req_data['STA_ID'] : '',
3460
-                'CNT_ISO'       => isset($this->_req_data['CNT_ISO']) ? $this->_req_data['CNT_ISO'] : '',
3461
-                'ATT_zip'       => isset($this->_req_data['ATT_zip']) ? $this->_req_data['ATT_zip'] : '',
3462
-            );
3463
-            foreach ($updated_fields as $field => $value) {
3464
-                $attendee->set($field, $value);
3465
-            }
3466
-
3467
-            //process contact details metabox form handler (which will also save the attendee)
3468
-            $contact_details_form = $this->getAttendeeContactDetailsMetaboxFormHandler($attendee);
3469
-            $success = $contact_details_form->process($this->_req_data);
3470
-
3471
-            $attendee_update_callbacks = apply_filters(
3472
-                'FHEE__Registrations_Admin_Page__insert_update_cpt_item__attendee_update',
3473
-                array()
3474
-            );
3475
-            foreach ($attendee_update_callbacks as $a_callback) {
3476
-                if (false === call_user_func_array($a_callback, array($attendee, $this->_req_data))) {
3477
-                    throw new EE_Error(
3478
-                        sprintf(
3479
-                            esc_html__(
3480
-                                '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.',
3481
-                                'event_espresso'
3482
-                            ),
3483
-                            $a_callback
3484
-                        )
3485
-                    );
3486
-                }
3487
-            }
3488
-        }
3489
-
3490
-        if ($success === false) {
3491
-            EE_Error::add_error(
3492
-                esc_html__(
3493
-                    'Something went wrong with updating the meta table data for the registration.',
3494
-                    'event_espresso'
3495
-                ),
3496
-                __FILE__, __FUNCTION__, __LINE__
3497
-            );
3498
-        }
3499
-    }
3500
-
3501
-
3502
-    public function trash_cpt_item($post_id)
3503
-    {
3504
-    }
3505
-
3506
-
3507
-    public function delete_cpt_item($post_id)
3508
-    {
3509
-    }
3510
-
3511
-
3512
-    public function restore_cpt_item($post_id)
3513
-    {
3514
-    }
3515
-
3516
-
3517
-    protected function _restore_cpt_item($post_id, $revision_id)
3518
-    {
3519
-    }
3520
-
3521
-
3522
-    public function attendee_editor_metaboxes()
3523
-    {
3524
-        $this->verify_cpt_object();
3525
-        remove_meta_box(
3526
-            'postexcerpt',
3527
-            esc_html__('Excerpt', 'event_espresso'),
3528
-            'post_excerpt_meta_box',
3529
-            $this->_cpt_routes[$this->_req_action],
3530
-            'normal',
3531
-            'core'
3532
-        );
3533
-        remove_meta_box('commentstatusdiv', $this->_cpt_routes[$this->_req_action], 'normal', 'core');
3534
-        if (post_type_supports('espresso_attendees', 'excerpt')) {
3535
-            add_meta_box(
3536
-                'postexcerpt',
3537
-                esc_html__('Short Biography', 'event_espresso'),
3538
-                'post_excerpt_meta_box',
3539
-                $this->_cpt_routes[$this->_req_action],
3540
-                'normal'
3541
-            );
3542
-        }
3543
-        if (post_type_supports('espresso_attendees', 'comments')) {
3544
-            add_meta_box(
3545
-                'commentsdiv',
3546
-                esc_html__('Notes on the Contact', 'event_espresso'),
3547
-                'post_comment_meta_box',
3548
-                $this->_cpt_routes[$this->_req_action],
3549
-                'normal',
3550
-                'core'
3551
-            );
3552
-        }
3553
-        add_meta_box(
3554
-            'attendee_contact_info',
3555
-            esc_html__('Contact Info', 'event_espresso'),
3556
-            array($this, 'attendee_contact_info'),
3557
-            $this->_cpt_routes[$this->_req_action],
3558
-            'side',
3559
-            'core'
3560
-        );
3561
-        add_meta_box(
3562
-            'attendee_details_address',
3563
-            esc_html__('Address Details', 'event_espresso'),
3564
-            array($this, 'attendee_address_details'),
3565
-            $this->_cpt_routes[$this->_req_action],
3566
-            'normal',
3567
-            'core'
3568
-        );
3569
-        add_meta_box(
3570
-            'attendee_registrations',
3571
-            esc_html__('Registrations for this Contact', 'event_espresso'),
3572
-            array($this, 'attendee_registrations_meta_box'),
3573
-            $this->_cpt_routes[$this->_req_action],
3574
-            'normal',
3575
-            'high'
3576
-        );
3577
-    }
3578
-
3579
-
3580
-    /**
3581
-     * Metabox for attendee contact info
3582
-     *
3583
-     * @param  WP_Post $post wp post object
3584
-     * @return string attendee contact info ( and form )
3585
-     * @throws EE_Error
3586
-     * @throws InvalidArgumentException
3587
-     * @throws InvalidDataTypeException
3588
-     * @throws InvalidInterfaceException
3589
-     * @throws LogicException
3590
-     * @throws DomainException
3591
-     */
3592
-    public function attendee_contact_info($post)
3593
-    {
3594
-        //get attendee object ( should already have it )
3595
-        $form = $this->getAttendeeContactDetailsMetaboxFormHandler($this->_cpt_model_obj);
3596
-        $form->enqueueStylesAndScripts();
3597
-        echo $form->display();
3598
-    }
3599
-
3600
-
3601
-    /**
3602
-     * Return form handler for the contact details metabox
3603
-     *
3604
-     * @param EE_Attendee $attendee
3605
-     * @return AttendeeContactDetailsMetaboxFormHandler
3606
-     * @throws DomainException
3607
-     * @throws InvalidArgumentException
3608
-     * @throws InvalidDataTypeException
3609
-     * @throws InvalidInterfaceException
3610
-     */
3611
-    protected function getAttendeeContactDetailsMetaboxFormHandler(EE_Attendee $attendee)
3612
-    {
3613
-        return new AttendeeContactDetailsMetaboxFormHandler($attendee, EE_Registry::instance());
3614
-    }
3615
-
3616
-
3617
-    /**
3618
-     * Metabox for attendee details
3619
-     *
3620
-     * @param  WP_Post $post wp post object
3621
-     * @throws DomainException
3622
-     */
3623
-    public function attendee_address_details($post)
3624
-    {
3625
-        //get attendee object (should already have it)
3626
-        $this->_template_args['attendee']     = $this->_cpt_model_obj;
3627
-        $this->_template_args['state_html']   = EEH_Form_Fields::generate_form_input(
3628
-            new EE_Question_Form_Input(
3629
-                EE_Question::new_instance(
3630
-                    array(
3631
-                        'QST_ID'           => 0,
3632
-                        'QST_display_text' => esc_html__('State/Province', 'event_espresso'),
3633
-                        'QST_system'       => 'admin-state',
3634
-                    )
3635
-                ),
3636
-                EE_Answer::new_instance(
3637
-                    array(
3638
-                        'ANS_ID'    => 0,
3639
-                        'ANS_value' => $this->_cpt_model_obj->state_ID(),
3640
-                    )
3641
-                ),
3642
-                array(
3643
-                    'input_id'       => 'STA_ID',
3644
-                    'input_name'     => 'STA_ID',
3645
-                    'input_prefix'   => '',
3646
-                    'append_qstn_id' => false,
3647
-                )
3648
-            )
3649
-        );
3650
-        $this->_template_args['country_html'] = EEH_Form_Fields::generate_form_input(
3651
-            new EE_Question_Form_Input(
3652
-                EE_Question::new_instance(
3653
-                    array(
3654
-                        'QST_ID'           => 0,
3655
-                        'QST_display_text' => esc_html__('Country', 'event_espresso'),
3656
-                        'QST_system'       => 'admin-country',
3657
-                    )
3658
-                ),
3659
-                EE_Answer::new_instance(
3660
-                    array(
3661
-                        'ANS_ID'    => 0,
3662
-                        'ANS_value' => $this->_cpt_model_obj->country_ID(),
3663
-                    )
3664
-                ),
3665
-                array(
3666
-                    'input_id'       => 'CNT_ISO',
3667
-                    'input_name'     => 'CNT_ISO',
3668
-                    'input_prefix'   => '',
3669
-                    'append_qstn_id' => false,
3670
-                )
3671
-            )
3672
-        );
3673
-        $template                             =
3674
-            REG_TEMPLATE_PATH . 'attendee_address_details_metabox_content.template.php';
3675
-        EEH_Template::display_template($template, $this->_template_args);
3676
-    }
3677
-
3678
-
3679
-    /**
3680
-     *        _attendee_details
3681
-     *
3682
-     * @access protected
3683
-     * @param $post
3684
-     * @return void
3685
-     * @throws DomainException
3686
-     * @throws EE_Error
3687
-     */
3688
-    public function attendee_registrations_meta_box($post)
3689
-    {
3690
-        $this->_template_args['attendee']      = $this->_cpt_model_obj;
3691
-        $this->_template_args['registrations'] = $this->_cpt_model_obj->get_many_related('Registration');
3692
-        $template                              =
3693
-            REG_TEMPLATE_PATH . 'attendee_registrations_main_meta_box.template.php';
3694
-        EEH_Template::display_template($template, $this->_template_args);
3695
-    }
3696
-
3697
-
3698
-    /**
3699
-     * add in the form fields for the attendee edit
3700
-     *
3701
-     * @param  WP_Post $post wp post object
3702
-     * @return string html for new form.
3703
-     * @throws DomainException
3704
-     */
3705
-    public function after_title_form_fields($post)
3706
-    {
3707
-        if ($post->post_type == 'espresso_attendees') {
3708
-            $template                  = REG_TEMPLATE_PATH . 'attendee_details_after_title_form_fields.template.php';
3709
-            $template_args['attendee'] = $this->_cpt_model_obj;
3710
-            EEH_Template::display_template($template, $template_args);
3711
-        }
3712
-    }
3713
-
3714
-
3715
-    /**
3716
-     *        _trash_or_restore_attendee
3717
-     *
3718
-     * @param boolean $trash - whether to move item to trash (TRUE) or restore it (FALSE)
3719
-     * @return void
3720
-     * @throws EE_Error
3721
-     * @throws InvalidArgumentException
3722
-     * @throws InvalidDataTypeException
3723
-     * @throws InvalidInterfaceException
3724
-     * @access protected
3725
-     */
3726
-    protected function _trash_or_restore_attendees($trash = true)
3727
-    {
3728
-        do_action('AHEE_log', __FILE__, __FUNCTION__, '');
3729
-        $ATT_MDL = EEM_Attendee::instance();
3730
-        $success = 1;
3731
-        //Checkboxes
3732
-        if ( ! empty($this->_req_data['checkbox']) && is_array($this->_req_data['checkbox'])) {
3733
-            // if array has more than one element than success message should be plural
3734
-            $success = count($this->_req_data['checkbox']) > 1 ? 2 : 1;
3735
-            // cycle thru checkboxes
3736
-            while (list($ATT_ID, $value) = each($this->_req_data['checkbox'])) {
3737
-                $updated = $trash ? $ATT_MDL->update_by_ID(array('status' => 'trash'), $ATT_ID)
3738
-                    : $ATT_MDL->update_by_ID(array('status' => 'publish'), $ATT_ID);
3739
-                if ( ! $updated) {
3740
-                    $success = 0;
3741
-                }
3742
-            }
3743
-        } else {
3744
-            // grab single id and delete
3745
-            $ATT_ID = absint($this->_req_data['ATT_ID']);
3746
-            //get attendee
3747
-            $att     = $ATT_MDL->get_one_by_ID($ATT_ID);
3748
-            $updated = $trash ? $att->set_status('trash') : $att->set_status('publish');
3749
-            $updated = $att->save();
3750
-            if ( ! $updated) {
3751
-                $success = 0;
3752
-            }
3753
-        }
3754
-        $what        = $success > 1
3755
-            ? esc_html__('Contacts', 'event_espresso')
3756
-            : esc_html__('Contact', 'event_espresso');
3757
-        $action_desc = $trash
3758
-            ? esc_html__('moved to the trash', 'event_espresso')
3759
-            : esc_html__('restored', 'event_espresso');
3760
-        $this->_redirect_after_action($success, $what, $action_desc, array('action' => 'contact_list'));
3761
-    }
2920
+		}
2921
+		$template_args = array(
2922
+			'title'                    => '',
2923
+			'content'                  => '',
2924
+			'step_button_text'         => '',
2925
+			'show_notification_toggle' => false,
2926
+		);
2927
+		//to indicate we're processing a new registration
2928
+		$hidden_fields = array(
2929
+			'processing_registration' => array(
2930
+				'type'  => 'hidden',
2931
+				'value' => 0,
2932
+			),
2933
+			'event_id'                => array(
2934
+				'type'  => 'hidden',
2935
+				'value' => $this->_reg_event->ID(),
2936
+			),
2937
+		);
2938
+		//if the cart is empty then we know we're at step one so we'll display ticket selector
2939
+		$cart = EE_Registry::instance()->SSN->cart();
2940
+		$step = ! $cart instanceof EE_Cart ? 'ticket' : 'questions';
2941
+		switch ($step) {
2942
+			case 'ticket' :
2943
+				$hidden_fields['processing_registration']['value'] = 1;
2944
+				$template_args['title']                            = esc_html__(
2945
+					'Step One: Select the Ticket for this registration',
2946
+					'event_espresso'
2947
+				);
2948
+				$template_args['content']                          =
2949
+					EED_Ticket_Selector::instance()->display_ticket_selector($this->_reg_event);
2950
+				$template_args['step_button_text']                 = esc_html__(
2951
+					'Add Tickets and Continue to Registrant Details',
2952
+					'event_espresso'
2953
+				);
2954
+				$template_args['show_notification_toggle']         = false;
2955
+				break;
2956
+			case 'questions' :
2957
+				$hidden_fields['processing_registration']['value'] = 2;
2958
+				$template_args['title']                            = esc_html__(
2959
+					'Step Two: Add Registrant Details for this Registration',
2960
+					'event_espresso'
2961
+				);
2962
+				//in theory we should be able to run EED_SPCO at this point because the cart should have been setup
2963
+				// properly by the first process_reg_step run.
2964
+				$template_args['content']                  =
2965
+					EED_Single_Page_Checkout::registration_checkout_for_admin();
2966
+				$template_args['step_button_text']         = esc_html__(
2967
+					'Save Registration and Continue to Details',
2968
+					'event_espresso'
2969
+				);
2970
+				$template_args['show_notification_toggle'] = true;
2971
+				break;
2972
+		}
2973
+		//we come back to the process_registration_step route.
2974
+		$this->_set_add_edit_form_tags('process_reg_step', $hidden_fields);
2975
+		return EEH_Template::display_template(
2976
+			REG_TEMPLATE_PATH . 'reg_admin_register_new_attendee_step_content.template.php',
2977
+			$template_args,
2978
+			true
2979
+		);
2980
+	}
2981
+
2982
+
2983
+	/**
2984
+	 *        set_reg_event
2985
+	 *
2986
+	 * @access private
2987
+	 * @return bool
2988
+	 * @throws EE_Error
2989
+	 * @throws InvalidArgumentException
2990
+	 * @throws InvalidDataTypeException
2991
+	 * @throws InvalidInterfaceException
2992
+	 */
2993
+	private function _set_reg_event()
2994
+	{
2995
+		if (is_object($this->_reg_event)) {
2996
+			return true;
2997
+		}
2998
+		$EVT_ID = (! empty($this->_req_data['event_id'])) ? absint($this->_req_data['event_id']) : false;
2999
+		if ( ! $EVT_ID) {
3000
+			return false;
3001
+		}
3002
+		$this->_reg_event = EEM_Event::instance()->get_one_by_ID($EVT_ID);
3003
+		return true;
3004
+	}
3005
+
3006
+
3007
+	/**
3008
+	 * process_reg_step
3009
+	 *
3010
+	 * @access        public
3011
+	 * @return string
3012
+	 * @throws DomainException
3013
+	 * @throws EE_Error
3014
+	 * @throws InvalidArgumentException
3015
+	 * @throws InvalidDataTypeException
3016
+	 * @throws InvalidInterfaceException
3017
+	 * @throws ReflectionException
3018
+	 * @throws RuntimeException
3019
+	 */
3020
+	public function process_reg_step()
3021
+	{
3022
+		EE_System::do_not_cache();
3023
+		$this->_set_reg_event();
3024
+		EE_Registry::instance()->REQ->set_espresso_page(true);
3025
+		EE_Registry::instance()->REQ->set('uts', time());
3026
+		//what step are we on?
3027
+		$cart = EE_Registry::instance()->SSN->cart();
3028
+		$step = ! $cart instanceof EE_Cart ? 'ticket' : 'questions';
3029
+		//if doing ajax then we need to verify the nonce
3030
+		if (defined('DOING_AJAX')) {
3031
+			$nonce = isset($this->_req_data[$this->_req_nonce])
3032
+				? sanitize_text_field($this->_req_data[$this->_req_nonce]) : '';
3033
+			$this->_verify_nonce($nonce, $this->_req_nonce);
3034
+		}
3035
+		switch ($step) {
3036
+			case 'ticket' :
3037
+				//process ticket selection
3038
+				$success = EED_Ticket_Selector::instance()->process_ticket_selections();
3039
+				if ($success) {
3040
+					EE_Error::add_success(
3041
+						esc_html__(
3042
+							'Tickets Selected. Now complete the registration.',
3043
+							'event_espresso'
3044
+						)
3045
+					);
3046
+				} else {
3047
+					$query_args['step_error'] = $this->_req_data['step_error'] = true;
3048
+				}
3049
+				if (defined('DOING_AJAX')) {
3050
+					$this->new_registration(); //display next step
3051
+				} else {
3052
+					$query_args = array(
3053
+						'action'                  => 'new_registration',
3054
+						'processing_registration' => 1,
3055
+						'event_id'                => $this->_reg_event->ID(),
3056
+						'uts'                     => time(),
3057
+					);
3058
+					$this->_redirect_after_action(
3059
+						false,
3060
+						'',
3061
+						'',
3062
+						$query_args,
3063
+						true
3064
+					);
3065
+				}
3066
+				break;
3067
+			case 'questions' :
3068
+				if (! isset(
3069
+					$this->_req_data['txn_reg_status_change'],
3070
+					$this->_req_data['txn_reg_status_change']['send_notifications'])
3071
+				) {
3072
+					add_filter('FHEE__EED_Messages___maybe_registration__deliver_notifications', '__return_false', 15);
3073
+				}
3074
+				//process registration
3075
+				$transaction = EED_Single_Page_Checkout::instance()->process_registration_from_admin();
3076
+				if ($cart instanceof EE_Cart) {
3077
+					$grand_total = $cart->get_cart_grand_total();
3078
+					if ($grand_total instanceof EE_Line_Item) {
3079
+						$grand_total->save_this_and_descendants_to_txn();
3080
+					}
3081
+				}
3082
+				if ( ! $transaction instanceof EE_Transaction) {
3083
+					$query_args = array(
3084
+						'action'                  => 'new_registration',
3085
+						'processing_registration' => 2,
3086
+						'event_id'                => $this->_reg_event->ID(),
3087
+						'uts'                     => time(),
3088
+					);
3089
+					if (defined('DOING_AJAX')) {
3090
+						//display registration form again because there are errors (maybe validation?)
3091
+						$this->new_registration();
3092
+						return;
3093
+					} else {
3094
+						$this->_redirect_after_action(
3095
+							false,
3096
+							'',
3097
+							'',
3098
+							$query_args,
3099
+							true
3100
+						);
3101
+						return;
3102
+					}
3103
+				}
3104
+				// maybe update status, and make sure to save transaction if not done already
3105
+				if ( ! $transaction->update_status_based_on_total_paid()) {
3106
+					$transaction->save();
3107
+				}
3108
+				EE_Registry::instance()->SSN->clear_session(__CLASS__, __FUNCTION__);
3109
+				$this->_req_data = array();
3110
+				$query_args      = array(
3111
+					'action'        => 'redirect_to_txn',
3112
+					'TXN_ID'        => $transaction->ID(),
3113
+					'EVT_ID'        => $this->_reg_event->ID(),
3114
+					'event_name'    => urlencode($this->_reg_event->name()),
3115
+					'redirect_from' => 'new_registration',
3116
+				);
3117
+				$this->_redirect_after_action(false, '', '', $query_args, true);
3118
+				break;
3119
+		}
3120
+		//what are you looking here for?  Should be nothing to do at this point.
3121
+	}
3122
+
3123
+
3124
+	/**
3125
+	 * redirect_to_txn
3126
+	 *
3127
+	 * @access public
3128
+	 * @return void
3129
+	 * @throws EE_Error
3130
+	 * @throws InvalidArgumentException
3131
+	 * @throws InvalidDataTypeException
3132
+	 * @throws InvalidInterfaceException
3133
+	 */
3134
+	public function redirect_to_txn()
3135
+	{
3136
+		EE_System::do_not_cache();
3137
+		EE_Registry::instance()->SSN->clear_session(__CLASS__, __FUNCTION__);
3138
+		$query_args = array(
3139
+			'action' => 'view_transaction',
3140
+			'TXN_ID' => isset($this->_req_data['TXN_ID']) ? absint($this->_req_data['TXN_ID']) : 0,
3141
+			'page'   => 'espresso_transactions',
3142
+		);
3143
+		if (isset($this->_req_data['EVT_ID'], $this->_req_data['redirect_from'])) {
3144
+			$query_args['EVT_ID']        = $this->_req_data['EVT_ID'];
3145
+			$query_args['event_name']    = urlencode($this->_req_data['event_name']);
3146
+			$query_args['redirect_from'] = $this->_req_data['redirect_from'];
3147
+		}
3148
+		EE_Error::add_success(
3149
+			esc_html__(
3150
+				'Registration Created.  Please review the transaction and add any payments as necessary',
3151
+				'event_espresso'
3152
+			)
3153
+		);
3154
+		$this->_redirect_after_action(false, '', '', $query_args, true);
3155
+	}
3156
+
3157
+
3158
+	/**
3159
+	 *        generates HTML for the Attendee Contact List
3160
+	 *
3161
+	 * @access protected
3162
+	 * @return void
3163
+	 */
3164
+	protected function _attendee_contact_list_table()
3165
+	{
3166
+		do_action('AHEE_log', __FILE__, __FUNCTION__, '');
3167
+		$this->_search_btn_label = esc_html__('Contacts', 'event_espresso');
3168
+		$this->display_admin_list_table_page_with_no_sidebar();
3169
+	}
3170
+
3171
+
3172
+	/**
3173
+	 *        get_attendees
3174
+	 *
3175
+	 * @param      $per_page
3176
+	 * @param bool $count whether to return count or data.
3177
+	 * @param bool $trash
3178
+	 * @return array
3179
+	 * @throws EE_Error
3180
+	 * @throws InvalidArgumentException
3181
+	 * @throws InvalidDataTypeException
3182
+	 * @throws InvalidInterfaceException
3183
+	 * @access public
3184
+	 */
3185
+	public function get_attendees($per_page, $count = false, $trash = false)
3186
+	{
3187
+		do_action('AHEE_log', __FILE__, __FUNCTION__, '');
3188
+		require_once(REG_ADMIN . 'EE_Attendee_Contact_List_Table.class.php');
3189
+		$ATT_MDL                    = EEM_Attendee::instance();
3190
+		$this->_req_data['orderby'] = ! empty($this->_req_data['orderby']) ? $this->_req_data['orderby'] : '';
3191
+		switch ($this->_req_data['orderby']) {
3192
+			case 'ATT_ID':
3193
+				$orderby = 'ATT_ID';
3194
+				break;
3195
+			case 'ATT_fname':
3196
+				$orderby = 'ATT_fname';
3197
+				break;
3198
+			case 'ATT_email':
3199
+				$orderby = 'ATT_email';
3200
+				break;
3201
+			case 'ATT_city':
3202
+				$orderby = 'ATT_city';
3203
+				break;
3204
+			case 'STA_ID':
3205
+				$orderby = 'STA_ID';
3206
+				break;
3207
+			case 'CNT_ID':
3208
+				$orderby = 'CNT_ID';
3209
+				break;
3210
+			default:
3211
+				$orderby = 'ATT_lname';
3212
+		}
3213
+		$sort         = (isset($this->_req_data['order']) && ! empty($this->_req_data['order']))
3214
+			? $this->_req_data['order']
3215
+			: 'ASC';
3216
+		$current_page = isset($this->_req_data['paged']) && ! empty($this->_req_data['paged'])
3217
+			? $this->_req_data['paged']
3218
+			: 1;
3219
+		$per_page     = isset($per_page) && ! empty($per_page) ? $per_page : 10;
3220
+		$per_page     = isset($this->_req_data['perpage']) && ! empty($this->_req_data['perpage'])
3221
+			? $this->_req_data['perpage']
3222
+			: $per_page;
3223
+		$_where       = array();
3224
+		if ( ! empty($this->_req_data['s'])) {
3225
+			$sstr         = '%' . $this->_req_data['s'] . '%';
3226
+			$_where['OR'] = array(
3227
+				'Registration.Event.EVT_name'       => array('LIKE', $sstr),
3228
+				'Registration.Event.EVT_desc'       => array('LIKE', $sstr),
3229
+				'Registration.Event.EVT_short_desc' => array('LIKE', $sstr),
3230
+				'ATT_fname'                         => array('LIKE', $sstr),
3231
+				'ATT_lname'                         => array('LIKE', $sstr),
3232
+				'ATT_short_bio'                     => array('LIKE', $sstr),
3233
+				'ATT_email'                         => array('LIKE', $sstr),
3234
+				'ATT_address'                       => array('LIKE', $sstr),
3235
+				'ATT_address2'                      => array('LIKE', $sstr),
3236
+				'ATT_city'                          => array('LIKE', $sstr),
3237
+				'Country.CNT_name'                  => array('LIKE', $sstr),
3238
+				'State.STA_name'                    => array('LIKE', $sstr),
3239
+				'ATT_phone'                         => array('LIKE', $sstr),
3240
+				'Registration.REG_final_price'      => array('LIKE', $sstr),
3241
+				'Registration.REG_code'             => array('LIKE', $sstr),
3242
+				'Registration.REG_count'            => array('LIKE', $sstr),
3243
+				'Registration.REG_group_size'       => array('LIKE', $sstr),
3244
+			);
3245
+		}
3246
+		$offset = ($current_page - 1) * $per_page;
3247
+		$limit  = $count ? null : array($offset, $per_page);
3248
+		if ($trash) {
3249
+			$_where['status'] = array('!=', 'publish');
3250
+			$all_attendees    = $count
3251
+				? $ATT_MDL->count(array(
3252
+					$_where,
3253
+					'order_by' => array($orderby => $sort),
3254
+					'limit'    => $limit,
3255
+				), 'ATT_ID', true)
3256
+				: $ATT_MDL->get_all(array(
3257
+					$_where,
3258
+					'order_by' => array($orderby => $sort),
3259
+					'limit'    => $limit,
3260
+				));
3261
+		} else {
3262
+			$_where['status'] = array('IN', array('publish'));
3263
+			$all_attendees    = $count
3264
+				? $ATT_MDL->count(array(
3265
+					$_where,
3266
+					'order_by' => array($orderby => $sort),
3267
+					'limit'    => $limit,
3268
+				), 'ATT_ID', true)
3269
+				: $ATT_MDL->get_all(array(
3270
+					$_where,
3271
+					'order_by' => array($orderby => $sort),
3272
+					'limit'    => $limit,
3273
+				));
3274
+		}
3275
+		return $all_attendees;
3276
+	}
3277
+
3278
+
3279
+	/**
3280
+	 * This is just taking care of resending the registration confirmation
3281
+	 *
3282
+	 * @access protected
3283
+	 * @return void
3284
+	 */
3285
+	protected function _resend_registration()
3286
+	{
3287
+		$this->_process_resend_registration();
3288
+		$query_args = isset($this->_req_data['redirect_to'])
3289
+			? array('action' => $this->_req_data['redirect_to'], '_REG_ID' => $this->_req_data['_REG_ID'])
3290
+			: array('action' => 'default');
3291
+		$this->_redirect_after_action(false, '', '', $query_args, true);
3292
+	}
3293
+
3294
+	/**
3295
+	 * Creates a registration report, but accepts the name of a method to use for preparing the query parameters
3296
+	 * to use when selecting registrations
3297
+	 * @param string $method_name_for_getting_query_params the name of the method (on this class) to use for preparing
3298
+	 *                                                     the query parameters from the request
3299
+	 * @return void ends the request with a redirect or download
3300
+	 */
3301
+	public function _registrations_report_base( $method_name_for_getting_query_params )
3302
+	{
3303
+		if (! defined('EE_USE_OLD_CSV_REPORT_CLASS')) {
3304
+			wp_redirect(EE_Admin_Page::add_query_args_and_nonce(
3305
+				array(
3306
+					'page'        => 'espresso_batch',
3307
+					'batch'       => 'file',
3308
+					'EVT_ID'      => isset($this->_req_data['EVT_ID']) ? $this->_req_data['EVT_ID'] : null,
3309
+					'filters'     => urlencode(
3310
+						serialize(
3311
+							call_user_func(
3312
+								array( $this, $method_name_for_getting_query_params ),
3313
+								EEH_Array::is_set(
3314
+									$this->_req_data,
3315
+									'filters',
3316
+									array()
3317
+								)
3318
+							)
3319
+						)
3320
+				),
3321
+				'use_filters' => EEH_Array::is_set($this->_req_data, 'use_filters', false),
3322
+				'job_handler' => urlencode('EventEspressoBatchRequest\JobHandlers\RegistrationsReport'),
3323
+				'return_url'  => urlencode($this->_req_data['return_url']),
3324
+			)));
3325
+		} else {
3326
+			$new_request_args = array(
3327
+				'export' => 'report',
3328
+				'action' => 'registrations_report_for_event',
3329
+				'EVT_ID' => isset($this->_req_data['EVT_ID']) ? $this->_req_data['EVT_ID'] : null,
3330
+			);
3331
+			$this->_req_data = array_merge($this->_req_data, $new_request_args);
3332
+			if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
3333
+				require_once(EE_CLASSES . 'EE_Export.class.php');
3334
+				$EE_Export = EE_Export::instance($this->_req_data);
3335
+				$EE_Export->export();
3336
+			}
3337
+		}
3338
+	}
3339
+
3340
+
3341
+
3342
+	/**
3343
+	 * Creates a registration report using only query parameters in the request
3344
+	 * @return void
3345
+	 */
3346
+	public function _registrations_report()
3347
+	{
3348
+		$this->_registrations_report_base('_get_registration_query_parameters');
3349
+	}
3350
+
3351
+
3352
+	public function _contact_list_export()
3353
+	{
3354
+		if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
3355
+			require_once(EE_CLASSES . 'EE_Export.class.php');
3356
+			$EE_Export = EE_Export::instance($this->_req_data);
3357
+			$EE_Export->export_attendees();
3358
+		}
3359
+	}
3360
+
3361
+
3362
+	public function _contact_list_report()
3363
+	{
3364
+		if ( ! defined('EE_USE_OLD_CSV_REPORT_CLASS')) {
3365
+			wp_redirect(EE_Admin_Page::add_query_args_and_nonce(array(
3366
+				'page'        => 'espresso_batch',
3367
+				'batch'       => 'file',
3368
+				'job_handler' => urlencode('EventEspressoBatchRequest\JobHandlers\AttendeesReport'),
3369
+				'return_url'  => urlencode($this->_req_data['return_url']),
3370
+			)));
3371
+		} else {
3372
+			if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
3373
+				require_once(EE_CLASSES . 'EE_Export.class.php');
3374
+				$EE_Export = EE_Export::instance($this->_req_data);
3375
+				$EE_Export->report_attendees();
3376
+			}
3377
+		}
3378
+	}
3379
+
3380
+
3381
+
3382
+
3383
+
3384
+	/***************************************        ATTENDEE DETAILS        ***************************************/
3385
+	/**
3386
+	 * This duplicates the attendee object for the given incoming registration id and attendee_id.
3387
+	 *
3388
+	 * @return void
3389
+	 * @throws EE_Error
3390
+	 * @throws InvalidArgumentException
3391
+	 * @throws InvalidDataTypeException
3392
+	 * @throws InvalidInterfaceException
3393
+	 */
3394
+	protected function _duplicate_attendee()
3395
+	{
3396
+		$action = ! empty($this->_req_data['return']) ? $this->_req_data['return'] : 'default';
3397
+		//verify we have necessary info
3398
+		if (empty($this->_req_data['_REG_ID'])) {
3399
+			EE_Error::add_error(
3400
+				esc_html__(
3401
+					'Unable to create the contact for the registration because the required parameters are not present (_REG_ID )',
3402
+					'event_espresso'
3403
+				), __FILE__, __LINE__, __FUNCTION__
3404
+			);
3405
+			$query_args = array('action' => $action);
3406
+			$this->_redirect_after_action('', '', '', $query_args, true);
3407
+		}
3408
+		//okay necessary deets present... let's dupe the incoming attendee and attach to incoming registration.
3409
+		$registration = EEM_Registration::instance()->get_one_by_ID($this->_req_data['_REG_ID']);
3410
+		$attendee     = $registration->attendee();
3411
+		//remove relation of existing attendee on registration
3412
+		$registration->_remove_relation_to($attendee, 'Attendee');
3413
+		//new attendee
3414
+		$new_attendee = clone $attendee;
3415
+		$new_attendee->set('ATT_ID', 0);
3416
+		$new_attendee->save();
3417
+		//add new attendee to reg
3418
+		$registration->_add_relation_to($new_attendee, 'Attendee');
3419
+		EE_Error::add_success(
3420
+			esc_html__(
3421
+				'New Contact record created.  Now make any edits you wish to make for this contact.',
3422
+				'event_espresso'
3423
+			)
3424
+		);
3425
+		//redirect to edit page for attendee
3426
+		$query_args = array('post' => $new_attendee->ID(), 'action' => 'edit_attendee');
3427
+		$this->_redirect_after_action('', '', '', $query_args, true);
3428
+	}
3429
+
3430
+
3431
+	/**
3432
+	 * Callback invoked by parent EE_Admin_CPT class hooked in on `save_post` wp hook.
3433
+	 * @param int      $post_id
3434
+	 * @param WP_POST $post
3435
+	 * @throws DomainException
3436
+	 * @throws EE_Error
3437
+	 * @throws InvalidArgumentException
3438
+	 * @throws InvalidDataTypeException
3439
+	 * @throws InvalidInterfaceException
3440
+	 * @throws LogicException
3441
+	 * @throws InvalidFormSubmissionException
3442
+	 */
3443
+	protected function _insert_update_cpt_item($post_id, $post)
3444
+	{
3445
+		$success  = true;
3446
+		$attendee = $post instanceof WP_Post && $post->post_type === 'espresso_attendees'
3447
+			? EEM_Attendee::instance()->get_one_by_ID($post_id)
3448
+			: null;
3449
+		//for attendee updates
3450
+		if ($attendee instanceof EE_Attendee) {
3451
+			//note we should only be UPDATING attendees at this point.
3452
+			$updated_fields = array(
3453
+				'ATT_fname'     => $this->_req_data['ATT_fname'],
3454
+				'ATT_lname'     => $this->_req_data['ATT_lname'],
3455
+				'ATT_full_name' => $this->_req_data['ATT_fname'] . ' ' . $this->_req_data['ATT_lname'],
3456
+				'ATT_address'   => isset($this->_req_data['ATT_address']) ? $this->_req_data['ATT_address'] : '',
3457
+				'ATT_address2'  => isset($this->_req_data['ATT_address2']) ? $this->_req_data['ATT_address2'] : '',
3458
+				'ATT_city'      => isset($this->_req_data['ATT_city']) ? $this->_req_data['ATT_city'] : '',
3459
+				'STA_ID'        => isset($this->_req_data['STA_ID']) ? $this->_req_data['STA_ID'] : '',
3460
+				'CNT_ISO'       => isset($this->_req_data['CNT_ISO']) ? $this->_req_data['CNT_ISO'] : '',
3461
+				'ATT_zip'       => isset($this->_req_data['ATT_zip']) ? $this->_req_data['ATT_zip'] : '',
3462
+			);
3463
+			foreach ($updated_fields as $field => $value) {
3464
+				$attendee->set($field, $value);
3465
+			}
3466
+
3467
+			//process contact details metabox form handler (which will also save the attendee)
3468
+			$contact_details_form = $this->getAttendeeContactDetailsMetaboxFormHandler($attendee);
3469
+			$success = $contact_details_form->process($this->_req_data);
3470
+
3471
+			$attendee_update_callbacks = apply_filters(
3472
+				'FHEE__Registrations_Admin_Page__insert_update_cpt_item__attendee_update',
3473
+				array()
3474
+			);
3475
+			foreach ($attendee_update_callbacks as $a_callback) {
3476
+				if (false === call_user_func_array($a_callback, array($attendee, $this->_req_data))) {
3477
+					throw new EE_Error(
3478
+						sprintf(
3479
+							esc_html__(
3480
+								'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.',
3481
+								'event_espresso'
3482
+							),
3483
+							$a_callback
3484
+						)
3485
+					);
3486
+				}
3487
+			}
3488
+		}
3489
+
3490
+		if ($success === false) {
3491
+			EE_Error::add_error(
3492
+				esc_html__(
3493
+					'Something went wrong with updating the meta table data for the registration.',
3494
+					'event_espresso'
3495
+				),
3496
+				__FILE__, __FUNCTION__, __LINE__
3497
+			);
3498
+		}
3499
+	}
3500
+
3501
+
3502
+	public function trash_cpt_item($post_id)
3503
+	{
3504
+	}
3505
+
3506
+
3507
+	public function delete_cpt_item($post_id)
3508
+	{
3509
+	}
3510
+
3511
+
3512
+	public function restore_cpt_item($post_id)
3513
+	{
3514
+	}
3515
+
3516
+
3517
+	protected function _restore_cpt_item($post_id, $revision_id)
3518
+	{
3519
+	}
3520
+
3521
+
3522
+	public function attendee_editor_metaboxes()
3523
+	{
3524
+		$this->verify_cpt_object();
3525
+		remove_meta_box(
3526
+			'postexcerpt',
3527
+			esc_html__('Excerpt', 'event_espresso'),
3528
+			'post_excerpt_meta_box',
3529
+			$this->_cpt_routes[$this->_req_action],
3530
+			'normal',
3531
+			'core'
3532
+		);
3533
+		remove_meta_box('commentstatusdiv', $this->_cpt_routes[$this->_req_action], 'normal', 'core');
3534
+		if (post_type_supports('espresso_attendees', 'excerpt')) {
3535
+			add_meta_box(
3536
+				'postexcerpt',
3537
+				esc_html__('Short Biography', 'event_espresso'),
3538
+				'post_excerpt_meta_box',
3539
+				$this->_cpt_routes[$this->_req_action],
3540
+				'normal'
3541
+			);
3542
+		}
3543
+		if (post_type_supports('espresso_attendees', 'comments')) {
3544
+			add_meta_box(
3545
+				'commentsdiv',
3546
+				esc_html__('Notes on the Contact', 'event_espresso'),
3547
+				'post_comment_meta_box',
3548
+				$this->_cpt_routes[$this->_req_action],
3549
+				'normal',
3550
+				'core'
3551
+			);
3552
+		}
3553
+		add_meta_box(
3554
+			'attendee_contact_info',
3555
+			esc_html__('Contact Info', 'event_espresso'),
3556
+			array($this, 'attendee_contact_info'),
3557
+			$this->_cpt_routes[$this->_req_action],
3558
+			'side',
3559
+			'core'
3560
+		);
3561
+		add_meta_box(
3562
+			'attendee_details_address',
3563
+			esc_html__('Address Details', 'event_espresso'),
3564
+			array($this, 'attendee_address_details'),
3565
+			$this->_cpt_routes[$this->_req_action],
3566
+			'normal',
3567
+			'core'
3568
+		);
3569
+		add_meta_box(
3570
+			'attendee_registrations',
3571
+			esc_html__('Registrations for this Contact', 'event_espresso'),
3572
+			array($this, 'attendee_registrations_meta_box'),
3573
+			$this->_cpt_routes[$this->_req_action],
3574
+			'normal',
3575
+			'high'
3576
+		);
3577
+	}
3578
+
3579
+
3580
+	/**
3581
+	 * Metabox for attendee contact info
3582
+	 *
3583
+	 * @param  WP_Post $post wp post object
3584
+	 * @return string attendee contact info ( and form )
3585
+	 * @throws EE_Error
3586
+	 * @throws InvalidArgumentException
3587
+	 * @throws InvalidDataTypeException
3588
+	 * @throws InvalidInterfaceException
3589
+	 * @throws LogicException
3590
+	 * @throws DomainException
3591
+	 */
3592
+	public function attendee_contact_info($post)
3593
+	{
3594
+		//get attendee object ( should already have it )
3595
+		$form = $this->getAttendeeContactDetailsMetaboxFormHandler($this->_cpt_model_obj);
3596
+		$form->enqueueStylesAndScripts();
3597
+		echo $form->display();
3598
+	}
3599
+
3600
+
3601
+	/**
3602
+	 * Return form handler for the contact details metabox
3603
+	 *
3604
+	 * @param EE_Attendee $attendee
3605
+	 * @return AttendeeContactDetailsMetaboxFormHandler
3606
+	 * @throws DomainException
3607
+	 * @throws InvalidArgumentException
3608
+	 * @throws InvalidDataTypeException
3609
+	 * @throws InvalidInterfaceException
3610
+	 */
3611
+	protected function getAttendeeContactDetailsMetaboxFormHandler(EE_Attendee $attendee)
3612
+	{
3613
+		return new AttendeeContactDetailsMetaboxFormHandler($attendee, EE_Registry::instance());
3614
+	}
3615
+
3616
+
3617
+	/**
3618
+	 * Metabox for attendee details
3619
+	 *
3620
+	 * @param  WP_Post $post wp post object
3621
+	 * @throws DomainException
3622
+	 */
3623
+	public function attendee_address_details($post)
3624
+	{
3625
+		//get attendee object (should already have it)
3626
+		$this->_template_args['attendee']     = $this->_cpt_model_obj;
3627
+		$this->_template_args['state_html']   = EEH_Form_Fields::generate_form_input(
3628
+			new EE_Question_Form_Input(
3629
+				EE_Question::new_instance(
3630
+					array(
3631
+						'QST_ID'           => 0,
3632
+						'QST_display_text' => esc_html__('State/Province', 'event_espresso'),
3633
+						'QST_system'       => 'admin-state',
3634
+					)
3635
+				),
3636
+				EE_Answer::new_instance(
3637
+					array(
3638
+						'ANS_ID'    => 0,
3639
+						'ANS_value' => $this->_cpt_model_obj->state_ID(),
3640
+					)
3641
+				),
3642
+				array(
3643
+					'input_id'       => 'STA_ID',
3644
+					'input_name'     => 'STA_ID',
3645
+					'input_prefix'   => '',
3646
+					'append_qstn_id' => false,
3647
+				)
3648
+			)
3649
+		);
3650
+		$this->_template_args['country_html'] = EEH_Form_Fields::generate_form_input(
3651
+			new EE_Question_Form_Input(
3652
+				EE_Question::new_instance(
3653
+					array(
3654
+						'QST_ID'           => 0,
3655
+						'QST_display_text' => esc_html__('Country', 'event_espresso'),
3656
+						'QST_system'       => 'admin-country',
3657
+					)
3658
+				),
3659
+				EE_Answer::new_instance(
3660
+					array(
3661
+						'ANS_ID'    => 0,
3662
+						'ANS_value' => $this->_cpt_model_obj->country_ID(),
3663
+					)
3664
+				),
3665
+				array(
3666
+					'input_id'       => 'CNT_ISO',
3667
+					'input_name'     => 'CNT_ISO',
3668
+					'input_prefix'   => '',
3669
+					'append_qstn_id' => false,
3670
+				)
3671
+			)
3672
+		);
3673
+		$template                             =
3674
+			REG_TEMPLATE_PATH . 'attendee_address_details_metabox_content.template.php';
3675
+		EEH_Template::display_template($template, $this->_template_args);
3676
+	}
3677
+
3678
+
3679
+	/**
3680
+	 *        _attendee_details
3681
+	 *
3682
+	 * @access protected
3683
+	 * @param $post
3684
+	 * @return void
3685
+	 * @throws DomainException
3686
+	 * @throws EE_Error
3687
+	 */
3688
+	public function attendee_registrations_meta_box($post)
3689
+	{
3690
+		$this->_template_args['attendee']      = $this->_cpt_model_obj;
3691
+		$this->_template_args['registrations'] = $this->_cpt_model_obj->get_many_related('Registration');
3692
+		$template                              =
3693
+			REG_TEMPLATE_PATH . 'attendee_registrations_main_meta_box.template.php';
3694
+		EEH_Template::display_template($template, $this->_template_args);
3695
+	}
3696
+
3697
+
3698
+	/**
3699
+	 * add in the form fields for the attendee edit
3700
+	 *
3701
+	 * @param  WP_Post $post wp post object
3702
+	 * @return string html for new form.
3703
+	 * @throws DomainException
3704
+	 */
3705
+	public function after_title_form_fields($post)
3706
+	{
3707
+		if ($post->post_type == 'espresso_attendees') {
3708
+			$template                  = REG_TEMPLATE_PATH . 'attendee_details_after_title_form_fields.template.php';
3709
+			$template_args['attendee'] = $this->_cpt_model_obj;
3710
+			EEH_Template::display_template($template, $template_args);
3711
+		}
3712
+	}
3713
+
3714
+
3715
+	/**
3716
+	 *        _trash_or_restore_attendee
3717
+	 *
3718
+	 * @param boolean $trash - whether to move item to trash (TRUE) or restore it (FALSE)
3719
+	 * @return void
3720
+	 * @throws EE_Error
3721
+	 * @throws InvalidArgumentException
3722
+	 * @throws InvalidDataTypeException
3723
+	 * @throws InvalidInterfaceException
3724
+	 * @access protected
3725
+	 */
3726
+	protected function _trash_or_restore_attendees($trash = true)
3727
+	{
3728
+		do_action('AHEE_log', __FILE__, __FUNCTION__, '');
3729
+		$ATT_MDL = EEM_Attendee::instance();
3730
+		$success = 1;
3731
+		//Checkboxes
3732
+		if ( ! empty($this->_req_data['checkbox']) && is_array($this->_req_data['checkbox'])) {
3733
+			// if array has more than one element than success message should be plural
3734
+			$success = count($this->_req_data['checkbox']) > 1 ? 2 : 1;
3735
+			// cycle thru checkboxes
3736
+			while (list($ATT_ID, $value) = each($this->_req_data['checkbox'])) {
3737
+				$updated = $trash ? $ATT_MDL->update_by_ID(array('status' => 'trash'), $ATT_ID)
3738
+					: $ATT_MDL->update_by_ID(array('status' => 'publish'), $ATT_ID);
3739
+				if ( ! $updated) {
3740
+					$success = 0;
3741
+				}
3742
+			}
3743
+		} else {
3744
+			// grab single id and delete
3745
+			$ATT_ID = absint($this->_req_data['ATT_ID']);
3746
+			//get attendee
3747
+			$att     = $ATT_MDL->get_one_by_ID($ATT_ID);
3748
+			$updated = $trash ? $att->set_status('trash') : $att->set_status('publish');
3749
+			$updated = $att->save();
3750
+			if ( ! $updated) {
3751
+				$success = 0;
3752
+			}
3753
+		}
3754
+		$what        = $success > 1
3755
+			? esc_html__('Contacts', 'event_espresso')
3756
+			: esc_html__('Contact', 'event_espresso');
3757
+		$action_desc = $trash
3758
+			? esc_html__('moved to the trash', 'event_espresso')
3759
+			: esc_html__('restored', 'event_espresso');
3760
+		$this->_redirect_after_action($success, $what, $action_desc, array('action' => 'contact_list'));
3761
+	}
3762 3762
 
3763 3763
 }
Please login to merge, or discard this patch.
Spacing   +86 added lines, -86 removed lines patch added patch discarded remove patch
@@ -76,7 +76,7 @@  discard block
 block discarded – undo
76 76
         // when adding a new registration...
77 77
         if (isset($this->_req_data['action']) && $this->_req_data['action'] === 'new_registration') {
78 78
             EE_System::do_not_cache();
79
-            if (! isset($this->_req_data['processing_registration'])
79
+            if ( ! isset($this->_req_data['processing_registration'])
80 80
                  || absint($this->_req_data['processing_registration']) !== 1
81 81
             ) {
82 82
                 // and it's NOT the attendee information reg step
@@ -171,7 +171,7 @@  discard block
 block discarded – undo
171 171
     public function _set_page_routes()
172 172
     {
173 173
         $this->_get_registration_status_array();
174
-        $reg_id             = ! empty($this->_req_data['_REG_ID']) && ! is_array($this->_req_data['_REG_ID'])
174
+        $reg_id = ! empty($this->_req_data['_REG_ID']) && ! is_array($this->_req_data['_REG_ID'])
175 175
             ? $this->_req_data['_REG_ID'] : 0;
176 176
         $reg_id = empty($reg_id) && ! empty($this->_req_data['reg_status_change_form']['REG_ID'])
177 177
             ? $this->_req_data['reg_status_change_form']['REG_ID']
@@ -669,7 +669,7 @@  discard block
 block discarded – undo
669 669
         //style
670 670
         wp_register_style(
671 671
             'espresso_reg',
672
-            REG_ASSETS_URL . 'espresso_registrations_admin.css',
672
+            REG_ASSETS_URL.'espresso_registrations_admin.css',
673 673
             array('ee-admin-css'),
674 674
             EVENT_ESPRESSO_VERSION
675 675
         );
@@ -677,7 +677,7 @@  discard block
 block discarded – undo
677 677
         //script
678 678
         wp_register_script(
679 679
             'espresso_reg',
680
-            REG_ASSETS_URL . 'espresso_registrations_admin.js',
680
+            REG_ASSETS_URL.'espresso_registrations_admin.js',
681 681
             array('jquery-ui-datepicker', 'jquery-ui-draggable', 'ee_admin_js'),
682 682
             EVENT_ESPRESSO_VERSION,
683 683
             true
@@ -715,7 +715,7 @@  discard block
 block discarded – undo
715 715
         wp_deregister_style('espresso_reg');
716 716
         wp_register_style(
717 717
             'espresso_att',
718
-            REG_ASSETS_URL . 'espresso_attendees_admin.css',
718
+            REG_ASSETS_URL.'espresso_attendees_admin.css',
719 719
             array('ee-admin-css'),
720 720
             EVENT_ESPRESSO_VERSION
721 721
         );
@@ -727,7 +727,7 @@  discard block
 block discarded – undo
727 727
     {
728 728
         wp_register_script(
729 729
             'ee-spco-for-admin',
730
-            REG_ASSETS_URL . 'spco_for_admin.js',
730
+            REG_ASSETS_URL.'spco_for_admin.js',
731 731
             array('underscore', 'jquery'),
732 732
             EVENT_ESPRESSO_VERSION,
733 733
             true
@@ -861,7 +861,7 @@  discard block
 block discarded – undo
861 861
                     'trash_registrations' => esc_html__('Trash Registrations', 'event_espresso'),
862 862
                 ),
863 863
             );
864
-            $this->_views['trash']      = array(
864
+            $this->_views['trash'] = array(
865 865
                 'slug'        => 'trash',
866 866
                 'label'       => esc_html__('Trash', 'event_espresso'),
867 867
                 'count'       => 0,
@@ -950,7 +950,7 @@  discard block
 block discarded – undo
950 950
         }
951 951
         $sc_items = array(
952 952
             'approved_status'   => array(
953
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_approved,
953
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_approved,
954 954
                 'desc'  => EEH_Template::pretty_status(
955 955
                     EEM_Registration::status_id_approved,
956 956
                     false,
@@ -958,7 +958,7 @@  discard block
 block discarded – undo
958 958
                 ),
959 959
             ),
960 960
             'pending_status'    => array(
961
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_pending_payment,
961
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_pending_payment,
962 962
                 'desc'  => EEH_Template::pretty_status(
963 963
                     EEM_Registration::status_id_pending_payment,
964 964
                     false,
@@ -966,7 +966,7 @@  discard block
 block discarded – undo
966 966
                 ),
967 967
             ),
968 968
             'wait_list'         => array(
969
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_wait_list,
969
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_wait_list,
970 970
                 'desc'  => EEH_Template::pretty_status(
971 971
                     EEM_Registration::status_id_wait_list,
972 972
                     false,
@@ -974,7 +974,7 @@  discard block
 block discarded – undo
974 974
                 ),
975 975
             ),
976 976
             'incomplete_status' => array(
977
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_incomplete,
977
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_incomplete,
978 978
                 'desc'  => EEH_Template::pretty_status(
979 979
                     EEM_Registration::status_id_incomplete,
980 980
                     false,
@@ -982,7 +982,7 @@  discard block
 block discarded – undo
982 982
                 ),
983 983
             ),
984 984
             'not_approved'      => array(
985
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_not_approved,
985
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_not_approved,
986 986
                 'desc'  => EEH_Template::pretty_status(
987 987
                     EEM_Registration::status_id_not_approved,
988 988
                     false,
@@ -990,7 +990,7 @@  discard block
 block discarded – undo
990 990
                 ),
991 991
             ),
992 992
             'declined_status'   => array(
993
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_declined,
993
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_declined,
994 994
                 'desc'  => EEH_Template::pretty_status(
995 995
                     EEM_Registration::status_id_declined,
996 996
                     false,
@@ -998,7 +998,7 @@  discard block
 block discarded – undo
998 998
                 ),
999 999
             ),
1000 1000
             'cancelled_status'  => array(
1001
-                'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_cancelled,
1001
+                'class' => 'ee-status-legend ee-status-legend-'.EEM_Registration::status_id_cancelled,
1002 1002
                 'desc'  => EEH_Template::pretty_status(
1003 1003
                     EEM_Registration::status_id_cancelled,
1004 1004
                     false,
@@ -1027,7 +1027,7 @@  discard block
 block discarded – undo
1027 1027
                 'espresso_registrations_new_registration',
1028 1028
                 $EVT_ID
1029 1029
             )) {
1030
-                $this->_admin_page_title .= ' ' . $this->get_action_link_or_button(
1030
+                $this->_admin_page_title .= ' '.$this->get_action_link_or_button(
1031 1031
                     'new_registration',
1032 1032
                     'add-registrant',
1033 1033
                     array('event_id' => $EVT_ID),
@@ -1067,7 +1067,7 @@  discard block
 block discarded – undo
1067 1067
                 $this->_template_args['admin_page_header'] .= ' &nbsp;<span class="drk-grey-text">';
1068 1068
                 $this->_template_args['admin_page_header'] .= '<span class="dashicons dashicons-calendar"></span>';
1069 1069
                 $this->_template_args['admin_page_header'] .= $datetime->name();
1070
-                $this->_template_args['admin_page_header'] .= ' ( ' . $datetime->start_date() . ' )';
1070
+                $this->_template_args['admin_page_header'] .= ' ( '.$datetime->start_date().' )';
1071 1071
                 $this->_template_args['admin_page_header'] .= '</span></h3>';
1072 1072
             }
1073 1073
         }
@@ -1174,7 +1174,7 @@  discard block
 block discarded – undo
1174 1174
             'caps'                     => EEM_Registration::caps_read_admin,
1175 1175
             'default_where_conditions' => 'this_model_only',
1176 1176
         );
1177
-        if (! $count) {
1177
+        if ( ! $count) {
1178 1178
             $query_params = array_merge(
1179 1179
                 $query_params,
1180 1180
                 $this->_get_orderby_for_registrations_query(),
@@ -1195,7 +1195,7 @@  discard block
 block discarded – undo
1195 1195
     protected function _add_event_id_to_where_conditions(array $request)
1196 1196
     {
1197 1197
         $where = array();
1198
-        if (! empty($request['event_id'])) {
1198
+        if ( ! empty($request['event_id'])) {
1199 1199
             $where['EVT_ID'] = absint($request['event_id']);
1200 1200
         }
1201 1201
         return $where;
@@ -1211,7 +1211,7 @@  discard block
 block discarded – undo
1211 1211
     protected function _add_category_id_to_where_conditions(array $request)
1212 1212
     {
1213 1213
         $where = array();
1214
-        if (! empty($request['EVT_CAT']) && (int)$request['EVT_CAT'] !== -1) {
1214
+        if ( ! empty($request['EVT_CAT']) && (int) $request['EVT_CAT'] !== -1) {
1215 1215
             $where['Event.Term_Taxonomy.term_id'] = absint($request['EVT_CAT']);
1216 1216
         }
1217 1217
         return $where;
@@ -1227,10 +1227,10 @@  discard block
 block discarded – undo
1227 1227
     protected function _add_datetime_id_to_where_conditions(array $request)
1228 1228
     {
1229 1229
         $where = array();
1230
-        if (! empty($request['datetime_id'])) {
1230
+        if ( ! empty($request['datetime_id'])) {
1231 1231
             $where['Ticket.Datetime.DTT_ID'] = absint($request['datetime_id']);
1232 1232
         }
1233
-        if (! empty($request['DTT_ID'])) {
1233
+        if ( ! empty($request['DTT_ID'])) {
1234 1234
             $where['Ticket.Datetime.DTT_ID'] = absint($request['DTT_ID']);
1235 1235
         }
1236 1236
         return $where;
@@ -1256,7 +1256,7 @@  discard block
 block discarded – undo
1256 1256
          * If not filtering by specified status, then we show all registrations excluding incomplete registrations
1257 1257
          * UNLESS viewing trashed registrations.
1258 1258
          */
1259
-        if (! empty($registration_status)) {
1259
+        if ( ! empty($registration_status)) {
1260 1260
             $where['STS_ID'] = $registration_status;
1261 1261
         } else {
1262 1262
             //make sure we exclude incomplete registrations, but only if not trashed.
@@ -1299,12 +1299,12 @@  discard block
 block discarded – undo
1299 1299
                 array(
1300 1300
                     EEM_Registration::instance()->convert_datetime_for_query(
1301 1301
                         'REG_date',
1302
-                        $now . ' 00:00:00',
1302
+                        $now.' 00:00:00',
1303 1303
                         'Y-m-d H:i:s'
1304 1304
                     ),
1305 1305
                     EEM_Registration::instance()->convert_datetime_for_query(
1306 1306
                         'REG_date',
1307
-                        $now . ' 23:59:59',
1307
+                        $now.' 23:59:59',
1308 1308
                         'Y-m-d H:i:s'
1309 1309
                     ),
1310 1310
                 ),
@@ -1317,12 +1317,12 @@  discard block
 block discarded – undo
1317 1317
                 array(
1318 1318
                     EEM_Registration::instance()->convert_datetime_for_query(
1319 1319
                         'REG_date',
1320
-                        $current_year_and_month . '-01 00:00:00',
1320
+                        $current_year_and_month.'-01 00:00:00',
1321 1321
                         'Y-m-d H:i:s'
1322 1322
                     ),
1323 1323
                     EEM_Registration::instance()->convert_datetime_for_query(
1324 1324
                         'REG_date',
1325
-                        $current_year_and_month . '-' . $days_this_month . ' 23:59:59',
1325
+                        $current_year_and_month.'-'.$days_this_month.' 23:59:59',
1326 1326
                         'Y-m-d H:i:s'
1327 1327
                     ),
1328 1328
                 ),
@@ -1337,18 +1337,18 @@  discard block
 block discarded – undo
1337 1337
                 : '';
1338 1338
             //if there is not a month or year then we can't go further
1339 1339
             if ($month_requested && $year_requested) {
1340
-                $days_in_month     = date('t', strtotime($year_requested . '-' . $month_requested . '-' . '01'));
1340
+                $days_in_month     = date('t', strtotime($year_requested.'-'.$month_requested.'-'.'01'));
1341 1341
                 $where['REG_date'] = array(
1342 1342
                     'BETWEEN',
1343 1343
                     array(
1344 1344
                         EEM_Registration::instance()->convert_datetime_for_query(
1345 1345
                             'REG_date',
1346
-                            $year_requested . '-' . $month_requested . '-01 00:00:00',
1346
+                            $year_requested.'-'.$month_requested.'-01 00:00:00',
1347 1347
                             'Y-m-d H:i:s'
1348 1348
                         ),
1349 1349
                         EEM_Registration::instance()->convert_datetime_for_query(
1350 1350
                             'REG_date',
1351
-                            $year_requested . '-' . $month_requested . '-' . $days_in_month . ' 23:59:59',
1351
+                            $year_requested.'-'.$month_requested.'-'.$days_in_month.' 23:59:59',
1352 1352
                             'Y-m-d H:i:s'
1353 1353
                         ),
1354 1354
                     ),
@@ -1368,8 +1368,8 @@  discard block
 block discarded – undo
1368 1368
     protected function _add_search_to_where_conditions(array $request)
1369 1369
     {
1370 1370
         $where = array();
1371
-        if (! empty($request['s'])) {
1372
-            $search_string = '%' . sanitize_text_field($request['s']) . '%';
1371
+        if ( ! empty($request['s'])) {
1372
+            $search_string = '%'.sanitize_text_field($request['s']).'%';
1373 1373
             $where['OR*search_conditions'] = array(
1374 1374
                 'Event.EVT_name'                          => array('LIKE', $search_string),
1375 1375
                 'Event.EVT_desc'                          => array('LIKE', $search_string),
@@ -1487,7 +1487,7 @@  discard block
 block discarded – undo
1487 1487
             : $per_page;
1488 1488
 
1489 1489
         //-1 means return all results so get out if that's set.
1490
-        if ((int)$per_page === -1) {
1490
+        if ((int) $per_page === -1) {
1491 1491
             return array();
1492 1492
         }
1493 1493
         $per_page = absint($per_page);
@@ -1543,7 +1543,7 @@  discard block
 block discarded – undo
1543 1543
                 ),
1544 1544
                 REG_ADMIN_URL
1545 1545
             );
1546
-            $this->_template_args['filtered_transactions_link']  = EE_Admin_Page::add_query_args_and_nonce(
1546
+            $this->_template_args['filtered_transactions_link'] = EE_Admin_Page::add_query_args_and_nonce(
1547 1547
                 array(
1548 1548
                     'action' => 'default',
1549 1549
                     'EVT_ID' => $event_id,
@@ -1551,7 +1551,7 @@  discard block
 block discarded – undo
1551 1551
                 ),
1552 1552
                 admin_url('admin.php')
1553 1553
             );
1554
-            $this->_template_args['event_link']                  = EE_Admin_Page::add_query_args_and_nonce(
1554
+            $this->_template_args['event_link'] = EE_Admin_Page::add_query_args_and_nonce(
1555 1555
                 array(
1556 1556
                     'page'   => 'espresso_events',
1557 1557
                     'action' => 'edit',
@@ -1560,12 +1560,12 @@  discard block
 block discarded – undo
1560 1560
                 admin_url('admin.php')
1561 1561
             );
1562 1562
             //next and previous links
1563
-            $next_reg                                      = $this->_registration->next(
1563
+            $next_reg = $this->_registration->next(
1564 1564
                 null,
1565 1565
                 array(),
1566 1566
                 'REG_ID'
1567 1567
             );
1568
-            $this->_template_args['next_registration']     = $next_reg
1568
+            $this->_template_args['next_registration'] = $next_reg
1569 1569
                 ? $this->_next_link(
1570 1570
                     EE_Admin_Page::add_query_args_and_nonce(
1571 1571
                         array(
@@ -1577,7 +1577,7 @@  discard block
 block discarded – undo
1577 1577
                     'dashicons dashicons-arrow-right ee-icon-size-22'
1578 1578
                 )
1579 1579
                 : '';
1580
-            $previous_reg                                  = $this->_registration->previous(
1580
+            $previous_reg = $this->_registration->previous(
1581 1581
                 null,
1582 1582
                 array(),
1583 1583
                 'REG_ID'
@@ -1595,7 +1595,7 @@  discard block
 block discarded – undo
1595 1595
                 )
1596 1596
                 : '';
1597 1597
             // grab header
1598
-            $template_path                             = REG_TEMPLATE_PATH . 'reg_admin_details_header.template.php';
1598
+            $template_path                             = REG_TEMPLATE_PATH.'reg_admin_details_header.template.php';
1599 1599
             $this->_template_args['REG_ID']            = $this->_registration->ID();
1600 1600
             $this->_template_args['admin_page_header'] = EEH_Template::display_template(
1601 1601
                 $template_path,
@@ -1715,7 +1715,7 @@  discard block
 block discarded – undo
1715 1715
                             EEH_HTML::strong(
1716 1716
                                 $this->_registration->pretty_status(),
1717 1717
                                 '',
1718
-                                'status-' . $this->_registration->status_ID(),
1718
+                                'status-'.$this->_registration->status_ID(),
1719 1719
                                 'line-height: 1em; font-size: 1.5em; font-weight: bold;'
1720 1720
                             )
1721 1721
                         )
@@ -1795,11 +1795,11 @@  discard block
 block discarded – undo
1795 1795
     {
1796 1796
         if (isset($this->_req_data['reg_status_change_form'])) {
1797 1797
             $REG_IDs = isset($this->_req_data['reg_status_change_form']['REG_ID'])
1798
-                ? (array)$this->_req_data['reg_status_change_form']['REG_ID']
1798
+                ? (array) $this->_req_data['reg_status_change_form']['REG_ID']
1799 1799
                 : array();
1800 1800
         } else {
1801 1801
             $REG_IDs = isset($this->_req_data['_REG_ID'])
1802
-                ? (array)$this->_req_data['_REG_ID']
1802
+                ? (array) $this->_req_data['_REG_ID']
1803 1803
                 : array();
1804 1804
         }
1805 1805
         // sanitize $REG_IDs
@@ -1862,7 +1862,7 @@  discard block
 block discarded – undo
1862 1862
     {
1863 1863
         $success = false;
1864 1864
         // typecast $REG_IDs
1865
-        $REG_IDs = (array)$REG_IDs;
1865
+        $REG_IDs = (array) $REG_IDs;
1866 1866
         if ( ! empty($REG_IDs)) {
1867 1867
             $success = true;
1868 1868
             // set default status if none is passed
@@ -2012,7 +2012,7 @@  discard block
 block discarded – undo
2012 2012
             $action,
2013 2013
             $notify
2014 2014
         );
2015
-        $method = $action . '_registration';
2015
+        $method = $action.'_registration';
2016 2016
         if (method_exists($this, $method)) {
2017 2017
             $this->$method($notify);
2018 2018
         }
@@ -2130,7 +2130,7 @@  discard block
 block discarded – undo
2130 2130
             $filtered_line_item_tree,
2131 2131
             array('EE_Registration' => $this->_registration)
2132 2132
         );
2133
-        $attendee                                = $this->_registration->attendee();
2133
+        $attendee = $this->_registration->attendee();
2134 2134
         if (EE_Registry::instance()->CAP->current_user_can(
2135 2135
             'ee_read_transaction',
2136 2136
             'espresso_transactions_view_transaction'
@@ -2209,7 +2209,7 @@  discard block
 block discarded – undo
2209 2209
                 'Payment method response',
2210 2210
                 'event_espresso'
2211 2211
             );
2212
-            $this->_template_args['reg_details']['response_msg']['class']   = 'regular-text';
2212
+            $this->_template_args['reg_details']['response_msg']['class'] = 'regular-text';
2213 2213
         }
2214 2214
         $this->_template_args['reg_details']['registration_session']['value'] = $reg_details['registration_session'];
2215 2215
         $this->_template_args['reg_details']['registration_session']['label'] = esc_html__(
@@ -2237,7 +2237,7 @@  discard block
 block discarded – undo
2237 2237
         $this->_template_args['REG_ID']                                       = $this->_registration->ID();
2238 2238
         $this->_template_args['event_id']                                     = $this->_registration->event_ID();
2239 2239
         $template_path                                                        =
2240
-            REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_reg_details.template.php';
2240
+            REG_TEMPLATE_PATH.'reg_admin_details_main_meta_box_reg_details.template.php';
2241 2241
         echo EEH_Template::display_template($template_path, $this->_template_args, true);
2242 2242
     }
2243 2243
 
@@ -2266,7 +2266,7 @@  discard block
 block discarded – undo
2266 2266
             $this->_template_args['reg_questions_form_action'] = 'edit_registration';
2267 2267
             $this->_template_args['REG_ID']                    = $this->_registration->ID();
2268 2268
             $template_path                                     =
2269
-                REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_reg_questions.template.php';
2269
+                REG_TEMPLATE_PATH.'reg_admin_details_main_meta_box_reg_questions.template.php';
2270 2270
             echo EEH_Template::display_template($template_path, $this->_template_args, true);
2271 2271
         }
2272 2272
     }
@@ -2283,7 +2283,7 @@  discard block
 block discarded – undo
2283 2283
     public function form_before_question_group($output)
2284 2284
     {
2285 2285
         EE_Error::doing_it_wrong(
2286
-            __CLASS__ . '::' . __FUNCTION__,
2286
+            __CLASS__.'::'.__FUNCTION__,
2287 2287
             esc_html__(
2288 2288
                 'This method would have been protected but was used on a filter callback so needed to be public. Please discontinue usage as it will be removed soon.',
2289 2289
                 'event_espresso'
@@ -2308,7 +2308,7 @@  discard block
 block discarded – undo
2308 2308
     public function form_after_question_group($output)
2309 2309
     {
2310 2310
         EE_Error::doing_it_wrong(
2311
-            __CLASS__ . '::' . __FUNCTION__,
2311
+            __CLASS__.'::'.__FUNCTION__,
2312 2312
             esc_html__(
2313 2313
                 'This method would have been protected but was used on a filter callback so needed to be public. Please discontinue usage as it will be removed soon.',
2314 2314
                 'event_espresso'
@@ -2346,7 +2346,7 @@  discard block
 block discarded – undo
2346 2346
     public function form_form_field_label_wrap($label)
2347 2347
     {
2348 2348
         EE_Error::doing_it_wrong(
2349
-            __CLASS__ . '::' . __FUNCTION__,
2349
+            __CLASS__.'::'.__FUNCTION__,
2350 2350
             esc_html__(
2351 2351
                 'This method would have been protected but was used on a filter callback so needed to be public. Please discontinue usage as it will be removed soon.',
2352 2352
                 'event_espresso'
@@ -2356,7 +2356,7 @@  discard block
 block discarded – undo
2356 2356
         return '
2357 2357
 			<tr>
2358 2358
 				<th>
2359
-					' . $label . '
2359
+					' . $label.'
2360 2360
 				</th>';
2361 2361
     }
2362 2362
 
@@ -2372,7 +2372,7 @@  discard block
 block discarded – undo
2372 2372
     public function form_form_field_input__wrap($input)
2373 2373
     {
2374 2374
         EE_Error::doing_it_wrong(
2375
-            __CLASS__ . '::' . __FUNCTION__,
2375
+            __CLASS__.'::'.__FUNCTION__,
2376 2376
             esc_html__(
2377 2377
                 'This method would have been protected but was used on a filter callback so needed to be public. Please discontinue usage as it will be removed soon.',
2378 2378
                 'event_espresso'
@@ -2381,7 +2381,7 @@  discard block
 block discarded – undo
2381 2381
         );
2382 2382
         return '
2383 2383
 				<td class="reg-admin-attendee-questions-input-td disabled-input">
2384
-					' . $input . '
2384
+					' . $input.'
2385 2385
 				</td>
2386 2386
 			</tr>';
2387 2387
     }
@@ -2426,7 +2426,7 @@  discard block
 block discarded – undo
2426 2426
     protected function _get_reg_custom_questions_form($REG_ID)
2427 2427
     {
2428 2428
         if ( ! $this->_reg_custom_questions_form) {
2429
-            require_once(REG_ADMIN . 'form_sections' . DS . 'EE_Registration_Custom_Questions_Form.form.php');
2429
+            require_once(REG_ADMIN.'form_sections'.DS.'EE_Registration_Custom_Questions_Form.form.php');
2430 2430
             $this->_reg_custom_questions_form = new EE_Registration_Custom_Questions_Form(
2431 2431
                 EEM_Registration::instance()->get_one_by_ID($REG_ID)
2432 2432
             );
@@ -2462,7 +2462,7 @@  discard block
 block discarded – undo
2462 2462
         if ($form->is_valid()) {
2463 2463
             foreach ($form->subforms() as $question_group_id => $question_group_form) {
2464 2464
                 foreach ($question_group_form->inputs() as $question_id => $input) {
2465
-                    $where_conditions    = array(
2465
+                    $where_conditions = array(
2466 2466
                         'QST_ID' => $question_id,
2467 2467
                         'REG_ID' => $REG_ID,
2468 2468
                     );
@@ -2503,7 +2503,7 @@  discard block
 block discarded – undo
2503 2503
         $REG = EEM_Registration::instance();
2504 2504
         //get all other registrations on this transaction, and cache
2505 2505
         //the attendees for them so we don't have to run another query using force_join
2506
-        $registrations                           = $REG->get_all(array(
2506
+        $registrations = $REG->get_all(array(
2507 2507
             array(
2508 2508
                 'TXN_ID' => $this->_registration->transaction_ID(),
2509 2509
                 'REG_ID' => array('!=', $this->_registration->ID()),
@@ -2527,7 +2527,7 @@  discard block
 block discarded – undo
2527 2527
             $att_nmbr = 1;
2528 2528
             foreach ($registrations as $registration) {
2529 2529
                 /* @var $registration EE_Registration */
2530
-                $attendee                                                    = $registration->attendee()
2530
+                $attendee = $registration->attendee()
2531 2531
                     ? $registration->attendee()
2532 2532
                     : EEM_Attendee::instance()
2533 2533
                                   ->create_default_object();
@@ -2540,19 +2540,19 @@  discard block
 block discarded – undo
2540 2540
                     ', ',
2541 2541
                     $attendee->full_address_as_array()
2542 2542
                 );
2543
-                $this->_template_args['attendees'][$att_nmbr]['att_link']    = self::add_query_args_and_nonce(
2543
+                $this->_template_args['attendees'][$att_nmbr]['att_link'] = self::add_query_args_and_nonce(
2544 2544
                     array(
2545 2545
                         'action' => 'edit_attendee',
2546 2546
                         'post'   => $attendee->ID(),
2547 2547
                     ),
2548 2548
                     REG_ADMIN_URL
2549 2549
                 );
2550
-                $this->_template_args['attendees'][$att_nmbr]['event_name']  = $registration->event_obj()->name();
2550
+                $this->_template_args['attendees'][$att_nmbr]['event_name'] = $registration->event_obj()->name();
2551 2551
                 $att_nmbr++;
2552 2552
             }
2553 2553
             $this->_template_args['currency_sign'] = EE_Registry::instance()->CFG->currency->sign;
2554 2554
         }
2555
-        $template_path = REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_attendees.template.php';
2555
+        $template_path = REG_TEMPLATE_PATH.'reg_admin_details_main_meta_box_attendees.template.php';
2556 2556
         echo EEH_Template::display_template($template_path, $this->_template_args, true);
2557 2557
     }
2558 2558
 
@@ -2595,20 +2595,20 @@  discard block
 block discarded – undo
2595 2595
         $this->_template_args['phone']             = $attendee->phone();
2596 2596
         $this->_template_args['formatted_address'] = EEH_Address::format($attendee);
2597 2597
         //edit link
2598
-        $this->_template_args['att_edit_link']  = EE_Admin_Page::add_query_args_and_nonce(array(
2598
+        $this->_template_args['att_edit_link'] = EE_Admin_Page::add_query_args_and_nonce(array(
2599 2599
             'action' => 'edit_attendee',
2600 2600
             'post'   => $attendee->ID(),
2601 2601
         ), REG_ADMIN_URL);
2602 2602
         $this->_template_args['att_edit_label'] = esc_html__('View/Edit Contact', 'event_espresso');
2603 2603
         //create link
2604
-        $this->_template_args['create_link']  = $primary_registration instanceof EE_Registration
2604
+        $this->_template_args['create_link'] = $primary_registration instanceof EE_Registration
2605 2605
             ? EE_Admin_Page::add_query_args_and_nonce(array(
2606 2606
                 'action'  => 'duplicate_attendee',
2607 2607
                 '_REG_ID' => $this->_registration->ID(),
2608 2608
             ), REG_ADMIN_URL) : '';
2609 2609
         $this->_template_args['create_label'] = esc_html__('Create Contact', 'event_espresso');
2610 2610
         $this->_template_args['att_check']    = $att_check;
2611
-        $template_path                        = REG_TEMPLATE_PATH . 'reg_admin_details_side_meta_box_registrant.template.php';
2611
+        $template_path                        = REG_TEMPLATE_PATH.'reg_admin_details_side_meta_box_registrant.template.php';
2612 2612
         echo EEH_Template::display_template($template_path, $this->_template_args, true);
2613 2613
     }
2614 2614
 
@@ -2653,7 +2653,7 @@  discard block
 block discarded – undo
2653 2653
             /** @var EE_Registration $REG */
2654 2654
             $REG = EEM_Registration::instance()->get_one_by_ID($REG_ID);
2655 2655
             $payments = $REG->registration_payments();
2656
-            if (! empty($payments)) {
2656
+            if ( ! empty($payments)) {
2657 2657
                 $name = $REG->attendee() instanceof EE_Attendee
2658 2658
                     ? $REG->attendee()->full_name()
2659 2659
                     : esc_html__('Unknown Attendee', 'event_espresso');
@@ -2849,7 +2849,7 @@  discard block
 block discarded – undo
2849 2849
                 'action' => 'edit',
2850 2850
                 'post'   => $this->_reg_event->ID(),
2851 2851
             ), EVENTS_ADMIN_URL);
2852
-            $edit_event_lnk                     = '<a href="'
2852
+            $edit_event_lnk = '<a href="'
2853 2853
                                                   . $edit_event_url
2854 2854
                                                   . '" title="'
2855 2855
                                                   . esc_attr__('Edit ', 'event_espresso')
@@ -2867,7 +2867,7 @@  discard block
 block discarded – undo
2867 2867
         }
2868 2868
         // grab header
2869 2869
         $template_path                              =
2870
-            REG_TEMPLATE_PATH . 'reg_admin_register_new_attendee.template.php';
2870
+            REG_TEMPLATE_PATH.'reg_admin_register_new_attendee.template.php';
2871 2871
         $this->_template_args['admin_page_content'] = EEH_Template::display_template($template_path,
2872 2872
             $this->_template_args, true);
2873 2873
         //$this->_set_publish_post_box_vars( NULL, FALSE, FALSE, NULL, FALSE );
@@ -2905,7 +2905,7 @@  discard block
 block discarded – undo
2905 2905
                 '</b>'
2906 2906
             );
2907 2907
             return '
2908
-	<div id="ee-add-reg-back-button-dv"><p>' . $warning_msg . '</p></div>
2908
+	<div id="ee-add-reg-back-button-dv"><p>' . $warning_msg.'</p></div>
2909 2909
 	<script >
2910 2910
 		// WHOAH !!! it appears that someone is using the back button from the Transaction admin page
2911 2911
 		// after just adding a new registration... we gotta try to put a stop to that !!!
@@ -2973,7 +2973,7 @@  discard block
 block discarded – undo
2973 2973
         //we come back to the process_registration_step route.
2974 2974
         $this->_set_add_edit_form_tags('process_reg_step', $hidden_fields);
2975 2975
         return EEH_Template::display_template(
2976
-            REG_TEMPLATE_PATH . 'reg_admin_register_new_attendee_step_content.template.php',
2976
+            REG_TEMPLATE_PATH.'reg_admin_register_new_attendee_step_content.template.php',
2977 2977
             $template_args,
2978 2978
             true
2979 2979
         );
@@ -2995,7 +2995,7 @@  discard block
 block discarded – undo
2995 2995
         if (is_object($this->_reg_event)) {
2996 2996
             return true;
2997 2997
         }
2998
-        $EVT_ID = (! empty($this->_req_data['event_id'])) ? absint($this->_req_data['event_id']) : false;
2998
+        $EVT_ID = ( ! empty($this->_req_data['event_id'])) ? absint($this->_req_data['event_id']) : false;
2999 2999
         if ( ! $EVT_ID) {
3000 3000
             return false;
3001 3001
         }
@@ -3065,7 +3065,7 @@  discard block
 block discarded – undo
3065 3065
                 }
3066 3066
                 break;
3067 3067
             case 'questions' :
3068
-                if (! isset(
3068
+                if ( ! isset(
3069 3069
                     $this->_req_data['txn_reg_status_change'],
3070 3070
                     $this->_req_data['txn_reg_status_change']['send_notifications'])
3071 3071
                 ) {
@@ -3185,7 +3185,7 @@  discard block
 block discarded – undo
3185 3185
     public function get_attendees($per_page, $count = false, $trash = false)
3186 3186
     {
3187 3187
         do_action('AHEE_log', __FILE__, __FUNCTION__, '');
3188
-        require_once(REG_ADMIN . 'EE_Attendee_Contact_List_Table.class.php');
3188
+        require_once(REG_ADMIN.'EE_Attendee_Contact_List_Table.class.php');
3189 3189
         $ATT_MDL                    = EEM_Attendee::instance();
3190 3190
         $this->_req_data['orderby'] = ! empty($this->_req_data['orderby']) ? $this->_req_data['orderby'] : '';
3191 3191
         switch ($this->_req_data['orderby']) {
@@ -3222,7 +3222,7 @@  discard block
 block discarded – undo
3222 3222
             : $per_page;
3223 3223
         $_where       = array();
3224 3224
         if ( ! empty($this->_req_data['s'])) {
3225
-            $sstr         = '%' . $this->_req_data['s'] . '%';
3225
+            $sstr         = '%'.$this->_req_data['s'].'%';
3226 3226
             $_where['OR'] = array(
3227 3227
                 'Registration.Event.EVT_name'       => array('LIKE', $sstr),
3228 3228
                 'Registration.Event.EVT_desc'       => array('LIKE', $sstr),
@@ -3298,9 +3298,9 @@  discard block
 block discarded – undo
3298 3298
      *                                                     the query parameters from the request
3299 3299
      * @return void ends the request with a redirect or download
3300 3300
      */
3301
-    public function _registrations_report_base( $method_name_for_getting_query_params )
3301
+    public function _registrations_report_base($method_name_for_getting_query_params)
3302 3302
     {
3303
-        if (! defined('EE_USE_OLD_CSV_REPORT_CLASS')) {
3303
+        if ( ! defined('EE_USE_OLD_CSV_REPORT_CLASS')) {
3304 3304
             wp_redirect(EE_Admin_Page::add_query_args_and_nonce(
3305 3305
                 array(
3306 3306
                     'page'        => 'espresso_batch',
@@ -3309,7 +3309,7 @@  discard block
 block discarded – undo
3309 3309
                     'filters'     => urlencode(
3310 3310
                         serialize(
3311 3311
                             call_user_func(
3312
-                                array( $this, $method_name_for_getting_query_params ),
3312
+                                array($this, $method_name_for_getting_query_params),
3313 3313
                                 EEH_Array::is_set(
3314 3314
                                     $this->_req_data,
3315 3315
                                     'filters',
@@ -3329,8 +3329,8 @@  discard block
 block discarded – undo
3329 3329
                 'EVT_ID' => isset($this->_req_data['EVT_ID']) ? $this->_req_data['EVT_ID'] : null,
3330 3330
             );
3331 3331
             $this->_req_data = array_merge($this->_req_data, $new_request_args);
3332
-            if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
3333
-                require_once(EE_CLASSES . 'EE_Export.class.php');
3332
+            if (is_readable(EE_CLASSES.'EE_Export.class.php')) {
3333
+                require_once(EE_CLASSES.'EE_Export.class.php');
3334 3334
                 $EE_Export = EE_Export::instance($this->_req_data);
3335 3335
                 $EE_Export->export();
3336 3336
             }
@@ -3351,8 +3351,8 @@  discard block
 block discarded – undo
3351 3351
 
3352 3352
     public function _contact_list_export()
3353 3353
     {
3354
-        if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
3355
-            require_once(EE_CLASSES . 'EE_Export.class.php');
3354
+        if (is_readable(EE_CLASSES.'EE_Export.class.php')) {
3355
+            require_once(EE_CLASSES.'EE_Export.class.php');
3356 3356
             $EE_Export = EE_Export::instance($this->_req_data);
3357 3357
             $EE_Export->export_attendees();
3358 3358
         }
@@ -3369,8 +3369,8 @@  discard block
 block discarded – undo
3369 3369
                 'return_url'  => urlencode($this->_req_data['return_url']),
3370 3370
             )));
3371 3371
         } else {
3372
-            if (is_readable(EE_CLASSES . 'EE_Export.class.php')) {
3373
-                require_once(EE_CLASSES . 'EE_Export.class.php');
3372
+            if (is_readable(EE_CLASSES.'EE_Export.class.php')) {
3373
+                require_once(EE_CLASSES.'EE_Export.class.php');
3374 3374
                 $EE_Export = EE_Export::instance($this->_req_data);
3375 3375
                 $EE_Export->report_attendees();
3376 3376
             }
@@ -3452,7 +3452,7 @@  discard block
 block discarded – undo
3452 3452
             $updated_fields = array(
3453 3453
                 'ATT_fname'     => $this->_req_data['ATT_fname'],
3454 3454
                 'ATT_lname'     => $this->_req_data['ATT_lname'],
3455
-                'ATT_full_name' => $this->_req_data['ATT_fname'] . ' ' . $this->_req_data['ATT_lname'],
3455
+                'ATT_full_name' => $this->_req_data['ATT_fname'].' '.$this->_req_data['ATT_lname'],
3456 3456
                 'ATT_address'   => isset($this->_req_data['ATT_address']) ? $this->_req_data['ATT_address'] : '',
3457 3457
                 'ATT_address2'  => isset($this->_req_data['ATT_address2']) ? $this->_req_data['ATT_address2'] : '',
3458 3458
                 'ATT_city'      => isset($this->_req_data['ATT_city']) ? $this->_req_data['ATT_city'] : '',
@@ -3670,8 +3670,8 @@  discard block
 block discarded – undo
3670 3670
                 )
3671 3671
             )
3672 3672
         );
3673
-        $template                             =
3674
-            REG_TEMPLATE_PATH . 'attendee_address_details_metabox_content.template.php';
3673
+        $template =
3674
+            REG_TEMPLATE_PATH.'attendee_address_details_metabox_content.template.php';
3675 3675
         EEH_Template::display_template($template, $this->_template_args);
3676 3676
     }
3677 3677
 
@@ -3690,7 +3690,7 @@  discard block
 block discarded – undo
3690 3690
         $this->_template_args['attendee']      = $this->_cpt_model_obj;
3691 3691
         $this->_template_args['registrations'] = $this->_cpt_model_obj->get_many_related('Registration');
3692 3692
         $template                              =
3693
-            REG_TEMPLATE_PATH . 'attendee_registrations_main_meta_box.template.php';
3693
+            REG_TEMPLATE_PATH.'attendee_registrations_main_meta_box.template.php';
3694 3694
         EEH_Template::display_template($template, $this->_template_args);
3695 3695
     }
3696 3696
 
@@ -3705,7 +3705,7 @@  discard block
 block discarded – undo
3705 3705
     public function after_title_form_fields($post)
3706 3706
     {
3707 3707
         if ($post->post_type == 'espresso_attendees') {
3708
-            $template                  = REG_TEMPLATE_PATH . 'attendee_details_after_title_form_fields.template.php';
3708
+            $template                  = REG_TEMPLATE_PATH.'attendee_details_after_title_form_fields.template.php';
3709 3709
             $template_args['attendee'] = $this->_cpt_model_obj;
3710 3710
             EEH_Template::display_template($template, $template_args);
3711 3711
         }
Please login to merge, or discard this patch.
core/EE_Dependency_Map.core.php 2 patches
Indentation   +792 added lines, -792 removed lines patch added patch discarded remove patch
@@ -5,7 +5,7 @@  discard block
 block discarded – undo
5 5
 use EventEspresso\core\services\loaders\LoaderInterface;
6 6
 
7 7
 if (! defined('EVENT_ESPRESSO_VERSION')) {
8
-    exit('No direct script access allowed');
8
+	exit('No direct script access allowed');
9 9
 }
10 10
 
11 11
 
@@ -22,797 +22,797 @@  discard block
 block discarded – undo
22 22
 class EE_Dependency_Map
23 23
 {
24 24
 
25
-    /**
26
-     * This means that the requested class dependency is not present in the dependency map
27
-     */
28
-    const not_registered = 0;
29
-
30
-    /**
31
-     * This instructs class loaders to ALWAYS return a newly instantiated object for the requested class.
32
-     */
33
-    const load_new_object = 1;
34
-
35
-    /**
36
-     * This instructs class loaders to return a previously instantiated and cached object for the requested class.
37
-     * IF a previously instantiated object does not exist, a new one will be created and added to the cache.
38
-     */
39
-    const load_from_cache = 2;
40
-
41
-    /**
42
-     * When registering a dependency,
43
-     * this indicates to keep any existing dependencies that already exist,
44
-     * and simply discard any new dependencies declared in the incoming data
45
-     */
46
-    const KEEP_EXISTING_DEPENDENCIES = 0;
47
-
48
-    /**
49
-     * When registering a dependency,
50
-     * this indicates to overwrite any existing dependencies that already exist using the incoming data
51
-     */
52
-    const OVERWRITE_DEPENDENCIES = 1;
53
-
54
-
55
-
56
-    /**
57
-     * @type EE_Dependency_Map $_instance
58
-     */
59
-    protected static $_instance;
60
-
61
-    /**
62
-     * @type EE_Request $request
63
-     */
64
-    protected $_request;
65
-
66
-    /**
67
-     * @type EE_Response $response
68
-     */
69
-    protected $_response;
70
-
71
-    /**
72
-     * @type LoaderInterface $loader
73
-     */
74
-    protected $loader;
75
-
76
-    /**
77
-     * @type array $_dependency_map
78
-     */
79
-    protected $_dependency_map = array();
80
-
81
-    /**
82
-     * @type array $_class_loaders
83
-     */
84
-    protected $_class_loaders = array();
85
-
86
-    /**
87
-     * @type array $_aliases
88
-     */
89
-    protected $_aliases = array();
90
-
91
-
92
-
93
-    /**
94
-     * EE_Dependency_Map constructor.
95
-     *
96
-     * @param EE_Request  $request
97
-     * @param EE_Response $response
98
-     */
99
-    protected function __construct(EE_Request $request, EE_Response $response)
100
-    {
101
-        $this->_request = $request;
102
-        $this->_response = $response;
103
-        add_action('EE_Load_Espresso_Core__handle_request__initialize_core_loading', array($this, 'initialize'));
104
-        do_action('EE_Dependency_Map____construct');
105
-    }
106
-
107
-
108
-
109
-    /**
110
-     * @throws InvalidDataTypeException
111
-     * @throws InvalidInterfaceException
112
-     * @throws InvalidArgumentException
113
-     */
114
-    public function initialize()
115
-    {
116
-        $this->_register_core_dependencies();
117
-        $this->_register_core_class_loaders();
118
-        $this->_register_core_aliases();
119
-    }
120
-
121
-
122
-
123
-    /**
124
-     * @singleton method used to instantiate class object
125
-     * @access    public
126
-     * @param EE_Request  $request
127
-     * @param EE_Response $response
128
-     * @return EE_Dependency_Map
129
-     */
130
-    public static function instance(EE_Request $request = null, EE_Response $response = null)
131
-    {
132
-        // check if class object is instantiated, and instantiated properly
133
-        if (! self::$_instance instanceof EE_Dependency_Map) {
134
-            self::$_instance = new EE_Dependency_Map($request, $response);
135
-        }
136
-        return self::$_instance;
137
-    }
138
-
139
-
140
-
141
-    /**
142
-     * @param LoaderInterface $loader
143
-     */
144
-    public function setLoader(LoaderInterface $loader)
145
-    {
146
-        $this->loader = $loader;
147
-    }
148
-
149
-
150
-
151
-    /**
152
-     * @param string $class
153
-     * @param array  $dependencies
154
-     * @param int    $overwrite
155
-     * @return bool
156
-     */
157
-    public static function register_dependencies(
158
-        $class,
159
-        array $dependencies,
160
-        $overwrite = EE_Dependency_Map::KEEP_EXISTING_DEPENDENCIES
161
-    ) {
162
-        return self::$_instance->registerDependencies($class, $dependencies, $overwrite);
163
-    }
164
-
165
-
166
-
167
-    /**
168
-     * Assigns an array of class names and corresponding load sources (new or cached)
169
-     * to the class specified by the first parameter.
170
-     * IMPORTANT !!!
171
-     * The order of elements in the incoming $dependencies array MUST match
172
-     * the order of the constructor parameters for the class in question.
173
-     * This is especially important when overriding any existing dependencies that are registered.
174
-     * the third parameter controls whether any duplicate dependencies are overwritten or not.
175
-     *
176
-     * @param string $class
177
-     * @param array  $dependencies
178
-     * @param int    $overwrite
179
-     * @return bool
180
-     */
181
-    public function registerDependencies(
182
-        $class,
183
-        array $dependencies,
184
-        $overwrite = EE_Dependency_Map::KEEP_EXISTING_DEPENDENCIES
185
-    ) {
186
-        $class = trim($class, '\\');
187
-        $registered = false;
188
-        if (empty(self::$_instance->_dependency_map[ $class ])) {
189
-            self::$_instance->_dependency_map[ $class ] = array();
190
-        }
191
-        // we need to make sure that any aliases used when registering a dependency
192
-        // get resolved to the correct class name
193
-        foreach ((array)$dependencies as $dependency => $load_source) {
194
-            $alias = self::$_instance->get_alias($dependency);
195
-            if (
196
-                $overwrite === EE_Dependency_Map::OVERWRITE_DEPENDENCIES
197
-                || ! isset(self::$_instance->_dependency_map[ $class ][ $alias ])
198
-            ) {
199
-                unset($dependencies[$dependency]);
200
-                $dependencies[$alias] = $load_source;
201
-                $registered = true;
202
-            }
203
-        }
204
-        // now add our two lists of dependencies together.
205
-        // using Union (+=) favours the arrays in precedence from left to right,
206
-        // so $dependencies is NOT overwritten because it is listed first
207
-        // ie: with A = B + C, entries in B take precedence over duplicate entries in C
208
-        // Union is way faster than array_merge() but should be used with caution...
209
-        // especially with numerically indexed arrays
210
-        $dependencies += self::$_instance->_dependency_map[ $class ];
211
-        // now we need to ensure that the resulting dependencies
212
-        // array only has the entries that are required for the class
213
-        // so first count how many dependencies were originally registered for the class
214
-        $dependency_count = count(self::$_instance->_dependency_map[ $class ]);
215
-        // if that count is non-zero (meaning dependencies were already registered)
216
-        self::$_instance->_dependency_map[ $class ] = $dependency_count
217
-            // then truncate the  final array to match that count
218
-            ? array_slice($dependencies, 0, $dependency_count)
219
-            // otherwise just take the incoming array because nothing previously existed
220
-            : $dependencies;
221
-        return $registered;
222
-    }
223
-
224
-
225
-
226
-    /**
227
-     * @param string $class_name
228
-     * @param string $loader
229
-     * @return bool
230
-     * @throws DomainException
231
-     */
232
-    public static function register_class_loader($class_name, $loader = 'load_core')
233
-    {
234
-        if (! $loader instanceof Closure && strpos($class_name, '\\') !== false) {
235
-            throw new DomainException(
236
-                esc_html__('Don\'t use class loaders for FQCNs.', 'event_espresso')
237
-            );
238
-        }
239
-        // check that loader is callable or method starts with "load_" and exists in EE_Registry
240
-        if (
241
-            ! is_callable($loader)
242
-            && (
243
-                strpos($loader, 'load_') !== 0
244
-                || ! method_exists('EE_Registry', $loader)
245
-            )
246
-        ) {
247
-            throw new DomainException(
248
-                sprintf(
249
-                    esc_html__(
250
-                        '"%1$s" is not a valid loader method on EE_Registry.',
251
-                        'event_espresso'
252
-                    ),
253
-                    $loader
254
-                )
255
-            );
256
-        }
257
-        $class_name = self::$_instance->get_alias($class_name);
258
-        if (! isset(self::$_instance->_class_loaders[$class_name])) {
259
-            self::$_instance->_class_loaders[$class_name] = $loader;
260
-            return true;
261
-        }
262
-        return false;
263
-    }
264
-
265
-
266
-
267
-    /**
268
-     * @return array
269
-     */
270
-    public function dependency_map()
271
-    {
272
-        return $this->_dependency_map;
273
-    }
274
-
275
-
276
-
277
-    /**
278
-     * returns TRUE if dependency map contains a listing for the provided class name
279
-     *
280
-     * @param string $class_name
281
-     * @return boolean
282
-     */
283
-    public function has($class_name = '')
284
-    {
285
-        // all legacy models have the same dependencies
286
-        if (strpos($class_name, 'EEM_') === 0) {
287
-            $class_name = 'LEGACY_MODELS';
288
-        }
289
-        return isset($this->_dependency_map[$class_name]) ? true : false;
290
-    }
291
-
292
-
293
-
294
-    /**
295
-     * returns TRUE if dependency map contains a listing for the provided class name AND dependency
296
-     *
297
-     * @param string $class_name
298
-     * @param string $dependency
299
-     * @return bool
300
-     */
301
-    public function has_dependency_for_class($class_name = '', $dependency = '')
302
-    {
303
-        // all legacy models have the same dependencies
304
-        if (strpos($class_name, 'EEM_') === 0) {
305
-            $class_name = 'LEGACY_MODELS';
306
-        }
307
-        $dependency = $this->get_alias($dependency);
308
-        return isset($this->_dependency_map[$class_name], $this->_dependency_map[$class_name][$dependency])
309
-            ? true
310
-            : false;
311
-    }
312
-
313
-
314
-
315
-    /**
316
-     * returns loading strategy for whether a previously cached dependency should be loaded or a new instance returned
317
-     *
318
-     * @param string $class_name
319
-     * @param string $dependency
320
-     * @return int
321
-     */
322
-    public function loading_strategy_for_class_dependency($class_name = '', $dependency = '')
323
-    {
324
-        // all legacy models have the same dependencies
325
-        if (strpos($class_name, 'EEM_') === 0) {
326
-            $class_name = 'LEGACY_MODELS';
327
-        }
328
-        $dependency = $this->get_alias($dependency);
329
-        return $this->has_dependency_for_class($class_name, $dependency)
330
-            ? $this->_dependency_map[$class_name][$dependency]
331
-            : EE_Dependency_Map::not_registered;
332
-    }
333
-
334
-
335
-
336
-    /**
337
-     * @param string $class_name
338
-     * @return string | Closure
339
-     */
340
-    public function class_loader($class_name)
341
-    {
342
-        // all legacy models use load_model()
343
-        if(strpos($class_name, 'EEM_') === 0){
344
-            return 'load_model';
345
-        }
346
-        $class_name = $this->get_alias($class_name);
347
-        return isset($this->_class_loaders[$class_name]) ? $this->_class_loaders[$class_name] : '';
348
-    }
349
-
350
-
351
-
352
-    /**
353
-     * @return array
354
-     */
355
-    public function class_loaders()
356
-    {
357
-        return $this->_class_loaders;
358
-    }
359
-
360
-
361
-
362
-    /**
363
-     * adds an alias for a classname
364
-     *
365
-     * @param string $class_name the class name that should be used (concrete class to replace interface)
366
-     * @param string $alias      the class name that would be type hinted for (abstract parent or interface)
367
-     * @param string $for_class  the class that has the dependency (is type hinting for the interface)
368
-     */
369
-    public function add_alias($class_name, $alias, $for_class = '')
370
-    {
371
-        if ($for_class !== '') {
372
-            if (! isset($this->_aliases[$for_class])) {
373
-                $this->_aliases[$for_class] = array();
374
-            }
375
-            $this->_aliases[$for_class][$class_name] = $alias;
376
-        }
377
-        $this->_aliases[$class_name] = $alias;
378
-    }
379
-
380
-
381
-
382
-    /**
383
-     * returns TRUE if the provided class name has an alias
384
-     *
385
-     * @param string $class_name
386
-     * @param string $for_class
387
-     * @return bool
388
-     */
389
-    public function has_alias($class_name = '', $for_class = '')
390
-    {
391
-        return isset($this->_aliases[$for_class], $this->_aliases[$for_class][$class_name])
392
-               || (
393
-                   isset($this->_aliases[$class_name])
394
-                   && ! is_array($this->_aliases[$class_name])
395
-               );
396
-    }
397
-
398
-
399
-
400
-    /**
401
-     * returns alias for class name if one exists, otherwise returns the original classname
402
-     * functions recursively, so that multiple aliases can be used to drill down to a classname
403
-     *  for example:
404
-     *      if the following two entries were added to the _aliases array:
405
-     *          array(
406
-     *              'interface_alias'           => 'some\namespace\interface'
407
-     *              'some\namespace\interface'  => 'some\namespace\classname'
408
-     *          )
409
-     *      then one could use EE_Registry::instance()->create( 'interface_alias' )
410
-     *      to load an instance of 'some\namespace\classname'
411
-     *
412
-     * @param string $class_name
413
-     * @param string $for_class
414
-     * @return string
415
-     */
416
-    public function get_alias($class_name = '', $for_class = '')
417
-    {
418
-        if (! $this->has_alias($class_name, $for_class)) {
419
-            return $class_name;
420
-        }
421
-        if ($for_class !== '' && isset($this->_aliases[ $for_class ][ $class_name ])) {
422
-            return $this->get_alias($this->_aliases[$for_class][$class_name], $for_class);
423
-        }
424
-        return $this->get_alias($this->_aliases[$class_name]);
425
-    }
426
-
427
-
428
-
429
-    /**
430
-     * Registers the core dependencies and whether a previously instantiated object should be loaded from the cache,
431
-     * if one exists, or whether a new object should be generated every time the requested class is loaded.
432
-     * This is done by using the following class constants:
433
-     *        EE_Dependency_Map::load_from_cache - loads previously instantiated object
434
-     *        EE_Dependency_Map::load_new_object - generates a new object every time
435
-     */
436
-    protected function _register_core_dependencies()
437
-    {
438
-        $this->_dependency_map = array(
439
-            'EE_Request_Handler'                                                                                          => array(
440
-                'EE_Request' => EE_Dependency_Map::load_from_cache,
441
-            ),
442
-            'EE_System'                                                                                                   => array(
443
-                'EE_Registry'                                => EE_Dependency_Map::load_from_cache,
444
-                'EventEspresso\core\services\loaders\Loader' => EE_Dependency_Map::load_from_cache,
445
-                'EE_Capabilities'                            => EE_Dependency_Map::load_from_cache,
446
-                'EE_Request'                                 => EE_Dependency_Map::load_from_cache,
447
-                'EE_Maintenance_Mode'                        => EE_Dependency_Map::load_from_cache,
448
-            ),
449
-            'EE_Session'                                                                                                  => array(
450
-                'EventEspresso\core\services\cache\TransientCacheStorage' => EE_Dependency_Map::load_from_cache,
451
-                'EE_Encryption'                                           => EE_Dependency_Map::load_from_cache,
452
-            ),
453
-            'EE_Cart'                                                                                                     => array(
454
-                'EE_Session' => EE_Dependency_Map::load_from_cache,
455
-            ),
456
-            'EE_Front_Controller'                                                                                         => array(
457
-                'EE_Registry'              => EE_Dependency_Map::load_from_cache,
458
-                'EE_Request_Handler'       => EE_Dependency_Map::load_from_cache,
459
-                'EE_Module_Request_Router' => EE_Dependency_Map::load_from_cache,
460
-            ),
461
-            'EE_Messenger_Collection_Loader'                                                                              => array(
462
-                'EE_Messenger_Collection' => EE_Dependency_Map::load_new_object,
463
-            ),
464
-            'EE_Message_Type_Collection_Loader'                                                                           => array(
465
-                'EE_Message_Type_Collection' => EE_Dependency_Map::load_new_object,
466
-            ),
467
-            'EE_Message_Resource_Manager'                                                                                 => array(
468
-                'EE_Messenger_Collection_Loader'    => EE_Dependency_Map::load_new_object,
469
-                'EE_Message_Type_Collection_Loader' => EE_Dependency_Map::load_new_object,
470
-                'EEM_Message_Template_Group'        => EE_Dependency_Map::load_from_cache,
471
-            ),
472
-            'EE_Message_Factory'                                                                                          => array(
473
-                'EE_Message_Resource_Manager' => EE_Dependency_Map::load_from_cache,
474
-            ),
475
-            'EE_messages'                                                                                                 => array(
476
-                'EE_Message_Resource_Manager' => EE_Dependency_Map::load_from_cache,
477
-            ),
478
-            'EE_Messages_Generator'                                                                                       => array(
479
-                'EE_Messages_Queue'                    => EE_Dependency_Map::load_new_object,
480
-                'EE_Messages_Data_Handler_Collection'  => EE_Dependency_Map::load_new_object,
481
-                'EE_Message_Template_Group_Collection' => EE_Dependency_Map::load_new_object,
482
-                'EEH_Parse_Shortcodes'                 => EE_Dependency_Map::load_from_cache,
483
-            ),
484
-            'EE_Messages_Processor'                                                                                       => array(
485
-                'EE_Message_Resource_Manager' => EE_Dependency_Map::load_from_cache,
486
-            ),
487
-            'EE_Messages_Queue'                                                                                           => array(
488
-                'EE_Message_Repository' => EE_Dependency_Map::load_new_object,
489
-            ),
490
-            'EE_Messages_Template_Defaults'                                                                               => array(
491
-                'EEM_Message_Template_Group' => EE_Dependency_Map::load_from_cache,
492
-                'EEM_Message_Template'       => EE_Dependency_Map::load_from_cache,
493
-            ),
494
-            'EE_Message_To_Generate_From_Request'                                                                         => array(
495
-                'EE_Message_Resource_Manager' => EE_Dependency_Map::load_from_cache,
496
-                'EE_Request_Handler'          => EE_Dependency_Map::load_from_cache,
497
-            ),
498
-            'EventEspresso\core\services\commands\CommandBus'                                                             => array(
499
-                'EventEspresso\core\services\commands\CommandHandlerManager' => EE_Dependency_Map::load_from_cache,
500
-            ),
501
-            'EventEspresso\services\commands\CommandHandler'                                                              => array(
502
-                'EE_Registry'         => EE_Dependency_Map::load_from_cache,
503
-                'CommandBusInterface' => EE_Dependency_Map::load_from_cache,
504
-            ),
505
-            'EventEspresso\core\services\commands\CommandHandlerManager'                                                  => array(
506
-                'EventEspresso\core\services\loaders\Loader' => EE_Dependency_Map::load_from_cache,
507
-            ),
508
-            'EventEspresso\core\services\commands\CompositeCommandHandler'                                                => array(
509
-                'EventEspresso\core\services\commands\CommandBus'     => EE_Dependency_Map::load_from_cache,
510
-                'EventEspresso\core\services\commands\CommandFactory' => EE_Dependency_Map::load_from_cache,
511
-            ),
512
-            'EventEspresso\core\services\commands\CommandFactory'                                                         => array(
513
-                'EventEspresso\core\services\loaders\Loader' => EE_Dependency_Map::load_from_cache,
514
-            ),
515
-            'EventEspresso\core\services\commands\middleware\CapChecker'                                                  => array(
516
-                'EventEspresso\core\domain\services\capabilities\CapabilitiesChecker' => EE_Dependency_Map::load_from_cache,
517
-            ),
518
-            'EventEspresso\core\domain\services\capabilities\CapabilitiesChecker'                                         => array(
519
-                'EE_Capabilities' => EE_Dependency_Map::load_from_cache,
520
-            ),
521
-            'EventEspresso\core\domain\services\capabilities\RegistrationsCapChecker'                                     => array(
522
-                'EE_Capabilities' => EE_Dependency_Map::load_from_cache,
523
-            ),
524
-            'EventEspresso\core\services\commands\registration\CreateRegistrationCommandHandler'                          => array(
525
-                'EventEspresso\core\domain\services\registration\CreateRegistrationService' => EE_Dependency_Map::load_from_cache,
526
-            ),
527
-            'EventEspresso\core\services\commands\registration\CopyRegistrationDetailsCommandHandler'                     => array(
528
-                'EventEspresso\core\domain\services\registration\CopyRegistrationService' => EE_Dependency_Map::load_from_cache,
529
-            ),
530
-            'EventEspresso\core\services\commands\registration\CopyRegistrationPaymentsCommandHandler'                    => array(
531
-                'EventEspresso\core\domain\services\registration\CopyRegistrationService' => EE_Dependency_Map::load_from_cache,
532
-            ),
533
-            'EventEspresso\core\services\commands\registration\CancelRegistrationAndTicketLineItemCommandHandler'         => array(
534
-                'EventEspresso\core\domain\services\registration\CancelTicketLineItemService' => EE_Dependency_Map::load_from_cache,
535
-            ),
536
-            'EventEspresso\core\services\commands\registration\UpdateRegistrationAndTransactionAfterChangeCommandHandler' => array(
537
-                'EventEspresso\core\domain\services\registration\UpdateRegistrationService' => EE_Dependency_Map::load_from_cache,
538
-            ),
539
-            'EventEspresso\core\services\commands\ticket\CreateTicketLineItemCommandHandler'                              => array(
540
-                'EventEspresso\core\domain\services\ticket\CreateTicketLineItemService' => EE_Dependency_Map::load_from_cache,
541
-            ),
542
-            'EventEspresso\core\services\commands\ticket\CancelTicketLineItemCommandHandler'                              => array(
543
-                'EventEspresso\core\domain\services\ticket\CancelTicketLineItemService' => EE_Dependency_Map::load_from_cache,
544
-            ),
545
-            'EventEspresso\core\domain\services\registration\CancelRegistrationService'                                   => array(
546
-                'EventEspresso\core\domain\services\ticket\CancelTicketLineItemService' => EE_Dependency_Map::load_from_cache,
547
-            ),
548
-            'EventEspresso\core\services\commands\attendee\CreateAttendeeCommandHandler'                                  => array(
549
-                'EEM_Attendee' => EE_Dependency_Map::load_from_cache,
550
-            ),
551
-            'EventEspresso\core\services\database\TableManager'                                                           => array(
552
-                'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
553
-            ),
554
-            'EE_Data_Migration_Class_Base'                                                                                => array(
555
-                'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
556
-                'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
557
-            ),
558
-            'EE_DMS_Core_4_1_0'                                                                                           => array(
559
-                'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
560
-                'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
561
-            ),
562
-            'EE_DMS_Core_4_2_0'                                                                                           => array(
563
-                'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
564
-                'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
565
-            ),
566
-            'EE_DMS_Core_4_3_0'                                                                                           => array(
567
-                'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
568
-                'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
569
-            ),
570
-            'EE_DMS_Core_4_4_0'                                                                                           => array(
571
-                'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
572
-                'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
573
-            ),
574
-            'EE_DMS_Core_4_5_0'                                                                                           => array(
575
-                'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
576
-                'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
577
-            ),
578
-            'EE_DMS_Core_4_6_0'                                                                                           => array(
579
-                'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
580
-                'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
581
-            ),
582
-            'EE_DMS_Core_4_7_0'                                                                                           => array(
583
-                'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
584
-                'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
585
-            ),
586
-            'EE_DMS_Core_4_8_0'                                                                                           => array(
587
-                'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
588
-                'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
589
-            ),
590
-            'EE_DMS_Core_4_9_0'                                                                                           => array(
591
-                'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
592
-                'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
593
-            ),
594
-            'EventEspresso\core\services\assets\Registry'                                                                 => array(
595
-                'EE_Template_Config' => EE_Dependency_Map::load_from_cache,
596
-                'EE_Currency_Config' => EE_Dependency_Map::load_from_cache,
597
-            ),
598
-            'EventEspresso\core\domain\entities\shortcodes\EspressoCancelled'                                             => array(
599
-                'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
600
-            ),
601
-            'EventEspresso\core\domain\entities\shortcodes\EspressoCheckout'                                              => array(
602
-                'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
603
-            ),
604
-            'EventEspresso\core\domain\entities\shortcodes\EspressoEventAttendees'                                        => array(
605
-                'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
606
-            ),
607
-            'EventEspresso\core\domain\entities\shortcodes\EspressoEvents'                                                => array(
608
-                'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
609
-            ),
610
-            'EventEspresso\core\domain\entities\shortcodes\EspressoThankYou'                                              => array(
611
-                'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
612
-            ),
613
-            'EventEspresso\core\domain\entities\shortcodes\EspressoTicketSelector'                                        => array(
614
-                'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
615
-            ),
616
-            'EventEspresso\core\domain\entities\shortcodes\EspressoTxnPage'                                               => array(
617
-                'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
618
-            ),
619
-            'EventEspresso\core\services\cache\BasicCacheManager'                        => array(
620
-                'EventEspresso\core\services\cache\TransientCacheStorage' => EE_Dependency_Map::load_from_cache,
621
-            ),
622
-            'EventEspresso\core\services\cache\PostRelatedCacheManager'                  => array(
623
-                'EventEspresso\core\services\cache\TransientCacheStorage' => EE_Dependency_Map::load_from_cache,
624
-            ),
625
-            'EventEspresso\core\domain\services\validation\email\EmailValidationService' => array(
626
-                'EE_Registration_Config'                                  => EE_Dependency_Map::load_from_cache,
627
-                'EventEspresso\core\services\loaders\Loader'              => EE_Dependency_Map::load_from_cache,
628
-            ),
629
-            'EventEspresso\core\domain\values\EmailAddress'                              => array(
630
-                null,
631
-                'EventEspresso\core\domain\services\validation\email\EmailValidationService' => EE_Dependency_Map::load_from_cache,
632
-            ),
633
-            'EventEspresso\core\services\orm\ModelFieldFactory' => array(
634
-                'EventEspresso\core\services\loaders\Loader'              => EE_Dependency_Map::load_from_cache,
635
-            ),
636
-            'LEGACY_MODELS'                                                   => array(
637
-                null,
638
-                'EventEspresso\core\services\database\ModelFieldFactory' => EE_Dependency_Map::load_from_cache,
639
-            ),
640
-            'EE_Module_Request_Router' => array(
641
-                'EE_Request' => EE_Dependency_Map::load_from_cache,
642
-            ),
643
-        );
644
-    }
645
-
646
-
647
-
648
-    /**
649
-     * Registers how core classes are loaded.
650
-     * This can either be done by simply providing the name of one of the EE_Registry loader methods such as:
651
-     *        'EE_Request_Handler' => 'load_core'
652
-     *        'EE_Messages_Queue'  => 'load_lib'
653
-     *        'EEH_Debug_Tools'    => 'load_helper'
654
-     * or, if greater control is required, by providing a custom closure. For example:
655
-     *        'Some_Class' => function () {
656
-     *            return new Some_Class();
657
-     *        },
658
-     * This is required for instantiating dependencies
659
-     * where an interface has been type hinted in a class constructor. For example:
660
-     *        'Required_Interface' => function () {
661
-     *            return new A_Class_That_Implements_Required_Interface();
662
-     *        },
663
-     *
664
-     * @throws InvalidInterfaceException
665
-     * @throws InvalidDataTypeException
666
-     * @throws InvalidArgumentException
667
-     */
668
-    protected function _register_core_class_loaders()
669
-    {
670
-        //for PHP5.3 compat, we need to register any properties called here in a variable because `$this` cannot
671
-        //be used in a closure.
672
-        $request = &$this->_request;
673
-        $response = &$this->_response;
674
-        // $loader = &$this->loader;
675
-        $this->_class_loaders = array(
676
-            //load_core
677
-            'EE_Capabilities'                      => 'load_core',
678
-            'EE_Encryption'                        => 'load_core',
679
-            'EE_Front_Controller'                  => 'load_core',
680
-            'EE_Module_Request_Router'             => 'load_core',
681
-            'EE_Registry'                          => 'load_core',
682
-            'EE_Request'                           => function () use (&$request) {
683
-                return $request;
684
-            },
685
-            'EE_Response'                          => function () use (&$response) {
686
-                return $response;
687
-            },
688
-            'EE_Request_Handler'                   => 'load_core',
689
-            'EE_Session'                           => 'load_core',
690
-            'EE_Cron_Tasks'                        => 'load_core',
691
-            'EE_System'                            => 'load_core',
692
-            'EE_Maintenance_Mode'                  => 'load_core',
693
-            'EE_Register_CPTs'                     => 'load_core',
694
-            'EE_Admin'                             => 'load_core',
695
-            //load_lib
696
-            'EE_Message_Resource_Manager'          => 'load_lib',
697
-            'EE_Message_Type_Collection'           => 'load_lib',
698
-            'EE_Message_Type_Collection_Loader'    => 'load_lib',
699
-            'EE_Messenger_Collection'              => 'load_lib',
700
-            'EE_Messenger_Collection_Loader'       => 'load_lib',
701
-            'EE_Messages_Processor'                => 'load_lib',
702
-            'EE_Message_Repository'                => 'load_lib',
703
-            'EE_Messages_Queue'                    => 'load_lib',
704
-            'EE_Messages_Data_Handler_Collection'  => 'load_lib',
705
-            'EE_Message_Template_Group_Collection' => 'load_lib',
706
-            'EE_Payment_Method_Manager'            => 'load_lib',
707
-            'EE_Messages_Generator'                => function () {
708
-                return EE_Registry::instance()->load_lib(
709
-                    'Messages_Generator',
710
-                    array(),
711
-                    false,
712
-                    false
713
-                );
714
-            },
715
-            'EE_Messages_Template_Defaults'        => function ($arguments = array()) {
716
-                return EE_Registry::instance()->load_lib(
717
-                    'Messages_Template_Defaults',
718
-                    $arguments,
719
-                    false,
720
-                    false
721
-                );
722
-            },
723
-            //load_model
724
-            // 'EEM_Attendee'                         => 'load_model',
725
-            // 'EEM_Message_Template_Group'           => 'load_model',
726
-            // 'EEM_Message_Template'                 => 'load_model',
727
-            //load_helper
728
-            'EEH_Parse_Shortcodes'                 => function () {
729
-                if (EE_Registry::instance()->load_helper('Parse_Shortcodes')) {
730
-                    return new EEH_Parse_Shortcodes();
731
-                }
732
-                return null;
733
-            },
734
-            'EE_Template_Config'                   => function () {
735
-                return EE_Config::instance()->template_settings;
736
-            },
737
-            'EE_Currency_Config'                   => function () {
738
-                return EE_Config::instance()->currency;
739
-            },
740
-            'EE_Registration_Config'                   => function () {
741
-                return EE_Config::instance()->registration;
742
-            },
743
-            'EventEspresso\core\services\loaders\Loader' => function () {
744
-                return LoaderFactory::getLoader();
745
-            },
746
-        );
747
-    }
748
-
749
-
750
-
751
-    /**
752
-     * can be used for supplying alternate names for classes,
753
-     * or for connecting interface names to instantiable classes
754
-     */
755
-    protected function _register_core_aliases()
756
-    {
757
-        $this->_aliases = array(
758
-            'CommandBusInterface'                                                          => 'EventEspresso\core\services\commands\CommandBusInterface',
759
-            'EventEspresso\core\services\commands\CommandBusInterface'                     => 'EventEspresso\core\services\commands\CommandBus',
760
-            'CommandHandlerManagerInterface'                                               => 'EventEspresso\core\services\commands\CommandHandlerManagerInterface',
761
-            'EventEspresso\core\services\commands\CommandHandlerManagerInterface'          => 'EventEspresso\core\services\commands\CommandHandlerManager',
762
-            'CapChecker'                                                                   => 'EventEspresso\core\services\commands\middleware\CapChecker',
763
-            'AddActionHook'                                                                => 'EventEspresso\core\services\commands\middleware\AddActionHook',
764
-            'CapabilitiesChecker'                                                          => 'EventEspresso\core\domain\services\capabilities\CapabilitiesChecker',
765
-            'CapabilitiesCheckerInterface'                                                 => 'EventEspresso\core\domain\services\capabilities\CapabilitiesCheckerInterface',
766
-            'EventEspresso\core\domain\services\capabilities\CapabilitiesCheckerInterface' => 'EventEspresso\core\domain\services\capabilities\CapabilitiesChecker',
767
-            'CreateRegistrationService'                                                    => 'EventEspresso\core\domain\services\registration\CreateRegistrationService',
768
-            'CreateRegCodeCommandHandler'                                                  => 'EventEspresso\core\services\commands\registration\CreateRegCodeCommand',
769
-            'CreateRegUrlLinkCommandHandler'                                               => 'EventEspresso\core\services\commands\registration\CreateRegUrlLinkCommand',
770
-            'CreateRegistrationCommandHandler'                                             => 'EventEspresso\core\services\commands\registration\CreateRegistrationCommand',
771
-            'CopyRegistrationDetailsCommandHandler'                                        => 'EventEspresso\core\services\commands\registration\CopyRegistrationDetailsCommand',
772
-            'CopyRegistrationPaymentsCommandHandler'                                       => 'EventEspresso\core\services\commands\registration\CopyRegistrationPaymentsCommand',
773
-            'CancelRegistrationAndTicketLineItemCommandHandler'                            => 'EventEspresso\core\services\commands\registration\CancelRegistrationAndTicketLineItemCommandHandler',
774
-            'UpdateRegistrationAndTransactionAfterChangeCommandHandler'                    => 'EventEspresso\core\services\commands\registration\UpdateRegistrationAndTransactionAfterChangeCommandHandler',
775
-            'CreateTicketLineItemCommandHandler'                                           => 'EventEspresso\core\services\commands\ticket\CreateTicketLineItemCommand',
776
-            'CreateTransactionCommandHandler'                                     => 'EventEspresso\core\services\commands\transaction\CreateTransactionCommandHandler',
777
-            'CreateAttendeeCommandHandler'                                        => 'EventEspresso\core\services\commands\attendee\CreateAttendeeCommandHandler',
778
-            'TableManager'                                                                 => 'EventEspresso\core\services\database\TableManager',
779
-            'TableAnalysis'                                                                => 'EventEspresso\core\services\database\TableAnalysis',
780
-            'EspressoShortcode'                                                            => 'EventEspresso\core\services\shortcodes\EspressoShortcode',
781
-            'ShortcodeInterface'                                                           => 'EventEspresso\core\services\shortcodes\ShortcodeInterface',
782
-            'EventEspresso\core\services\shortcodes\ShortcodeInterface'                    => 'EventEspresso\core\services\shortcodes\EspressoShortcode',
783
-            'EventEspresso\core\services\cache\CacheStorageInterface'                      => 'EventEspresso\core\services\cache\TransientCacheStorage',
784
-            'LoaderInterface'                                                              => 'EventEspresso\core\services\loaders\LoaderInterface',
785
-            'EventEspresso\core\services\loaders\LoaderInterface'                          => 'EventEspresso\core\services\loaders\Loader',
786
-            'CommandFactoryInterface'                                                     => 'EventEspresso\core\services\commands\CommandFactoryInterface',
787
-            'EventEspresso\core\services\commands\CommandFactoryInterface'                => 'EventEspresso\core\services\commands\CommandFactory',
788
-            'EventEspresso\core\domain\services\session\SessionIdentifierInterface'       => 'EE_Session',
789
-            'EmailValidatorInterface'                                                     => 'EventEspresso\core\domain\services\validation\email\EmailValidatorInterface',
790
-            'EventEspresso\core\domain\services\validation\email\EmailValidatorInterface' => 'EventEspresso\core\domain\services\validation\email\EmailValidationService',
791
-            'NoticeConverterInterface'                                            => 'EventEspresso\core\services\notices\NoticeConverterInterface',
792
-            'EventEspresso\core\services\notices\NoticeConverterInterface'        => 'EventEspresso\core\services\notices\ConvertNoticesToEeErrors',
793
-            'NoticesContainerInterface'                                            => 'EventEspresso\core\services\notices\NoticesContainerInterface',
794
-            'EventEspresso\core\services\notices\NoticesContainerInterface'        => 'EventEspresso\core\services\notices\NoticesContainer',
795
-        );
796
-        if (! (defined('DOING_AJAX') && DOING_AJAX) && is_admin()) {
797
-            $this->_aliases['EventEspresso\core\services\notices\NoticeConverterInterface'] = 'EventEspresso\core\services\notices\ConvertNoticesToAdminNotices';
798
-        }
799
-    }
800
-
801
-
802
-
803
-    /**
804
-     * This is used to reset the internal map and class_loaders to their original default state at the beginning of the
805
-     * request Primarily used by unit tests.
806
-     *
807
-     * @throws InvalidDataTypeException
808
-     * @throws InvalidInterfaceException
809
-     * @throws InvalidArgumentException
810
-     */
811
-    public function reset()
812
-    {
813
-        $this->_register_core_class_loaders();
814
-        $this->_register_core_dependencies();
815
-    }
25
+	/**
26
+	 * This means that the requested class dependency is not present in the dependency map
27
+	 */
28
+	const not_registered = 0;
29
+
30
+	/**
31
+	 * This instructs class loaders to ALWAYS return a newly instantiated object for the requested class.
32
+	 */
33
+	const load_new_object = 1;
34
+
35
+	/**
36
+	 * This instructs class loaders to return a previously instantiated and cached object for the requested class.
37
+	 * IF a previously instantiated object does not exist, a new one will be created and added to the cache.
38
+	 */
39
+	const load_from_cache = 2;
40
+
41
+	/**
42
+	 * When registering a dependency,
43
+	 * this indicates to keep any existing dependencies that already exist,
44
+	 * and simply discard any new dependencies declared in the incoming data
45
+	 */
46
+	const KEEP_EXISTING_DEPENDENCIES = 0;
47
+
48
+	/**
49
+	 * When registering a dependency,
50
+	 * this indicates to overwrite any existing dependencies that already exist using the incoming data
51
+	 */
52
+	const OVERWRITE_DEPENDENCIES = 1;
53
+
54
+
55
+
56
+	/**
57
+	 * @type EE_Dependency_Map $_instance
58
+	 */
59
+	protected static $_instance;
60
+
61
+	/**
62
+	 * @type EE_Request $request
63
+	 */
64
+	protected $_request;
65
+
66
+	/**
67
+	 * @type EE_Response $response
68
+	 */
69
+	protected $_response;
70
+
71
+	/**
72
+	 * @type LoaderInterface $loader
73
+	 */
74
+	protected $loader;
75
+
76
+	/**
77
+	 * @type array $_dependency_map
78
+	 */
79
+	protected $_dependency_map = array();
80
+
81
+	/**
82
+	 * @type array $_class_loaders
83
+	 */
84
+	protected $_class_loaders = array();
85
+
86
+	/**
87
+	 * @type array $_aliases
88
+	 */
89
+	protected $_aliases = array();
90
+
91
+
92
+
93
+	/**
94
+	 * EE_Dependency_Map constructor.
95
+	 *
96
+	 * @param EE_Request  $request
97
+	 * @param EE_Response $response
98
+	 */
99
+	protected function __construct(EE_Request $request, EE_Response $response)
100
+	{
101
+		$this->_request = $request;
102
+		$this->_response = $response;
103
+		add_action('EE_Load_Espresso_Core__handle_request__initialize_core_loading', array($this, 'initialize'));
104
+		do_action('EE_Dependency_Map____construct');
105
+	}
106
+
107
+
108
+
109
+	/**
110
+	 * @throws InvalidDataTypeException
111
+	 * @throws InvalidInterfaceException
112
+	 * @throws InvalidArgumentException
113
+	 */
114
+	public function initialize()
115
+	{
116
+		$this->_register_core_dependencies();
117
+		$this->_register_core_class_loaders();
118
+		$this->_register_core_aliases();
119
+	}
120
+
121
+
122
+
123
+	/**
124
+	 * @singleton method used to instantiate class object
125
+	 * @access    public
126
+	 * @param EE_Request  $request
127
+	 * @param EE_Response $response
128
+	 * @return EE_Dependency_Map
129
+	 */
130
+	public static function instance(EE_Request $request = null, EE_Response $response = null)
131
+	{
132
+		// check if class object is instantiated, and instantiated properly
133
+		if (! self::$_instance instanceof EE_Dependency_Map) {
134
+			self::$_instance = new EE_Dependency_Map($request, $response);
135
+		}
136
+		return self::$_instance;
137
+	}
138
+
139
+
140
+
141
+	/**
142
+	 * @param LoaderInterface $loader
143
+	 */
144
+	public function setLoader(LoaderInterface $loader)
145
+	{
146
+		$this->loader = $loader;
147
+	}
148
+
149
+
150
+
151
+	/**
152
+	 * @param string $class
153
+	 * @param array  $dependencies
154
+	 * @param int    $overwrite
155
+	 * @return bool
156
+	 */
157
+	public static function register_dependencies(
158
+		$class,
159
+		array $dependencies,
160
+		$overwrite = EE_Dependency_Map::KEEP_EXISTING_DEPENDENCIES
161
+	) {
162
+		return self::$_instance->registerDependencies($class, $dependencies, $overwrite);
163
+	}
164
+
165
+
166
+
167
+	/**
168
+	 * Assigns an array of class names and corresponding load sources (new or cached)
169
+	 * to the class specified by the first parameter.
170
+	 * IMPORTANT !!!
171
+	 * The order of elements in the incoming $dependencies array MUST match
172
+	 * the order of the constructor parameters for the class in question.
173
+	 * This is especially important when overriding any existing dependencies that are registered.
174
+	 * the third parameter controls whether any duplicate dependencies are overwritten or not.
175
+	 *
176
+	 * @param string $class
177
+	 * @param array  $dependencies
178
+	 * @param int    $overwrite
179
+	 * @return bool
180
+	 */
181
+	public function registerDependencies(
182
+		$class,
183
+		array $dependencies,
184
+		$overwrite = EE_Dependency_Map::KEEP_EXISTING_DEPENDENCIES
185
+	) {
186
+		$class = trim($class, '\\');
187
+		$registered = false;
188
+		if (empty(self::$_instance->_dependency_map[ $class ])) {
189
+			self::$_instance->_dependency_map[ $class ] = array();
190
+		}
191
+		// we need to make sure that any aliases used when registering a dependency
192
+		// get resolved to the correct class name
193
+		foreach ((array)$dependencies as $dependency => $load_source) {
194
+			$alias = self::$_instance->get_alias($dependency);
195
+			if (
196
+				$overwrite === EE_Dependency_Map::OVERWRITE_DEPENDENCIES
197
+				|| ! isset(self::$_instance->_dependency_map[ $class ][ $alias ])
198
+			) {
199
+				unset($dependencies[$dependency]);
200
+				$dependencies[$alias] = $load_source;
201
+				$registered = true;
202
+			}
203
+		}
204
+		// now add our two lists of dependencies together.
205
+		// using Union (+=) favours the arrays in precedence from left to right,
206
+		// so $dependencies is NOT overwritten because it is listed first
207
+		// ie: with A = B + C, entries in B take precedence over duplicate entries in C
208
+		// Union is way faster than array_merge() but should be used with caution...
209
+		// especially with numerically indexed arrays
210
+		$dependencies += self::$_instance->_dependency_map[ $class ];
211
+		// now we need to ensure that the resulting dependencies
212
+		// array only has the entries that are required for the class
213
+		// so first count how many dependencies were originally registered for the class
214
+		$dependency_count = count(self::$_instance->_dependency_map[ $class ]);
215
+		// if that count is non-zero (meaning dependencies were already registered)
216
+		self::$_instance->_dependency_map[ $class ] = $dependency_count
217
+			// then truncate the  final array to match that count
218
+			? array_slice($dependencies, 0, $dependency_count)
219
+			// otherwise just take the incoming array because nothing previously existed
220
+			: $dependencies;
221
+		return $registered;
222
+	}
223
+
224
+
225
+
226
+	/**
227
+	 * @param string $class_name
228
+	 * @param string $loader
229
+	 * @return bool
230
+	 * @throws DomainException
231
+	 */
232
+	public static function register_class_loader($class_name, $loader = 'load_core')
233
+	{
234
+		if (! $loader instanceof Closure && strpos($class_name, '\\') !== false) {
235
+			throw new DomainException(
236
+				esc_html__('Don\'t use class loaders for FQCNs.', 'event_espresso')
237
+			);
238
+		}
239
+		// check that loader is callable or method starts with "load_" and exists in EE_Registry
240
+		if (
241
+			! is_callable($loader)
242
+			&& (
243
+				strpos($loader, 'load_') !== 0
244
+				|| ! method_exists('EE_Registry', $loader)
245
+			)
246
+		) {
247
+			throw new DomainException(
248
+				sprintf(
249
+					esc_html__(
250
+						'"%1$s" is not a valid loader method on EE_Registry.',
251
+						'event_espresso'
252
+					),
253
+					$loader
254
+				)
255
+			);
256
+		}
257
+		$class_name = self::$_instance->get_alias($class_name);
258
+		if (! isset(self::$_instance->_class_loaders[$class_name])) {
259
+			self::$_instance->_class_loaders[$class_name] = $loader;
260
+			return true;
261
+		}
262
+		return false;
263
+	}
264
+
265
+
266
+
267
+	/**
268
+	 * @return array
269
+	 */
270
+	public function dependency_map()
271
+	{
272
+		return $this->_dependency_map;
273
+	}
274
+
275
+
276
+
277
+	/**
278
+	 * returns TRUE if dependency map contains a listing for the provided class name
279
+	 *
280
+	 * @param string $class_name
281
+	 * @return boolean
282
+	 */
283
+	public function has($class_name = '')
284
+	{
285
+		// all legacy models have the same dependencies
286
+		if (strpos($class_name, 'EEM_') === 0) {
287
+			$class_name = 'LEGACY_MODELS';
288
+		}
289
+		return isset($this->_dependency_map[$class_name]) ? true : false;
290
+	}
291
+
292
+
293
+
294
+	/**
295
+	 * returns TRUE if dependency map contains a listing for the provided class name AND dependency
296
+	 *
297
+	 * @param string $class_name
298
+	 * @param string $dependency
299
+	 * @return bool
300
+	 */
301
+	public function has_dependency_for_class($class_name = '', $dependency = '')
302
+	{
303
+		// all legacy models have the same dependencies
304
+		if (strpos($class_name, 'EEM_') === 0) {
305
+			$class_name = 'LEGACY_MODELS';
306
+		}
307
+		$dependency = $this->get_alias($dependency);
308
+		return isset($this->_dependency_map[$class_name], $this->_dependency_map[$class_name][$dependency])
309
+			? true
310
+			: false;
311
+	}
312
+
313
+
314
+
315
+	/**
316
+	 * returns loading strategy for whether a previously cached dependency should be loaded or a new instance returned
317
+	 *
318
+	 * @param string $class_name
319
+	 * @param string $dependency
320
+	 * @return int
321
+	 */
322
+	public function loading_strategy_for_class_dependency($class_name = '', $dependency = '')
323
+	{
324
+		// all legacy models have the same dependencies
325
+		if (strpos($class_name, 'EEM_') === 0) {
326
+			$class_name = 'LEGACY_MODELS';
327
+		}
328
+		$dependency = $this->get_alias($dependency);
329
+		return $this->has_dependency_for_class($class_name, $dependency)
330
+			? $this->_dependency_map[$class_name][$dependency]
331
+			: EE_Dependency_Map::not_registered;
332
+	}
333
+
334
+
335
+
336
+	/**
337
+	 * @param string $class_name
338
+	 * @return string | Closure
339
+	 */
340
+	public function class_loader($class_name)
341
+	{
342
+		// all legacy models use load_model()
343
+		if(strpos($class_name, 'EEM_') === 0){
344
+			return 'load_model';
345
+		}
346
+		$class_name = $this->get_alias($class_name);
347
+		return isset($this->_class_loaders[$class_name]) ? $this->_class_loaders[$class_name] : '';
348
+	}
349
+
350
+
351
+
352
+	/**
353
+	 * @return array
354
+	 */
355
+	public function class_loaders()
356
+	{
357
+		return $this->_class_loaders;
358
+	}
359
+
360
+
361
+
362
+	/**
363
+	 * adds an alias for a classname
364
+	 *
365
+	 * @param string $class_name the class name that should be used (concrete class to replace interface)
366
+	 * @param string $alias      the class name that would be type hinted for (abstract parent or interface)
367
+	 * @param string $for_class  the class that has the dependency (is type hinting for the interface)
368
+	 */
369
+	public function add_alias($class_name, $alias, $for_class = '')
370
+	{
371
+		if ($for_class !== '') {
372
+			if (! isset($this->_aliases[$for_class])) {
373
+				$this->_aliases[$for_class] = array();
374
+			}
375
+			$this->_aliases[$for_class][$class_name] = $alias;
376
+		}
377
+		$this->_aliases[$class_name] = $alias;
378
+	}
379
+
380
+
381
+
382
+	/**
383
+	 * returns TRUE if the provided class name has an alias
384
+	 *
385
+	 * @param string $class_name
386
+	 * @param string $for_class
387
+	 * @return bool
388
+	 */
389
+	public function has_alias($class_name = '', $for_class = '')
390
+	{
391
+		return isset($this->_aliases[$for_class], $this->_aliases[$for_class][$class_name])
392
+			   || (
393
+				   isset($this->_aliases[$class_name])
394
+				   && ! is_array($this->_aliases[$class_name])
395
+			   );
396
+	}
397
+
398
+
399
+
400
+	/**
401
+	 * returns alias for class name if one exists, otherwise returns the original classname
402
+	 * functions recursively, so that multiple aliases can be used to drill down to a classname
403
+	 *  for example:
404
+	 *      if the following two entries were added to the _aliases array:
405
+	 *          array(
406
+	 *              'interface_alias'           => 'some\namespace\interface'
407
+	 *              'some\namespace\interface'  => 'some\namespace\classname'
408
+	 *          )
409
+	 *      then one could use EE_Registry::instance()->create( 'interface_alias' )
410
+	 *      to load an instance of 'some\namespace\classname'
411
+	 *
412
+	 * @param string $class_name
413
+	 * @param string $for_class
414
+	 * @return string
415
+	 */
416
+	public function get_alias($class_name = '', $for_class = '')
417
+	{
418
+		if (! $this->has_alias($class_name, $for_class)) {
419
+			return $class_name;
420
+		}
421
+		if ($for_class !== '' && isset($this->_aliases[ $for_class ][ $class_name ])) {
422
+			return $this->get_alias($this->_aliases[$for_class][$class_name], $for_class);
423
+		}
424
+		return $this->get_alias($this->_aliases[$class_name]);
425
+	}
426
+
427
+
428
+
429
+	/**
430
+	 * Registers the core dependencies and whether a previously instantiated object should be loaded from the cache,
431
+	 * if one exists, or whether a new object should be generated every time the requested class is loaded.
432
+	 * This is done by using the following class constants:
433
+	 *        EE_Dependency_Map::load_from_cache - loads previously instantiated object
434
+	 *        EE_Dependency_Map::load_new_object - generates a new object every time
435
+	 */
436
+	protected function _register_core_dependencies()
437
+	{
438
+		$this->_dependency_map = array(
439
+			'EE_Request_Handler'                                                                                          => array(
440
+				'EE_Request' => EE_Dependency_Map::load_from_cache,
441
+			),
442
+			'EE_System'                                                                                                   => array(
443
+				'EE_Registry'                                => EE_Dependency_Map::load_from_cache,
444
+				'EventEspresso\core\services\loaders\Loader' => EE_Dependency_Map::load_from_cache,
445
+				'EE_Capabilities'                            => EE_Dependency_Map::load_from_cache,
446
+				'EE_Request'                                 => EE_Dependency_Map::load_from_cache,
447
+				'EE_Maintenance_Mode'                        => EE_Dependency_Map::load_from_cache,
448
+			),
449
+			'EE_Session'                                                                                                  => array(
450
+				'EventEspresso\core\services\cache\TransientCacheStorage' => EE_Dependency_Map::load_from_cache,
451
+				'EE_Encryption'                                           => EE_Dependency_Map::load_from_cache,
452
+			),
453
+			'EE_Cart'                                                                                                     => array(
454
+				'EE_Session' => EE_Dependency_Map::load_from_cache,
455
+			),
456
+			'EE_Front_Controller'                                                                                         => array(
457
+				'EE_Registry'              => EE_Dependency_Map::load_from_cache,
458
+				'EE_Request_Handler'       => EE_Dependency_Map::load_from_cache,
459
+				'EE_Module_Request_Router' => EE_Dependency_Map::load_from_cache,
460
+			),
461
+			'EE_Messenger_Collection_Loader'                                                                              => array(
462
+				'EE_Messenger_Collection' => EE_Dependency_Map::load_new_object,
463
+			),
464
+			'EE_Message_Type_Collection_Loader'                                                                           => array(
465
+				'EE_Message_Type_Collection' => EE_Dependency_Map::load_new_object,
466
+			),
467
+			'EE_Message_Resource_Manager'                                                                                 => array(
468
+				'EE_Messenger_Collection_Loader'    => EE_Dependency_Map::load_new_object,
469
+				'EE_Message_Type_Collection_Loader' => EE_Dependency_Map::load_new_object,
470
+				'EEM_Message_Template_Group'        => EE_Dependency_Map::load_from_cache,
471
+			),
472
+			'EE_Message_Factory'                                                                                          => array(
473
+				'EE_Message_Resource_Manager' => EE_Dependency_Map::load_from_cache,
474
+			),
475
+			'EE_messages'                                                                                                 => array(
476
+				'EE_Message_Resource_Manager' => EE_Dependency_Map::load_from_cache,
477
+			),
478
+			'EE_Messages_Generator'                                                                                       => array(
479
+				'EE_Messages_Queue'                    => EE_Dependency_Map::load_new_object,
480
+				'EE_Messages_Data_Handler_Collection'  => EE_Dependency_Map::load_new_object,
481
+				'EE_Message_Template_Group_Collection' => EE_Dependency_Map::load_new_object,
482
+				'EEH_Parse_Shortcodes'                 => EE_Dependency_Map::load_from_cache,
483
+			),
484
+			'EE_Messages_Processor'                                                                                       => array(
485
+				'EE_Message_Resource_Manager' => EE_Dependency_Map::load_from_cache,
486
+			),
487
+			'EE_Messages_Queue'                                                                                           => array(
488
+				'EE_Message_Repository' => EE_Dependency_Map::load_new_object,
489
+			),
490
+			'EE_Messages_Template_Defaults'                                                                               => array(
491
+				'EEM_Message_Template_Group' => EE_Dependency_Map::load_from_cache,
492
+				'EEM_Message_Template'       => EE_Dependency_Map::load_from_cache,
493
+			),
494
+			'EE_Message_To_Generate_From_Request'                                                                         => array(
495
+				'EE_Message_Resource_Manager' => EE_Dependency_Map::load_from_cache,
496
+				'EE_Request_Handler'          => EE_Dependency_Map::load_from_cache,
497
+			),
498
+			'EventEspresso\core\services\commands\CommandBus'                                                             => array(
499
+				'EventEspresso\core\services\commands\CommandHandlerManager' => EE_Dependency_Map::load_from_cache,
500
+			),
501
+			'EventEspresso\services\commands\CommandHandler'                                                              => array(
502
+				'EE_Registry'         => EE_Dependency_Map::load_from_cache,
503
+				'CommandBusInterface' => EE_Dependency_Map::load_from_cache,
504
+			),
505
+			'EventEspresso\core\services\commands\CommandHandlerManager'                                                  => array(
506
+				'EventEspresso\core\services\loaders\Loader' => EE_Dependency_Map::load_from_cache,
507
+			),
508
+			'EventEspresso\core\services\commands\CompositeCommandHandler'                                                => array(
509
+				'EventEspresso\core\services\commands\CommandBus'     => EE_Dependency_Map::load_from_cache,
510
+				'EventEspresso\core\services\commands\CommandFactory' => EE_Dependency_Map::load_from_cache,
511
+			),
512
+			'EventEspresso\core\services\commands\CommandFactory'                                                         => array(
513
+				'EventEspresso\core\services\loaders\Loader' => EE_Dependency_Map::load_from_cache,
514
+			),
515
+			'EventEspresso\core\services\commands\middleware\CapChecker'                                                  => array(
516
+				'EventEspresso\core\domain\services\capabilities\CapabilitiesChecker' => EE_Dependency_Map::load_from_cache,
517
+			),
518
+			'EventEspresso\core\domain\services\capabilities\CapabilitiesChecker'                                         => array(
519
+				'EE_Capabilities' => EE_Dependency_Map::load_from_cache,
520
+			),
521
+			'EventEspresso\core\domain\services\capabilities\RegistrationsCapChecker'                                     => array(
522
+				'EE_Capabilities' => EE_Dependency_Map::load_from_cache,
523
+			),
524
+			'EventEspresso\core\services\commands\registration\CreateRegistrationCommandHandler'                          => array(
525
+				'EventEspresso\core\domain\services\registration\CreateRegistrationService' => EE_Dependency_Map::load_from_cache,
526
+			),
527
+			'EventEspresso\core\services\commands\registration\CopyRegistrationDetailsCommandHandler'                     => array(
528
+				'EventEspresso\core\domain\services\registration\CopyRegistrationService' => EE_Dependency_Map::load_from_cache,
529
+			),
530
+			'EventEspresso\core\services\commands\registration\CopyRegistrationPaymentsCommandHandler'                    => array(
531
+				'EventEspresso\core\domain\services\registration\CopyRegistrationService' => EE_Dependency_Map::load_from_cache,
532
+			),
533
+			'EventEspresso\core\services\commands\registration\CancelRegistrationAndTicketLineItemCommandHandler'         => array(
534
+				'EventEspresso\core\domain\services\registration\CancelTicketLineItemService' => EE_Dependency_Map::load_from_cache,
535
+			),
536
+			'EventEspresso\core\services\commands\registration\UpdateRegistrationAndTransactionAfterChangeCommandHandler' => array(
537
+				'EventEspresso\core\domain\services\registration\UpdateRegistrationService' => EE_Dependency_Map::load_from_cache,
538
+			),
539
+			'EventEspresso\core\services\commands\ticket\CreateTicketLineItemCommandHandler'                              => array(
540
+				'EventEspresso\core\domain\services\ticket\CreateTicketLineItemService' => EE_Dependency_Map::load_from_cache,
541
+			),
542
+			'EventEspresso\core\services\commands\ticket\CancelTicketLineItemCommandHandler'                              => array(
543
+				'EventEspresso\core\domain\services\ticket\CancelTicketLineItemService' => EE_Dependency_Map::load_from_cache,
544
+			),
545
+			'EventEspresso\core\domain\services\registration\CancelRegistrationService'                                   => array(
546
+				'EventEspresso\core\domain\services\ticket\CancelTicketLineItemService' => EE_Dependency_Map::load_from_cache,
547
+			),
548
+			'EventEspresso\core\services\commands\attendee\CreateAttendeeCommandHandler'                                  => array(
549
+				'EEM_Attendee' => EE_Dependency_Map::load_from_cache,
550
+			),
551
+			'EventEspresso\core\services\database\TableManager'                                                           => array(
552
+				'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
553
+			),
554
+			'EE_Data_Migration_Class_Base'                                                                                => array(
555
+				'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
556
+				'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
557
+			),
558
+			'EE_DMS_Core_4_1_0'                                                                                           => array(
559
+				'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
560
+				'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
561
+			),
562
+			'EE_DMS_Core_4_2_0'                                                                                           => array(
563
+				'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
564
+				'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
565
+			),
566
+			'EE_DMS_Core_4_3_0'                                                                                           => array(
567
+				'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
568
+				'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
569
+			),
570
+			'EE_DMS_Core_4_4_0'                                                                                           => array(
571
+				'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
572
+				'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
573
+			),
574
+			'EE_DMS_Core_4_5_0'                                                                                           => array(
575
+				'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
576
+				'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
577
+			),
578
+			'EE_DMS_Core_4_6_0'                                                                                           => array(
579
+				'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
580
+				'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
581
+			),
582
+			'EE_DMS_Core_4_7_0'                                                                                           => array(
583
+				'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
584
+				'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
585
+			),
586
+			'EE_DMS_Core_4_8_0'                                                                                           => array(
587
+				'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
588
+				'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
589
+			),
590
+			'EE_DMS_Core_4_9_0'                                                                                           => array(
591
+				'EventEspresso\core\services\database\TableAnalysis' => EE_Dependency_Map::load_from_cache,
592
+				'EventEspresso\core\services\database\TableManager'  => EE_Dependency_Map::load_from_cache,
593
+			),
594
+			'EventEspresso\core\services\assets\Registry'                                                                 => array(
595
+				'EE_Template_Config' => EE_Dependency_Map::load_from_cache,
596
+				'EE_Currency_Config' => EE_Dependency_Map::load_from_cache,
597
+			),
598
+			'EventEspresso\core\domain\entities\shortcodes\EspressoCancelled'                                             => array(
599
+				'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
600
+			),
601
+			'EventEspresso\core\domain\entities\shortcodes\EspressoCheckout'                                              => array(
602
+				'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
603
+			),
604
+			'EventEspresso\core\domain\entities\shortcodes\EspressoEventAttendees'                                        => array(
605
+				'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
606
+			),
607
+			'EventEspresso\core\domain\entities\shortcodes\EspressoEvents'                                                => array(
608
+				'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
609
+			),
610
+			'EventEspresso\core\domain\entities\shortcodes\EspressoThankYou'                                              => array(
611
+				'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
612
+			),
613
+			'EventEspresso\core\domain\entities\shortcodes\EspressoTicketSelector'                                        => array(
614
+				'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
615
+			),
616
+			'EventEspresso\core\domain\entities\shortcodes\EspressoTxnPage'                                               => array(
617
+				'EventEspresso\core\services\cache\PostRelatedCacheManager' => EE_Dependency_Map::load_from_cache,
618
+			),
619
+			'EventEspresso\core\services\cache\BasicCacheManager'                        => array(
620
+				'EventEspresso\core\services\cache\TransientCacheStorage' => EE_Dependency_Map::load_from_cache,
621
+			),
622
+			'EventEspresso\core\services\cache\PostRelatedCacheManager'                  => array(
623
+				'EventEspresso\core\services\cache\TransientCacheStorage' => EE_Dependency_Map::load_from_cache,
624
+			),
625
+			'EventEspresso\core\domain\services\validation\email\EmailValidationService' => array(
626
+				'EE_Registration_Config'                                  => EE_Dependency_Map::load_from_cache,
627
+				'EventEspresso\core\services\loaders\Loader'              => EE_Dependency_Map::load_from_cache,
628
+			),
629
+			'EventEspresso\core\domain\values\EmailAddress'                              => array(
630
+				null,
631
+				'EventEspresso\core\domain\services\validation\email\EmailValidationService' => EE_Dependency_Map::load_from_cache,
632
+			),
633
+			'EventEspresso\core\services\orm\ModelFieldFactory' => array(
634
+				'EventEspresso\core\services\loaders\Loader'              => EE_Dependency_Map::load_from_cache,
635
+			),
636
+			'LEGACY_MODELS'                                                   => array(
637
+				null,
638
+				'EventEspresso\core\services\database\ModelFieldFactory' => EE_Dependency_Map::load_from_cache,
639
+			),
640
+			'EE_Module_Request_Router' => array(
641
+				'EE_Request' => EE_Dependency_Map::load_from_cache,
642
+			),
643
+		);
644
+	}
645
+
646
+
647
+
648
+	/**
649
+	 * Registers how core classes are loaded.
650
+	 * This can either be done by simply providing the name of one of the EE_Registry loader methods such as:
651
+	 *        'EE_Request_Handler' => 'load_core'
652
+	 *        'EE_Messages_Queue'  => 'load_lib'
653
+	 *        'EEH_Debug_Tools'    => 'load_helper'
654
+	 * or, if greater control is required, by providing a custom closure. For example:
655
+	 *        'Some_Class' => function () {
656
+	 *            return new Some_Class();
657
+	 *        },
658
+	 * This is required for instantiating dependencies
659
+	 * where an interface has been type hinted in a class constructor. For example:
660
+	 *        'Required_Interface' => function () {
661
+	 *            return new A_Class_That_Implements_Required_Interface();
662
+	 *        },
663
+	 *
664
+	 * @throws InvalidInterfaceException
665
+	 * @throws InvalidDataTypeException
666
+	 * @throws InvalidArgumentException
667
+	 */
668
+	protected function _register_core_class_loaders()
669
+	{
670
+		//for PHP5.3 compat, we need to register any properties called here in a variable because `$this` cannot
671
+		//be used in a closure.
672
+		$request = &$this->_request;
673
+		$response = &$this->_response;
674
+		// $loader = &$this->loader;
675
+		$this->_class_loaders = array(
676
+			//load_core
677
+			'EE_Capabilities'                      => 'load_core',
678
+			'EE_Encryption'                        => 'load_core',
679
+			'EE_Front_Controller'                  => 'load_core',
680
+			'EE_Module_Request_Router'             => 'load_core',
681
+			'EE_Registry'                          => 'load_core',
682
+			'EE_Request'                           => function () use (&$request) {
683
+				return $request;
684
+			},
685
+			'EE_Response'                          => function () use (&$response) {
686
+				return $response;
687
+			},
688
+			'EE_Request_Handler'                   => 'load_core',
689
+			'EE_Session'                           => 'load_core',
690
+			'EE_Cron_Tasks'                        => 'load_core',
691
+			'EE_System'                            => 'load_core',
692
+			'EE_Maintenance_Mode'                  => 'load_core',
693
+			'EE_Register_CPTs'                     => 'load_core',
694
+			'EE_Admin'                             => 'load_core',
695
+			//load_lib
696
+			'EE_Message_Resource_Manager'          => 'load_lib',
697
+			'EE_Message_Type_Collection'           => 'load_lib',
698
+			'EE_Message_Type_Collection_Loader'    => 'load_lib',
699
+			'EE_Messenger_Collection'              => 'load_lib',
700
+			'EE_Messenger_Collection_Loader'       => 'load_lib',
701
+			'EE_Messages_Processor'                => 'load_lib',
702
+			'EE_Message_Repository'                => 'load_lib',
703
+			'EE_Messages_Queue'                    => 'load_lib',
704
+			'EE_Messages_Data_Handler_Collection'  => 'load_lib',
705
+			'EE_Message_Template_Group_Collection' => 'load_lib',
706
+			'EE_Payment_Method_Manager'            => 'load_lib',
707
+			'EE_Messages_Generator'                => function () {
708
+				return EE_Registry::instance()->load_lib(
709
+					'Messages_Generator',
710
+					array(),
711
+					false,
712
+					false
713
+				);
714
+			},
715
+			'EE_Messages_Template_Defaults'        => function ($arguments = array()) {
716
+				return EE_Registry::instance()->load_lib(
717
+					'Messages_Template_Defaults',
718
+					$arguments,
719
+					false,
720
+					false
721
+				);
722
+			},
723
+			//load_model
724
+			// 'EEM_Attendee'                         => 'load_model',
725
+			// 'EEM_Message_Template_Group'           => 'load_model',
726
+			// 'EEM_Message_Template'                 => 'load_model',
727
+			//load_helper
728
+			'EEH_Parse_Shortcodes'                 => function () {
729
+				if (EE_Registry::instance()->load_helper('Parse_Shortcodes')) {
730
+					return new EEH_Parse_Shortcodes();
731
+				}
732
+				return null;
733
+			},
734
+			'EE_Template_Config'                   => function () {
735
+				return EE_Config::instance()->template_settings;
736
+			},
737
+			'EE_Currency_Config'                   => function () {
738
+				return EE_Config::instance()->currency;
739
+			},
740
+			'EE_Registration_Config'                   => function () {
741
+				return EE_Config::instance()->registration;
742
+			},
743
+			'EventEspresso\core\services\loaders\Loader' => function () {
744
+				return LoaderFactory::getLoader();
745
+			},
746
+		);
747
+	}
748
+
749
+
750
+
751
+	/**
752
+	 * can be used for supplying alternate names for classes,
753
+	 * or for connecting interface names to instantiable classes
754
+	 */
755
+	protected function _register_core_aliases()
756
+	{
757
+		$this->_aliases = array(
758
+			'CommandBusInterface'                                                          => 'EventEspresso\core\services\commands\CommandBusInterface',
759
+			'EventEspresso\core\services\commands\CommandBusInterface'                     => 'EventEspresso\core\services\commands\CommandBus',
760
+			'CommandHandlerManagerInterface'                                               => 'EventEspresso\core\services\commands\CommandHandlerManagerInterface',
761
+			'EventEspresso\core\services\commands\CommandHandlerManagerInterface'          => 'EventEspresso\core\services\commands\CommandHandlerManager',
762
+			'CapChecker'                                                                   => 'EventEspresso\core\services\commands\middleware\CapChecker',
763
+			'AddActionHook'                                                                => 'EventEspresso\core\services\commands\middleware\AddActionHook',
764
+			'CapabilitiesChecker'                                                          => 'EventEspresso\core\domain\services\capabilities\CapabilitiesChecker',
765
+			'CapabilitiesCheckerInterface'                                                 => 'EventEspresso\core\domain\services\capabilities\CapabilitiesCheckerInterface',
766
+			'EventEspresso\core\domain\services\capabilities\CapabilitiesCheckerInterface' => 'EventEspresso\core\domain\services\capabilities\CapabilitiesChecker',
767
+			'CreateRegistrationService'                                                    => 'EventEspresso\core\domain\services\registration\CreateRegistrationService',
768
+			'CreateRegCodeCommandHandler'                                                  => 'EventEspresso\core\services\commands\registration\CreateRegCodeCommand',
769
+			'CreateRegUrlLinkCommandHandler'                                               => 'EventEspresso\core\services\commands\registration\CreateRegUrlLinkCommand',
770
+			'CreateRegistrationCommandHandler'                                             => 'EventEspresso\core\services\commands\registration\CreateRegistrationCommand',
771
+			'CopyRegistrationDetailsCommandHandler'                                        => 'EventEspresso\core\services\commands\registration\CopyRegistrationDetailsCommand',
772
+			'CopyRegistrationPaymentsCommandHandler'                                       => 'EventEspresso\core\services\commands\registration\CopyRegistrationPaymentsCommand',
773
+			'CancelRegistrationAndTicketLineItemCommandHandler'                            => 'EventEspresso\core\services\commands\registration\CancelRegistrationAndTicketLineItemCommandHandler',
774
+			'UpdateRegistrationAndTransactionAfterChangeCommandHandler'                    => 'EventEspresso\core\services\commands\registration\UpdateRegistrationAndTransactionAfterChangeCommandHandler',
775
+			'CreateTicketLineItemCommandHandler'                                           => 'EventEspresso\core\services\commands\ticket\CreateTicketLineItemCommand',
776
+			'CreateTransactionCommandHandler'                                     => 'EventEspresso\core\services\commands\transaction\CreateTransactionCommandHandler',
777
+			'CreateAttendeeCommandHandler'                                        => 'EventEspresso\core\services\commands\attendee\CreateAttendeeCommandHandler',
778
+			'TableManager'                                                                 => 'EventEspresso\core\services\database\TableManager',
779
+			'TableAnalysis'                                                                => 'EventEspresso\core\services\database\TableAnalysis',
780
+			'EspressoShortcode'                                                            => 'EventEspresso\core\services\shortcodes\EspressoShortcode',
781
+			'ShortcodeInterface'                                                           => 'EventEspresso\core\services\shortcodes\ShortcodeInterface',
782
+			'EventEspresso\core\services\shortcodes\ShortcodeInterface'                    => 'EventEspresso\core\services\shortcodes\EspressoShortcode',
783
+			'EventEspresso\core\services\cache\CacheStorageInterface'                      => 'EventEspresso\core\services\cache\TransientCacheStorage',
784
+			'LoaderInterface'                                                              => 'EventEspresso\core\services\loaders\LoaderInterface',
785
+			'EventEspresso\core\services\loaders\LoaderInterface'                          => 'EventEspresso\core\services\loaders\Loader',
786
+			'CommandFactoryInterface'                                                     => 'EventEspresso\core\services\commands\CommandFactoryInterface',
787
+			'EventEspresso\core\services\commands\CommandFactoryInterface'                => 'EventEspresso\core\services\commands\CommandFactory',
788
+			'EventEspresso\core\domain\services\session\SessionIdentifierInterface'       => 'EE_Session',
789
+			'EmailValidatorInterface'                                                     => 'EventEspresso\core\domain\services\validation\email\EmailValidatorInterface',
790
+			'EventEspresso\core\domain\services\validation\email\EmailValidatorInterface' => 'EventEspresso\core\domain\services\validation\email\EmailValidationService',
791
+			'NoticeConverterInterface'                                            => 'EventEspresso\core\services\notices\NoticeConverterInterface',
792
+			'EventEspresso\core\services\notices\NoticeConverterInterface'        => 'EventEspresso\core\services\notices\ConvertNoticesToEeErrors',
793
+			'NoticesContainerInterface'                                            => 'EventEspresso\core\services\notices\NoticesContainerInterface',
794
+			'EventEspresso\core\services\notices\NoticesContainerInterface'        => 'EventEspresso\core\services\notices\NoticesContainer',
795
+		);
796
+		if (! (defined('DOING_AJAX') && DOING_AJAX) && is_admin()) {
797
+			$this->_aliases['EventEspresso\core\services\notices\NoticeConverterInterface'] = 'EventEspresso\core\services\notices\ConvertNoticesToAdminNotices';
798
+		}
799
+	}
800
+
801
+
802
+
803
+	/**
804
+	 * This is used to reset the internal map and class_loaders to their original default state at the beginning of the
805
+	 * request Primarily used by unit tests.
806
+	 *
807
+	 * @throws InvalidDataTypeException
808
+	 * @throws InvalidInterfaceException
809
+	 * @throws InvalidArgumentException
810
+	 */
811
+	public function reset()
812
+	{
813
+		$this->_register_core_class_loaders();
814
+		$this->_register_core_dependencies();
815
+	}
816 816
 
817 817
 
818 818
 }
Please login to merge, or discard this patch.
Spacing   +25 added lines, -25 removed lines patch added patch discarded remove patch
@@ -4,7 +4,7 @@  discard block
 block discarded – undo
4 4
 use EventEspresso\core\services\loaders\LoaderFactory;
5 5
 use EventEspresso\core\services\loaders\LoaderInterface;
6 6
 
7
-if (! defined('EVENT_ESPRESSO_VERSION')) {
7
+if ( ! defined('EVENT_ESPRESSO_VERSION')) {
8 8
     exit('No direct script access allowed');
9 9
 }
10 10
 
@@ -130,7 +130,7 @@  discard block
 block discarded – undo
130 130
     public static function instance(EE_Request $request = null, EE_Response $response = null)
131 131
     {
132 132
         // check if class object is instantiated, and instantiated properly
133
-        if (! self::$_instance instanceof EE_Dependency_Map) {
133
+        if ( ! self::$_instance instanceof EE_Dependency_Map) {
134 134
             self::$_instance = new EE_Dependency_Map($request, $response);
135 135
         }
136 136
         return self::$_instance;
@@ -185,16 +185,16 @@  discard block
 block discarded – undo
185 185
     ) {
186 186
         $class = trim($class, '\\');
187 187
         $registered = false;
188
-        if (empty(self::$_instance->_dependency_map[ $class ])) {
189
-            self::$_instance->_dependency_map[ $class ] = array();
188
+        if (empty(self::$_instance->_dependency_map[$class])) {
189
+            self::$_instance->_dependency_map[$class] = array();
190 190
         }
191 191
         // we need to make sure that any aliases used when registering a dependency
192 192
         // get resolved to the correct class name
193
-        foreach ((array)$dependencies as $dependency => $load_source) {
193
+        foreach ((array) $dependencies as $dependency => $load_source) {
194 194
             $alias = self::$_instance->get_alias($dependency);
195 195
             if (
196 196
                 $overwrite === EE_Dependency_Map::OVERWRITE_DEPENDENCIES
197
-                || ! isset(self::$_instance->_dependency_map[ $class ][ $alias ])
197
+                || ! isset(self::$_instance->_dependency_map[$class][$alias])
198 198
             ) {
199 199
                 unset($dependencies[$dependency]);
200 200
                 $dependencies[$alias] = $load_source;
@@ -207,13 +207,13 @@  discard block
 block discarded – undo
207 207
         // ie: with A = B + C, entries in B take precedence over duplicate entries in C
208 208
         // Union is way faster than array_merge() but should be used with caution...
209 209
         // especially with numerically indexed arrays
210
-        $dependencies += self::$_instance->_dependency_map[ $class ];
210
+        $dependencies += self::$_instance->_dependency_map[$class];
211 211
         // now we need to ensure that the resulting dependencies
212 212
         // array only has the entries that are required for the class
213 213
         // so first count how many dependencies were originally registered for the class
214
-        $dependency_count = count(self::$_instance->_dependency_map[ $class ]);
214
+        $dependency_count = count(self::$_instance->_dependency_map[$class]);
215 215
         // if that count is non-zero (meaning dependencies were already registered)
216
-        self::$_instance->_dependency_map[ $class ] = $dependency_count
216
+        self::$_instance->_dependency_map[$class] = $dependency_count
217 217
             // then truncate the  final array to match that count
218 218
             ? array_slice($dependencies, 0, $dependency_count)
219 219
             // otherwise just take the incoming array because nothing previously existed
@@ -231,7 +231,7 @@  discard block
 block discarded – undo
231 231
      */
232 232
     public static function register_class_loader($class_name, $loader = 'load_core')
233 233
     {
234
-        if (! $loader instanceof Closure && strpos($class_name, '\\') !== false) {
234
+        if ( ! $loader instanceof Closure && strpos($class_name, '\\') !== false) {
235 235
             throw new DomainException(
236 236
                 esc_html__('Don\'t use class loaders for FQCNs.', 'event_espresso')
237 237
             );
@@ -255,7 +255,7 @@  discard block
 block discarded – undo
255 255
             );
256 256
         }
257 257
         $class_name = self::$_instance->get_alias($class_name);
258
-        if (! isset(self::$_instance->_class_loaders[$class_name])) {
258
+        if ( ! isset(self::$_instance->_class_loaders[$class_name])) {
259 259
             self::$_instance->_class_loaders[$class_name] = $loader;
260 260
             return true;
261 261
         }
@@ -340,7 +340,7 @@  discard block
 block discarded – undo
340 340
     public function class_loader($class_name)
341 341
     {
342 342
         // all legacy models use load_model()
343
-        if(strpos($class_name, 'EEM_') === 0){
343
+        if (strpos($class_name, 'EEM_') === 0) {
344 344
             return 'load_model';
345 345
         }
346 346
         $class_name = $this->get_alias($class_name);
@@ -369,7 +369,7 @@  discard block
 block discarded – undo
369 369
     public function add_alias($class_name, $alias, $for_class = '')
370 370
     {
371 371
         if ($for_class !== '') {
372
-            if (! isset($this->_aliases[$for_class])) {
372
+            if ( ! isset($this->_aliases[$for_class])) {
373 373
                 $this->_aliases[$for_class] = array();
374 374
             }
375 375
             $this->_aliases[$for_class][$class_name] = $alias;
@@ -415,10 +415,10 @@  discard block
 block discarded – undo
415 415
      */
416 416
     public function get_alias($class_name = '', $for_class = '')
417 417
     {
418
-        if (! $this->has_alias($class_name, $for_class)) {
418
+        if ( ! $this->has_alias($class_name, $for_class)) {
419 419
             return $class_name;
420 420
         }
421
-        if ($for_class !== '' && isset($this->_aliases[ $for_class ][ $class_name ])) {
421
+        if ($for_class !== '' && isset($this->_aliases[$for_class][$class_name])) {
422 422
             return $this->get_alias($this->_aliases[$for_class][$class_name], $for_class);
423 423
         }
424 424
         return $this->get_alias($this->_aliases[$class_name]);
@@ -679,10 +679,10 @@  discard block
 block discarded – undo
679 679
             'EE_Front_Controller'                  => 'load_core',
680 680
             'EE_Module_Request_Router'             => 'load_core',
681 681
             'EE_Registry'                          => 'load_core',
682
-            'EE_Request'                           => function () use (&$request) {
682
+            'EE_Request'                           => function() use (&$request) {
683 683
                 return $request;
684 684
             },
685
-            'EE_Response'                          => function () use (&$response) {
685
+            'EE_Response'                          => function() use (&$response) {
686 686
                 return $response;
687 687
             },
688 688
             'EE_Request_Handler'                   => 'load_core',
@@ -704,7 +704,7 @@  discard block
 block discarded – undo
704 704
             'EE_Messages_Data_Handler_Collection'  => 'load_lib',
705 705
             'EE_Message_Template_Group_Collection' => 'load_lib',
706 706
             'EE_Payment_Method_Manager'            => 'load_lib',
707
-            'EE_Messages_Generator'                => function () {
707
+            'EE_Messages_Generator'                => function() {
708 708
                 return EE_Registry::instance()->load_lib(
709 709
                     'Messages_Generator',
710 710
                     array(),
@@ -712,7 +712,7 @@  discard block
 block discarded – undo
712 712
                     false
713 713
                 );
714 714
             },
715
-            'EE_Messages_Template_Defaults'        => function ($arguments = array()) {
715
+            'EE_Messages_Template_Defaults'        => function($arguments = array()) {
716 716
                 return EE_Registry::instance()->load_lib(
717 717
                     'Messages_Template_Defaults',
718 718
                     $arguments,
@@ -725,22 +725,22 @@  discard block
 block discarded – undo
725 725
             // 'EEM_Message_Template_Group'           => 'load_model',
726 726
             // 'EEM_Message_Template'                 => 'load_model',
727 727
             //load_helper
728
-            'EEH_Parse_Shortcodes'                 => function () {
728
+            'EEH_Parse_Shortcodes'                 => function() {
729 729
                 if (EE_Registry::instance()->load_helper('Parse_Shortcodes')) {
730 730
                     return new EEH_Parse_Shortcodes();
731 731
                 }
732 732
                 return null;
733 733
             },
734
-            'EE_Template_Config'                   => function () {
734
+            'EE_Template_Config'                   => function() {
735 735
                 return EE_Config::instance()->template_settings;
736 736
             },
737
-            'EE_Currency_Config'                   => function () {
737
+            'EE_Currency_Config'                   => function() {
738 738
                 return EE_Config::instance()->currency;
739 739
             },
740
-            'EE_Registration_Config'                   => function () {
740
+            'EE_Registration_Config'                   => function() {
741 741
                 return EE_Config::instance()->registration;
742 742
             },
743
-            'EventEspresso\core\services\loaders\Loader' => function () {
743
+            'EventEspresso\core\services\loaders\Loader' => function() {
744 744
                 return LoaderFactory::getLoader();
745 745
             },
746 746
         );
@@ -793,7 +793,7 @@  discard block
 block discarded – undo
793 793
             'NoticesContainerInterface'                                            => 'EventEspresso\core\services\notices\NoticesContainerInterface',
794 794
             'EventEspresso\core\services\notices\NoticesContainerInterface'        => 'EventEspresso\core\services\notices\NoticesContainer',
795 795
         );
796
-        if (! (defined('DOING_AJAX') && DOING_AJAX) && is_admin()) {
796
+        if ( ! (defined('DOING_AJAX') && DOING_AJAX) && is_admin()) {
797 797
             $this->_aliases['EventEspresso\core\services\notices\NoticeConverterInterface'] = 'EventEspresso\core\services\notices\ConvertNoticesToAdminNotices';
798 798
         }
799 799
     }
Please login to merge, or discard this patch.
core/services/notices/NoticeInterface.php 1 patch
Indentation   +24 added lines, -24 removed lines patch added patch discarded remove patch
@@ -17,40 +17,40 @@
 block discarded – undo
17 17
 interface NoticeInterface
18 18
 {
19 19
 
20
-    /**
21
-     * @return string
22
-     */
23
-    public function type();
20
+	/**
21
+	 * @return string
22
+	 */
23
+	public function type();
24 24
 
25 25
 
26
-    /**
27
-     * @return string
28
-     */
29
-    public function message();
26
+	/**
27
+	 * @return string
28
+	 */
29
+	public function message();
30 30
 
31 31
 
32
-    /**
33
-     * @return bool
34
-     */
35
-    public function isDismissible();
32
+	/**
33
+	 * @return bool
34
+	 */
35
+	public function isDismissible();
36 36
 
37 37
 
38
-    /**
39
-     * @return string
40
-     */
41
-    public function file();
38
+	/**
39
+	 * @return string
40
+	 */
41
+	public function file();
42 42
 
43 43
 
44
-    /**
45
-     * @return string
46
-     */
47
-    public function func();
44
+	/**
45
+	 * @return string
46
+	 */
47
+	public function func();
48 48
 
49 49
 
50
-    /**
51
-     * @return string
52
-     */
53
-    public function line();
50
+	/**
51
+	 * @return string
52
+	 */
53
+	public function line();
54 54
 
55 55
 
56 56
 
Please login to merge, or discard this patch.
core/services/notices/NoticesContainerInterface.php 1 patch
Indentation   +81 added lines, -81 removed lines patch added patch discarded remove patch
@@ -16,129 +16,129 @@
 block discarded – undo
16 16
 interface NoticesContainerInterface
17 17
 {
18 18
 
19
-    /**
20
-     * @param string $notice
21
-     * @param bool   $dismissible
22
-     * @param string $file
23
-     * @param string $func
24
-     * @param string $line
25
-     */
26
-    public function addInformation($notice, $dismissible = true, $file = '', $func = '', $line = '');
19
+	/**
20
+	 * @param string $notice
21
+	 * @param bool   $dismissible
22
+	 * @param string $file
23
+	 * @param string $func
24
+	 * @param string $line
25
+	 */
26
+	public function addInformation($notice, $dismissible = true, $file = '', $func = '', $line = '');
27 27
 
28 28
 
29
-    /**
30
-     * @param string $notice
31
-     * @param bool   $dismissible
32
-     * @param string $file
33
-     * @param string $func
34
-     * @param string $line
35
-     * @return
36
-     */
37
-    public function addAttention($notice, $dismissible = true, $file = '', $func = '', $line = '');
29
+	/**
30
+	 * @param string $notice
31
+	 * @param bool   $dismissible
32
+	 * @param string $file
33
+	 * @param string $func
34
+	 * @param string $line
35
+	 * @return
36
+	 */
37
+	public function addAttention($notice, $dismissible = true, $file = '', $func = '', $line = '');
38 38
 
39 39
 
40 40
 
41
-    /**
42
-     * @param string $notice
43
-     * @param bool   $dismissible
44
-     * @param string $file
45
-     * @param string $func
46
-     * @param string $line
47
-     */
48
-    public function addError($notice, $dismissible = true, $file, $func, $line);
41
+	/**
42
+	 * @param string $notice
43
+	 * @param bool   $dismissible
44
+	 * @param string $file
45
+	 * @param string $func
46
+	 * @param string $line
47
+	 */
48
+	public function addError($notice, $dismissible = true, $file, $func, $line);
49 49
 
50 50
 
51 51
 
52
-    /**
53
-     * @param string $notice
54
-     * @param bool   $dismissible
55
-     * @param string $file
56
-     * @param string $func
57
-     * @param string $line
58
-     */
59
-    public function addSuccess($notice, $dismissible = true, $file = '', $func = '', $line = '');
52
+	/**
53
+	 * @param string $notice
54
+	 * @param bool   $dismissible
55
+	 * @param string $file
56
+	 * @param string $func
57
+	 * @param string $line
58
+	 */
59
+	public function addSuccess($notice, $dismissible = true, $file = '', $func = '', $line = '');
60 60
 
61 61
 
62 62
 
63
-    /**
64
-     * @return boolean
65
-     */
66
-    public function hasInformation();
63
+	/**
64
+	 * @return boolean
65
+	 */
66
+	public function hasInformation();
67 67
 
68 68
 
69 69
 
70
-    /**
71
-     * @return boolean
72
-     */
73
-    public function hasAttention();
70
+	/**
71
+	 * @return boolean
72
+	 */
73
+	public function hasAttention();
74 74
 
75 75
 
76 76
 
77
-    /**
78
-     * @return boolean
79
-     */
80
-    public function hasError();
77
+	/**
78
+	 * @return boolean
79
+	 */
80
+	public function hasError();
81 81
 
82 82
 
83 83
 
84
-    /**
85
-     * @return boolean
86
-     */
87
-    public function hasSuccess();
84
+	/**
85
+	 * @return boolean
86
+	 */
87
+	public function hasSuccess();
88 88
 
89 89
 
90 90
 
91
-    /**
92
-     * @return int
93
-     */
94
-    public function countInformation();
91
+	/**
92
+	 * @return int
93
+	 */
94
+	public function countInformation();
95 95
 
96 96
 
97 97
 
98
-    /**
99
-     * @return int
100
-     */
101
-    public function countAttention();
98
+	/**
99
+	 * @return int
100
+	 */
101
+	public function countAttention();
102 102
 
103 103
 
104 104
 
105
-    /**
106
-     * @return int
107
-     */
108
-    public function countError();
105
+	/**
106
+	 * @return int
107
+	 */
108
+	public function countError();
109 109
 
110 110
 
111 111
 
112
-    /**
113
-     * @return int
114
-     */
115
-    public function countSuccess();
112
+	/**
113
+	 * @return int
114
+	 */
115
+	public function countSuccess();
116 116
 
117 117
 
118 118
 
119
-    /**
120
-     * @return NoticeInterface[]
121
-     */
122
-    public function getInformation();
119
+	/**
120
+	 * @return NoticeInterface[]
121
+	 */
122
+	public function getInformation();
123 123
 
124 124
 
125 125
 
126
-    /**
127
-     * @return NoticeInterface[]
128
-     */
129
-    public function getAttention();
126
+	/**
127
+	 * @return NoticeInterface[]
128
+	 */
129
+	public function getAttention();
130 130
 
131 131
 
132 132
 
133
-    /**
134
-     * @return NoticeInterface[]
135
-     */
136
-    public function getError();
133
+	/**
134
+	 * @return NoticeInterface[]
135
+	 */
136
+	public function getError();
137 137
 
138 138
 
139 139
 
140
-    /**
141
-     * @return NoticeInterface[]
142
-     */
143
-    public function getSuccess();
140
+	/**
141
+	 * @return NoticeInterface[]
142
+	 */
143
+	public function getSuccess();
144 144
 }
Please login to merge, or discard this patch.
core/services/notices/AdminNotice.php 2 patches
Indentation   +115 added lines, -115 removed lines patch added patch discarded remove patch
@@ -17,121 +17,121 @@
 block discarded – undo
17 17
 class AdminNotice
18 18
 {
19 19
 
20
-    const ERROR       = 'notice-error';
21
-
22
-    const WARNING     = 'notice-warning';
23
-
24
-    const SUCCESS     = 'notice-success';
25
-
26
-    const INFORMATION = 'notice-info';
27
-
28
-    const DISMISSABLE = ' is-dismissible';
29
-
30
-    /**
31
-     * generic system notice to be converted into a WP admin notice
32
-     *
33
-     * @var NoticeInterface $notice
34
-     */
35
-    private $notice;
36
-
37
-
38
-    /**
39
-     * AdminNotice constructor.
40
-     *
41
-     * @param NoticeInterface $notice
42
-     * @param bool            $display_now
43
-     */
44
-    public function __construct(NoticeInterface $notice, $display_now = true)
45
-    {
46
-        $this->notice = $notice;
47
-        if (! did_action('admin_notices')) {
48
-            add_action('admin_notices', array($this, 'displayNotice'));
49
-        } elseif ($display_now) {
50
-            $this->displayNotice();
51
-        }
52
-    }
53
-
54
-
55
-    /**
56
-     * @return void
57
-     */
58
-    public function displayNotice()
59
-    {
60
-        echo $this->getNotice();
61
-    }
62
-
63
-
64
-    /**
65
-     * produces something  like:
66
-     *  <div class="notice notice-success is-dismissible event-espresso-admin-notice">
67
-     *      <p>YOU DID IT!</p>
68
-     *      <button type="button" class="notice-dismiss"><span class="screen-reader-text">Dismiss this
69
-     *      notice.</span></button>
70
-     *  </div>
71
-     *
72
-     * @return string
73
-     */
74
-    public function getNotice()
75
-    {
76
-        return sprintf(
77
-            '<div class="notice %1$s%2$s event-espresso-admin-notice"><p>%3$s</p></div>',
78
-            $this->getType(),
79
-            $this->notice->isDismissible() ? AdminNotice::DISMISSABLE : '',
80
-            $this->getMessage()
81
-        );
82
-    }
83
-
84
-
85
-    /**
86
-     * @return string
87
-     */
88
-    private function getType()
89
-    {
90
-        switch ($this->notice->type()) {
91
-            case Notice::ERROR :
92
-                return AdminNotice::ERROR;
93
-                break;
94
-            case Notice::ATTENTION :
95
-                return AdminNotice::WARNING;
96
-                break;
97
-            case Notice::SUCCESS :
98
-                return AdminNotice::SUCCESS;
99
-                break;
100
-            case Notice::INFORMATION :
101
-            default:
102
-                return AdminNotice::INFORMATION;
103
-                break;
104
-        }
105
-    }
106
-
107
-
108
-    /**
109
-     * @return string
110
-     */
111
-    protected function getMessage()
112
-    {
113
-        $message = $this->notice->message();
114
-        if (WP_DEBUG && $this->getType() === AdminNotice::ERROR) {
115
-            $message .= '<br/><span class="tiny-text">' . $this->generateErrorCode() . '</span>';
116
-        }
117
-        return $message;
118
-    }
119
-
120
-
121
-    /**
122
-     * create error code from filepath, function name,
123
-     * and line number where notice was generated
124
-     *
125
-     * @return string
126
-     */
127
-    protected function generateErrorCode()
128
-    {
129
-        $file       = explode('.', basename($this->notice->file()));
130
-        $error_code = ! empty($file[0]) ? $file[0] : '';
131
-        $error_code .= ! empty($error_code) ? ' - ' . $this->notice->func() : $this->notice->func();
132
-        $error_code .= ' - ' . $this->notice->line();
133
-        return $error_code;
134
-    }
20
+	const ERROR       = 'notice-error';
21
+
22
+	const WARNING     = 'notice-warning';
23
+
24
+	const SUCCESS     = 'notice-success';
25
+
26
+	const INFORMATION = 'notice-info';
27
+
28
+	const DISMISSABLE = ' is-dismissible';
29
+
30
+	/**
31
+	 * generic system notice to be converted into a WP admin notice
32
+	 *
33
+	 * @var NoticeInterface $notice
34
+	 */
35
+	private $notice;
36
+
37
+
38
+	/**
39
+	 * AdminNotice constructor.
40
+	 *
41
+	 * @param NoticeInterface $notice
42
+	 * @param bool            $display_now
43
+	 */
44
+	public function __construct(NoticeInterface $notice, $display_now = true)
45
+	{
46
+		$this->notice = $notice;
47
+		if (! did_action('admin_notices')) {
48
+			add_action('admin_notices', array($this, 'displayNotice'));
49
+		} elseif ($display_now) {
50
+			$this->displayNotice();
51
+		}
52
+	}
53
+
54
+
55
+	/**
56
+	 * @return void
57
+	 */
58
+	public function displayNotice()
59
+	{
60
+		echo $this->getNotice();
61
+	}
62
+
63
+
64
+	/**
65
+	 * produces something  like:
66
+	 *  <div class="notice notice-success is-dismissible event-espresso-admin-notice">
67
+	 *      <p>YOU DID IT!</p>
68
+	 *      <button type="button" class="notice-dismiss"><span class="screen-reader-text">Dismiss this
69
+	 *      notice.</span></button>
70
+	 *  </div>
71
+	 *
72
+	 * @return string
73
+	 */
74
+	public function getNotice()
75
+	{
76
+		return sprintf(
77
+			'<div class="notice %1$s%2$s event-espresso-admin-notice"><p>%3$s</p></div>',
78
+			$this->getType(),
79
+			$this->notice->isDismissible() ? AdminNotice::DISMISSABLE : '',
80
+			$this->getMessage()
81
+		);
82
+	}
83
+
84
+
85
+	/**
86
+	 * @return string
87
+	 */
88
+	private function getType()
89
+	{
90
+		switch ($this->notice->type()) {
91
+			case Notice::ERROR :
92
+				return AdminNotice::ERROR;
93
+				break;
94
+			case Notice::ATTENTION :
95
+				return AdminNotice::WARNING;
96
+				break;
97
+			case Notice::SUCCESS :
98
+				return AdminNotice::SUCCESS;
99
+				break;
100
+			case Notice::INFORMATION :
101
+			default:
102
+				return AdminNotice::INFORMATION;
103
+				break;
104
+		}
105
+	}
106
+
107
+
108
+	/**
109
+	 * @return string
110
+	 */
111
+	protected function getMessage()
112
+	{
113
+		$message = $this->notice->message();
114
+		if (WP_DEBUG && $this->getType() === AdminNotice::ERROR) {
115
+			$message .= '<br/><span class="tiny-text">' . $this->generateErrorCode() . '</span>';
116
+		}
117
+		return $message;
118
+	}
119
+
120
+
121
+	/**
122
+	 * create error code from filepath, function name,
123
+	 * and line number where notice was generated
124
+	 *
125
+	 * @return string
126
+	 */
127
+	protected function generateErrorCode()
128
+	{
129
+		$file       = explode('.', basename($this->notice->file()));
130
+		$error_code = ! empty($file[0]) ? $file[0] : '';
131
+		$error_code .= ! empty($error_code) ? ' - ' . $this->notice->func() : $this->notice->func();
132
+		$error_code .= ' - ' . $this->notice->line();
133
+		return $error_code;
134
+	}
135 135
 
136 136
 
137 137
 }
Please login to merge, or discard this patch.
Spacing   +4 added lines, -4 removed lines patch added patch discarded remove patch
@@ -44,7 +44,7 @@  discard block
 block discarded – undo
44 44
     public function __construct(NoticeInterface $notice, $display_now = true)
45 45
     {
46 46
         $this->notice = $notice;
47
-        if (! did_action('admin_notices')) {
47
+        if ( ! did_action('admin_notices')) {
48 48
             add_action('admin_notices', array($this, 'displayNotice'));
49 49
         } elseif ($display_now) {
50 50
             $this->displayNotice();
@@ -112,7 +112,7 @@  discard block
 block discarded – undo
112 112
     {
113 113
         $message = $this->notice->message();
114 114
         if (WP_DEBUG && $this->getType() === AdminNotice::ERROR) {
115
-            $message .= '<br/><span class="tiny-text">' . $this->generateErrorCode() . '</span>';
115
+            $message .= '<br/><span class="tiny-text">'.$this->generateErrorCode().'</span>';
116 116
         }
117 117
         return $message;
118 118
     }
@@ -128,8 +128,8 @@  discard block
 block discarded – undo
128 128
     {
129 129
         $file       = explode('.', basename($this->notice->file()));
130 130
         $error_code = ! empty($file[0]) ? $file[0] : '';
131
-        $error_code .= ! empty($error_code) ? ' - ' . $this->notice->func() : $this->notice->func();
132
-        $error_code .= ' - ' . $this->notice->line();
131
+        $error_code .= ! empty($error_code) ? ' - '.$this->notice->func() : $this->notice->func();
132
+        $error_code .= ' - '.$this->notice->line();
133 133
         return $error_code;
134 134
     }
135 135
 
Please login to merge, or discard this patch.
core/services/notices/ConvertNoticesToAdminNotices.php 2 patches
Indentation   +38 added lines, -38 removed lines patch added patch discarded remove patch
@@ -19,44 +19,44 @@
 block discarded – undo
19 19
 class ConvertNoticesToAdminNotices extends NoticeConverter
20 20
 {
21 21
 
22
-    /**
23
-     * Converts Notice objects into AdminNotice notifications
24
-     *
25
-     * @param NoticesContainerInterface $notices
26
-     * @throws DomainException
27
-     */
28
-    public function process(NoticesContainerInterface $notices)
29
-    {
30
-        if ($notices->hasAttention()) {
31
-            foreach ($notices->getAttention() as $notice) {
32
-                new AdminNotice($notice);
33
-            }
34
-        }
35
-        if ($notices->hasError()) {
36
-            $error_string = esc_html__('The following errors occurred:', 'event_espresso');
37
-            foreach ($notices->getError() as $notice) {
38
-                if ($this->getThrowExceptions()) {
39
-                    $error_string .= '<br />' . $notice->message();
40
-                } else {
41
-                    new AdminNotice($notice);
42
-                }
43
-            }
44
-            if ($this->getThrowExceptions()) {
45
-                throw new DomainException($error_string);
46
-            }
47
-        }
48
-        if ($notices->hasSuccess()) {
49
-            foreach ($notices->getSuccess() as $notice) {
50
-                new AdminNotice($notice);
51
-            }
52
-        }
53
-        if ($notices->hasInformation()) {
54
-            foreach ($notices->getInformation() as $notice) {
55
-                new AdminNotice($notice);
56
-            }
57
-        }
58
-        $this->clearNotices();
59
-    }
22
+	/**
23
+	 * Converts Notice objects into AdminNotice notifications
24
+	 *
25
+	 * @param NoticesContainerInterface $notices
26
+	 * @throws DomainException
27
+	 */
28
+	public function process(NoticesContainerInterface $notices)
29
+	{
30
+		if ($notices->hasAttention()) {
31
+			foreach ($notices->getAttention() as $notice) {
32
+				new AdminNotice($notice);
33
+			}
34
+		}
35
+		if ($notices->hasError()) {
36
+			$error_string = esc_html__('The following errors occurred:', 'event_espresso');
37
+			foreach ($notices->getError() as $notice) {
38
+				if ($this->getThrowExceptions()) {
39
+					$error_string .= '<br />' . $notice->message();
40
+				} else {
41
+					new AdminNotice($notice);
42
+				}
43
+			}
44
+			if ($this->getThrowExceptions()) {
45
+				throw new DomainException($error_string);
46
+			}
47
+		}
48
+		if ($notices->hasSuccess()) {
49
+			foreach ($notices->getSuccess() as $notice) {
50
+				new AdminNotice($notice);
51
+			}
52
+		}
53
+		if ($notices->hasInformation()) {
54
+			foreach ($notices->getInformation() as $notice) {
55
+				new AdminNotice($notice);
56
+			}
57
+		}
58
+		$this->clearNotices();
59
+	}
60 60
 
61 61
 }
62 62
 // Location: ConvertNoticesToAdminNotices.php
Please login to merge, or discard this patch.
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -36,7 +36,7 @@
 block discarded – undo
36 36
             $error_string = esc_html__('The following errors occurred:', 'event_espresso');
37 37
             foreach ($notices->getError() as $notice) {
38 38
                 if ($this->getThrowExceptions()) {
39
-                    $error_string .= '<br />' . $notice->message();
39
+                    $error_string .= '<br />'.$notice->message();
40 40
                 } else {
41 41
                     new AdminNotice($notice);
42 42
                 }
Please login to merge, or discard this patch.