Duplicate code is one of the most pungent code smells. A rule that is often used is to re-structure code once it is duplicated in three or more places.
Common duplication problems, and corresponding solutions are:
Complex classes like Registrations_Admin_Page often do a lot of different things. To break such a class down, we need to identify a cohesive component within that class. A common approach to find such a component is to look for fields/methods that share the same prefixes, or suffixes. You can also have a look at the cohesion graph to spot any un-connected, or weakly-connected components.
Once you have determined the fields that belong together, you can apply the Extract Class refactoring. If the component makes sense as a sub-class, Extract Subclass is also a candidate, and is often faster.
While breaking up the class, it is a good idea to analyze how other classes use Registrations_Admin_Page, and based on these observations, apply Extract Interface, too.
1 | <?php if ( ! defined('EVENT_ESPRESSO_VERSION')) exit('No direct script access allowed'); |
||
24 | class Registrations_Admin_Page extends EE_Admin_Page_CPT { |
||
25 | |||
26 | /** |
||
27 | * |
||
28 | * @var EE_Registration |
||
29 | */ |
||
30 | private $_registration; |
||
31 | private $_reg_event; |
||
32 | private $_session; |
||
33 | private static $_reg_status; |
||
34 | |||
35 | |||
36 | |||
37 | /** |
||
38 | * constructor |
||
39 | * |
||
40 | * @Constructor |
||
41 | * @access public |
||
42 | * @param bool $routing |
||
43 | * @return Registrations_Admin_Page |
||
|
|||
44 | */ |
||
45 | public function __construct( $routing = TRUE ) { |
||
46 | parent::__construct( $routing ); |
||
47 | } |
||
48 | |||
49 | |||
50 | |||
51 | |||
52 | |||
53 | |||
54 | protected function _init_page_props() { |
||
55 | $this->page_slug = REG_PG_SLUG; |
||
56 | $this->_admin_base_url = REG_ADMIN_URL; |
||
57 | $this->_admin_base_path = REG_ADMIN; |
||
58 | $this->page_label = __('Registrations', 'event_espresso'); |
||
59 | $this->_cpt_routes = array( |
||
60 | 'add_new_attendee' => 'espresso_attendees', |
||
61 | 'edit_attendee' => 'espresso_attendees', |
||
62 | 'insert_attendee' => 'espresso_attendees', |
||
63 | 'update_attendee' => 'espresso_attendees' |
||
64 | ); |
||
65 | $this->_cpt_model_names = array( |
||
66 | 'add_new_attendee' => 'EEM_Attendee', |
||
67 | 'edit_attendee' => 'EEM_Attendee' |
||
68 | ); |
||
69 | $this->_cpt_edit_routes = array( |
||
70 | 'espresso_attendees' => 'edit_attendee' |
||
71 | ); |
||
72 | $this->_pagenow_map = array( |
||
73 | 'add_new_attendee' => 'post-new.php', |
||
74 | 'edit_attendee' => 'post.php', |
||
75 | 'trash' => 'post.php' |
||
76 | ); |
||
77 | |||
78 | add_action('edit_form_after_title', array($this, 'after_title_form_fields'), 10 ); |
||
79 | //add filters so that the comment urls don't take users to a confusing 404 page |
||
80 | add_filter('get_comment_link', array( $this, 'clear_comment_link' ), 10, 3 ); |
||
81 | } |
||
82 | |||
83 | |||
84 | public function clear_comment_link( $link, $comment, $args ) { |
||
85 | //gotta make sure this only happens on this route |
||
86 | $post_type = get_post_type( $comment->comment_post_ID); |
||
87 | if ( $post_type == 'espresso_attendees' ) |
||
88 | return '#commentsdiv'; |
||
89 | return $link; |
||
90 | } |
||
91 | |||
92 | |||
93 | protected function _ajax_hooks() { |
||
94 | //todo: all hooks for registrations ajax goes in here |
||
95 | add_action( 'wp_ajax_toggle_checkin_status', array( $this, 'toggle_checkin_status' )); |
||
96 | } |
||
97 | |||
98 | |||
99 | |||
100 | |||
101 | |||
102 | protected function _define_page_props() { |
||
103 | $this->_admin_page_title = $this->page_label; |
||
104 | $this->_labels = array( |
||
105 | 'buttons' => array( |
||
106 | 'add-registrant' => __('Add New Registration', 'event_espresso'), |
||
107 | 'add-attendee' => __('Add Contact', 'event_espresso'), |
||
108 | 'edit' => __('Edit Contact', 'event_espresso'), |
||
109 | 'report'=> __("Event Registrations CSV Report", "event_espresso"), |
||
110 | 'report_all' => __( 'All Registrations CSV Report', 'event_espresso' ), |
||
111 | 'contact_list_report' => __( 'Contact List Report', 'event_espresso' ), |
||
112 | 'contact_list_export'=> __("Export Data", "event_espresso"), |
||
113 | ), |
||
114 | 'publishbox' => array( |
||
115 | 'add_new_attendee' => __("Add Contact Record", 'event_espresso'), |
||
116 | 'edit_attendee' => __("Update Contact Record", 'event_espresso') |
||
117 | ), |
||
118 | 'hide_add_button_on_cpt_route' => array( |
||
119 | 'edit_attendee' => true |
||
120 | ) |
||
121 | ); |
||
122 | } |
||
123 | |||
124 | |||
125 | |||
126 | |||
127 | |||
128 | |||
129 | |||
130 | /** |
||
131 | * grab url requests and route them |
||
132 | * @access private |
||
133 | * @return void |
||
134 | */ |
||
135 | public function _set_page_routes() { |
||
372 | |||
373 | |||
374 | |||
375 | |||
376 | |||
377 | protected function _set_page_config() { |
||
378 | $this->_page_config = array( |
||
379 | |||
380 | 'default' => array( |
||
381 | 'nav' => array( |
||
382 | 'label' => __('Overview', 'event_espresso'), |
||
383 | 'order' => 5 |
||
384 | ), |
||
385 | 'help_tabs' => array( |
||
386 | 'registrations_overview_help_tab' => array( |
||
387 | 'title' => __('Registrations Overview', 'event_espresso'), |
||
388 | 'filename' => 'registrations_overview' |
||
389 | ), |
||
390 | 'registrations_overview_table_column_headings_help_tab' => array( |
||
391 | 'title' => __('Registrations Table Column Headings', 'event_espresso'), |
||
392 | 'filename' => 'registrations_overview_table_column_headings' |
||
393 | ), |
||
394 | 'registrations_overview_filters_help_tab' => array( |
||
395 | 'title' => __('Registration Filters', 'event_espresso'), |
||
396 | 'filename' => 'registrations_overview_filters' |
||
397 | ), |
||
398 | 'registrations_overview_views_help_tab' => array( |
||
399 | 'title' => __('Registration Views', 'event_espresso'), |
||
400 | 'filename' => 'registrations_overview_views' |
||
401 | ), |
||
402 | 'registrations_overview_other_help_tab' => array( |
||
403 | 'title' => __('Registrations Other', 'event_espresso'), |
||
404 | 'filename' => 'registrations_overview_other' |
||
405 | ) |
||
406 | ), |
||
407 | 'help_tour' => array( 'Registration_Overview_Help_Tour' ), |
||
408 | 'qtips' => array('Registration_List_Table_Tips'), |
||
409 | 'list_table' => 'EE_Registrations_List_Table', |
||
410 | 'require_nonce' => FALSE |
||
411 | ), |
||
412 | |||
413 | 'view_registration' => array( |
||
414 | 'nav' => array( |
||
415 | 'label' => __('REG Details', 'event_espresso'), |
||
416 | 'order' => 15, |
||
417 | 'url' => isset($this->_req_data['_REG_ID']) ? add_query_arg(array('_REG_ID' => $this->_req_data['_REG_ID'] ), $this->_current_page_view_url ) : $this->_admin_base_url, |
||
418 | 'persistent' => FALSE |
||
419 | ), |
||
420 | 'help_tabs' => array( |
||
421 | 'registrations_details_help_tab' => array( |
||
422 | 'title' => __('Registration Details', 'event_espresso'), |
||
423 | 'filename' => 'registrations_details' |
||
424 | ), |
||
425 | 'registrations_details_table_help_tab' => array( |
||
426 | 'title' => __('Registration Details Table', 'event_espresso'), |
||
427 | 'filename' => 'registrations_details_table' |
||
428 | ), |
||
429 | 'registrations_details_form_answers_help_tab' => array( |
||
430 | 'title' => __('Registration Form Answers', 'event_espresso'), |
||
431 | 'filename' => 'registrations_details_form_answers' |
||
432 | ), |
||
433 | 'registrations_details_registrant_details_help_tab' => array( |
||
434 | 'title' => __('Contact Details', 'event_espresso'), |
||
435 | 'filename' => 'registrations_details_registrant_details' |
||
436 | ) |
||
437 | ), |
||
438 | 'help_tour' => array( 'Registration_Details_Help_Tour' ), |
||
439 | 'metaboxes' => array_merge( $this->_default_espresso_metaboxes, array( '_registration_details_metaboxes' ) ), |
||
440 | 'require_nonce' => FALSE |
||
441 | ), |
||
442 | |||
443 | 'new_registration' => array( |
||
444 | 'nav' => array( |
||
445 | 'label' => __('Add New Registration', 'event_espresso'), |
||
446 | 'url' => '#', |
||
447 | 'order' => 15, |
||
448 | 'persistent' => FALSE |
||
449 | ), |
||
450 | 'metaboxes' => $this->_default_espresso_metaboxes, |
||
451 | 'labels' => array( |
||
452 | 'publishbox' => __('Save Registration', 'event_espresso') |
||
453 | ), |
||
454 | 'require_nonce' => FALSE |
||
455 | ), |
||
456 | |||
457 | 'add_new_attendee' => array( |
||
458 | 'nav' => array( |
||
459 | 'label' => __('Add Contact', 'event_espresso'), |
||
460 | 'order' => 15, |
||
461 | 'persistent' => FALSE |
||
462 | ), |
||
463 | 'metaboxes' => array_merge( $this->_default_espresso_metaboxes, array('_publish_post_box', 'attendee_editor_metaboxes' ) ), |
||
464 | 'require_nonce' => FALSE |
||
465 | ), |
||
466 | |||
467 | 'edit_attendee' => array( |
||
468 | 'nav' => array( |
||
469 | 'label' => __('Edit Contact', 'event_espresso'), |
||
470 | 'order' => 15, |
||
471 | 'persistent' => FALSE, |
||
472 | 'url' => isset($this->_req_data['ATT_ID']) ? add_query_arg(array('ATT_ID' => $this->_req_data['ATT_ID'] ), $this->_current_page_view_url ) : $this->_admin_base_url |
||
473 | ), |
||
474 | 'metaboxes' => array('attendee_editor_metaboxes'), |
||
475 | 'require_nonce' => FALSE |
||
476 | ), |
||
477 | |||
478 | 'contact_list' => array( |
||
479 | 'nav' => array( |
||
480 | 'label' => __('Contact List', 'event_espresso'), |
||
481 | 'order' => 20 |
||
482 | ), |
||
483 | 'list_table' => 'EE_Attendee_Contact_List_Table', |
||
484 | 'help_tabs' => array( |
||
485 | 'registrations_contact_list_help_tab' => array( |
||
486 | 'title' => __('Registrations Contact List', 'event_espresso'), |
||
487 | 'filename' => 'registrations_contact_list' |
||
488 | ), |
||
489 | 'registrations_contact-list_table_column_headings_help_tab' => array( |
||
490 | 'title' => __('Contact List Table Column Headings', 'event_espresso'), |
||
491 | 'filename' => 'registrations_contact_list_table_column_headings' |
||
492 | ), |
||
493 | 'registrations_contact_list_views_help_tab' => array( |
||
494 | 'title' => __('Contact List Views', 'event_espresso'), |
||
495 | 'filename' => 'registrations_contact_list_views' |
||
496 | ), |
||
497 | 'registrations_contact_list_other_help_tab' => array( |
||
498 | 'title' => __('Contact List Other', 'event_espresso'), |
||
499 | 'filename' => 'registrations_contact_list_other' |
||
500 | ) |
||
501 | ), |
||
502 | 'help_tour' => array( 'Contact_List_Help_Tour' ), |
||
503 | 'metaboxes' => array(), |
||
504 | 'require_nonce' => FALSE |
||
505 | ), |
||
506 | |||
507 | //override default cpt routes |
||
508 | 'create_new' => '', |
||
509 | 'edit' => '' |
||
510 | |||
511 | ); |
||
512 | } |
||
513 | |||
514 | |||
515 | /** |
||
516 | * The below methods aren't used by this class currently |
||
517 | */ |
||
518 | protected function _add_screen_options() {} |
||
519 | protected function _add_feature_pointers() {} |
||
520 | public function admin_init() { |
||
521 | EE_Registry::$i18n_js_strings[ 'update_att_qstns' ] = __( 'click "Update Registration Questions" to save your changes', 'event_espresso' ); |
||
522 | } |
||
523 | public function admin_notices() {} |
||
524 | public function admin_footer_scripts() {} |
||
525 | |||
526 | |||
527 | |||
528 | |||
529 | |||
530 | |||
531 | |||
532 | |||
533 | /** |
||
534 | * get list of registration statuses |
||
535 | * @access private |
||
536 | * @return void |
||
537 | */ |
||
538 | private function _get_registration_status_array() { |
||
539 | self::$_reg_status = EEM_Registration::reg_status_array( array(), TRUE); |
||
540 | } |
||
541 | |||
542 | |||
543 | |||
544 | |||
545 | protected function _add_screen_options_default() { |
||
546 | $this->_per_page_screen_option(); |
||
547 | } |
||
548 | |||
549 | View Code Duplication | protected function _add_screen_options_contact_list() { |
|
550 | $page_title = $this->_admin_page_title; |
||
551 | $this->_admin_page_title = __("Contacts", 'event_espresso'); |
||
552 | $this->_per_page_screen_option(); |
||
553 | $this->_admin_page_title = $page_title; |
||
554 | } |
||
555 | |||
556 | |||
557 | |||
558 | |||
559 | View Code Duplication | public function load_scripts_styles() { |
|
560 | //style |
||
561 | //wp_register_style('espresso_attendees', ATT_ASSETS_URL . 'espresso_attendees_admin.css', array(), EVENT_ESPRESSO_VERSION ); |
||
562 | wp_register_style('espresso_reg', REG_ASSETS_URL . 'espresso_registrations_admin.css', array('ee-admin-css'), EVENT_ESPRESSO_VERSION ); |
||
563 | wp_enqueue_style('espresso_reg'); |
||
564 | |||
565 | //script |
||
566 | wp_register_script('espresso_reg', REG_ASSETS_URL . 'espresso_registrations_admin.js', array('jquery-ui-datepicker', 'jquery-ui-draggable', 'ee_admin_js'), EVENT_ESPRESSO_VERSION, TRUE); |
||
567 | wp_enqueue_script('espresso_reg'); |
||
568 | } |
||
569 | |||
570 | |||
571 | |||
572 | public function load_scripts_styles_edit_attendee() { |
||
573 | //stuff to only show up on our attendee edit details page. |
||
574 | $attendee_details_translations = array( |
||
575 | 'att_publish_text' => sprintf( __('Created on: <b>%1$s</b>', 'event_espresso'), $this->_cpt_model_obj->get_datetime('ATT_created') ) |
||
576 | ); |
||
577 | wp_localize_script( 'espresso_reg', 'ATTENDEE_DETAILS', $attendee_details_translations ); |
||
578 | wp_enqueue_script('jquery-validate'); |
||
579 | } |
||
580 | |||
581 | |||
582 | public function load_scripts_styles_view_registration() { |
||
587 | |||
588 | |||
589 | |||
590 | |||
591 | |||
592 | |||
593 | public function load_scripts_styles_contact_list() { |
||
594 | wp_deregister_style('espresso_reg'); |
||
595 | wp_register_style('espresso_att', REG_ASSETS_URL . 'espresso_attendees_admin.css', array('ee-admin-css'), EVENT_ESPRESSO_VERSION ); |
||
596 | wp_enqueue_style('espresso_att'); |
||
597 | } |
||
598 | |||
599 | |||
600 | |||
601 | |||
602 | |||
603 | public function load_scripts_styles_new_registration() { |
||
604 | wp_register_script( 'ee-spco-for-admin', REG_ASSETS_URL . 'spco_for_admin.js', array('underscore', 'jquery'), EVENT_ESPRESSO_VERSION, TRUE ); |
||
605 | wp_enqueue_script('ee-spco-for-admin'); |
||
606 | add_filter('FHEE__EED_Ticket_Selector__load_tckt_slctr_assets', '__return_true' ); |
||
607 | EE_Form_Section_Proper::wp_enqueue_scripts(); |
||
608 | EED_Ticket_Selector::load_tckt_slctr_assets(); |
||
609 | EE_Datepicker_Input::enqueue_styles_and_scripts(); |
||
610 | } |
||
611 | |||
612 | |||
613 | |||
614 | |||
615 | |||
616 | public function AHEE__EE_Admin_Page__route_admin_request_resend_registration() { |
||
617 | add_filter('FHEE_load_EE_messages', '__return_true'); |
||
618 | } |
||
619 | |||
620 | |||
621 | |||
622 | public function AHEE__EE_Admin_Page__route_admin_request_approve_registration() { |
||
623 | add_filter('FHEE_load_EE_messages', '__return_true'); |
||
624 | } |
||
625 | |||
626 | |||
627 | |||
628 | protected function _set_list_table_views_default() { |
||
629 | |||
630 | //for notification related bulk actions we need to make sure only active messengers have an option. |
||
631 | EED_Messages::set_autoloaders(); |
||
632 | $EEMSG = EE_Registry::instance()->load_lib('messages'); |
||
633 | $active_mts = $EEMSG->get_active_message_types(); |
||
634 | //key= bulk_action_slug, value= message type. |
||
635 | $match_array = array( |
||
636 | 'approve_registration' => 'registration', |
||
637 | 'decline_registration' => 'declined_registration', |
||
638 | 'pending_registration' => 'pending_approval', |
||
639 | 'no_approve_registration' => 'not_approved_registration', |
||
640 | 'cancel_registration' => 'cancelled_registration' |
||
641 | ); |
||
642 | |||
643 | /** setup reg status bulk actions **/ |
||
644 | $def_reg_status_actions['approve_registration'] = __('Approve Registrations', 'event_espresso'); |
||
645 | View Code Duplication | if ( in_array( $match_array['approve_registration'], $active_mts ) && EE_Registry::instance()->CAP->current_user_can( 'ee_send_message', 'batch_send_messages' ) ) { |
|
646 | $def_reg_status_actions['approve_and_notify_registration'] = __('Approve and Notify Registrations', 'event_espresso'); |
||
647 | } |
||
648 | $def_reg_status_actions['decline_registration'] = __('Decline Registrations', 'event_espresso'); |
||
649 | View Code Duplication | if ( in_array( $match_array['decline_registration'], $active_mts ) && EE_Registry::instance()->CAP->current_user_can( 'ee_send_message', 'batch_send_messages' ) ) { |
|
650 | $def_reg_status_actions['decline_and_notify_registration'] = __('Decline and Notify Registrations', 'event_espresso'); |
||
651 | } |
||
652 | $def_reg_status_actions['pending_registration'] = __('Set Registrations to Pending Payment', 'event_espresso'); |
||
653 | View Code Duplication | if ( in_array( $match_array['pending_registration'], $active_mts ) && EE_Registry::instance()->CAP->current_user_can( 'ee_send_message', 'batch_send_messages' ) ) { |
|
654 | $def_reg_status_actions['pending_and_notify_registration'] = __('Set Registrations to Pending Payment and Notify', 'event_espresso'); |
||
655 | } |
||
656 | $def_reg_status_actions['no_approve_registration'] = __('Set Registrations to Not Approved', 'event_espresso'); |
||
657 | View Code Duplication | if ( in_array( $match_array['no_approve_registration'], $active_mts ) && EE_Registry::instance()->CAP->current_user_can( 'ee_send_message', 'batch_send_messages' ) ) { |
|
658 | $def_reg_status_actions['no_approve_and_notify_registration'] = __('Set Registrations to Not Approved and Notify', 'event_espresso'); |
||
659 | } |
||
660 | $def_reg_status_actions['cancel_registration'] = __('Cancel Registrations', 'event_espresso'); |
||
661 | View Code Duplication | if ( in_array( $match_array['cancel_registration'], $active_mts ) && EE_Registry::instance()->CAP->current_user_can( 'ee_send_message', 'batch_send_messages' ) ) { |
|
662 | $def_reg_status_actions['cancel_and_notify_registration'] = __('Cancel Registrations and Notify', 'event_espresso'); |
||
663 | } |
||
664 | |||
665 | $this->_views = array( |
||
666 | 'all' => array( |
||
667 | 'slug' => 'all', |
||
668 | 'label' => __('View All Registrations', 'event_espresso'), |
||
669 | 'count' => 0, |
||
670 | 'bulk_action' => array_merge( $def_reg_status_actions, array( |
||
671 | 'trash_registrations' => __('Trash Registrations', 'event_espresso') |
||
672 | ) ) |
||
673 | ), |
||
674 | 'month' => array( |
||
675 | 'slug' => 'month', |
||
676 | 'label' => __('This Month', 'event_espresso'), |
||
677 | 'count' => 0, |
||
678 | 'bulk_action' => array_merge( $def_reg_status_actions, array( |
||
679 | 'trash_registrations' => __('Trash Registrations', 'event_espresso') |
||
680 | )) |
||
681 | ), |
||
682 | 'today' => array( |
||
683 | 'slug' => 'today', |
||
684 | 'label' => sprintf( __('Today - %s', 'event_espresso'), date('M d, Y', current_time('timestamp' ) ) ), |
||
685 | 'count' => 0, |
||
686 | 'bulk_action' => array_merge( $def_reg_status_actions, array( |
||
687 | 'trash_registrations' => __('Trash Registrations', 'event_espresso') |
||
688 | )) |
||
689 | ) |
||
690 | ); |
||
691 | |||
692 | if ( EE_Registry::instance()->CAP->current_user_can( 'ee_delete_registrations', 'espresso_registrations_delete_registration' ) ) { |
||
693 | $this->_views['incomplete'] = array( |
||
694 | 'slug' => 'incomplete', |
||
695 | 'label' => __('Incomplete', 'event_espresso'), |
||
696 | 'count' => 0, |
||
697 | 'bulk_action' => array( |
||
698 | 'trash_registrations' => __('Trash Registrations', 'event_espresso') |
||
699 | ) |
||
700 | ); |
||
701 | $this->_views['trash'] = array( |
||
702 | 'slug' => 'trash', |
||
703 | 'label' => __('Trash', 'event_espresso'), |
||
704 | 'count' => 0, |
||
705 | 'bulk_action' => array( |
||
706 | 'restore_registrations' => __('Restore Registrations', 'event_espresso'), |
||
707 | 'delete_registrations' => __('Delete Registrations Permanently', 'event_espresso') |
||
708 | ) |
||
709 | ); |
||
710 | } |
||
711 | } |
||
712 | |||
713 | |||
714 | |||
715 | |||
716 | protected function _set_list_table_views_contact_list() { |
||
717 | $this->_views = array( |
||
718 | 'in_use' => array( |
||
719 | 'slug' => 'in_use', |
||
720 | 'label' => __('In Use', 'event_espresso'), |
||
721 | 'count' => 0, |
||
722 | 'bulk_action' => array( |
||
723 | 'trash_attendees' => __('Move to Trash', 'event_espresso'), |
||
724 | ) |
||
725 | ) |
||
726 | ); |
||
727 | |||
728 | if ( EE_Registry::instance()->CAP->current_user_can( 'ee_delete_contacts', 'espresso_registrations_trash_attendees' ) ) { |
||
729 | $this->_views['trash'] = array( |
||
730 | 'slug' => 'trash', |
||
731 | 'label' => __('Trash', 'event_espresso'), |
||
732 | 'count' => 0, |
||
733 | 'bulk_action' => array( |
||
734 | 'restore_attendees' => __('Restore from Trash', 'event_espresso'), |
||
735 | ) |
||
736 | ); |
||
737 | } |
||
738 | } |
||
739 | |||
740 | |||
741 | |||
742 | |||
743 | |||
744 | protected function _registration_legend_items() { |
||
745 | $fc_items = array( |
||
746 | 'star-icon' => array( |
||
747 | 'class' => 'dashicons dashicons-star-filled lt-blue-icon ee-icon-size-8', |
||
748 | 'desc' => __('This is the Primary Registrant', 'event_espresso') |
||
749 | ), |
||
750 | 'view_details' => array( |
||
751 | 'class' => 'dashicons dashicons-clipboard', |
||
752 | 'desc' => __('View Registration Details', 'event_espresso') |
||
753 | ), |
||
754 | 'edit_attendee' => array( |
||
755 | 'class' => 'ee-icon ee-icon-user-edit ee-icon-size-16', |
||
756 | 'desc' => __('Edit Contact Details', 'event_espresso') |
||
757 | ), |
||
758 | 'view_transaction' => array( |
||
759 | 'class' => 'dashicons dashicons-cart', |
||
760 | 'desc' => __('View Transaction Details', 'event_espresso') |
||
761 | ), |
||
762 | 'view_invoice' => array( |
||
763 | 'class' => 'dashicons dashicons-media-spreadsheet', |
||
764 | 'desc' => __('View Transaction Invoice', 'event_espresso') |
||
765 | ), |
||
766 | ); |
||
767 | if ( EE_Registry::instance()->CAP->current_user_can( 'ee_send_message', 'espresso_registrations_resend_registration' ) ) { |
||
768 | $fc_items['resend_registration'] = array( |
||
769 | 'class' => 'dashicons dashicons-email-alt', |
||
770 | 'desc' => __('Resend Registration Details', 'event_espresso') |
||
771 | ); |
||
772 | } else { |
||
773 | $fc_items['blank'] = array( 'class' => 'blank', 'desc' => '' ); |
||
774 | } |
||
775 | |||
776 | $sc_items = array( |
||
777 | 'approved_status' => array( |
||
778 | 'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_approved, |
||
779 | 'desc' => EEH_Template::pretty_status( EEM_Registration::status_id_approved, FALSE, 'sentence' ) |
||
780 | ), |
||
781 | 'pending_status' => array( |
||
782 | 'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_pending_payment, |
||
783 | 'desc' => EEH_Template::pretty_status( EEM_Registration::status_id_pending_payment, FALSE, 'sentence' ) |
||
784 | ), |
||
785 | 'incomplete_status' => array( |
||
786 | 'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_incomplete, |
||
787 | 'desc' => EEH_Template::pretty_status( EEM_Registration::status_id_incomplete, FALSE, 'sentence' ) |
||
788 | ), |
||
789 | 'not_approved' => array( |
||
790 | 'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_not_approved, |
||
791 | 'desc' => EEH_Template::pretty_status( EEM_Registration::status_id_not_approved, FALSE, 'sentence' ) |
||
792 | ), |
||
793 | 'declined_status' => array( |
||
794 | 'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_declined, |
||
795 | 'desc' => EEH_Template::pretty_status( EEM_Registration::status_id_declined, FALSE, 'sentence' ) |
||
796 | ), |
||
797 | 'cancelled_status' => array( |
||
798 | 'class' => 'ee-status-legend ee-status-legend-' . EEM_Registration::status_id_cancelled, |
||
799 | 'desc' => EEH_Template::pretty_status( EEM_Registration::status_id_cancelled, FALSE, 'sentence' ) |
||
800 | ) |
||
801 | ); |
||
802 | return array_merge( $fc_items, $sc_items ); |
||
803 | } |
||
804 | |||
805 | |||
806 | |||
807 | /*************************************** REGISTRATION OVERVIEW ***************************************/ |
||
808 | |||
809 | |||
810 | |||
811 | |||
812 | |||
813 | |||
814 | protected function _registrations_overview_list_table() { |
||
815 | $EVT_ID = ( ! empty( $this->_req_data['event_id'] )) ? absint( $this->_req_data['event_id'] ) : FALSE; |
||
816 | if ( $EVT_ID ) { |
||
817 | if ( EE_Registry::instance()->CAP->current_user_can( 'ee_edit_registrations', 'espresso_registrations_new_registration', $EVT_ID ) ) { |
||
818 | $this->_admin_page_title .= $this->get_action_link_or_button( 'new_registration', 'add-registrant', array( 'event_id' => $EVT_ID ), 'add-new-h2' ); |
||
819 | } |
||
820 | $event = EEM_Event::instance()->get_one_by_ID( $EVT_ID ); |
||
821 | $this->_template_args['admin_page_header'] = $event instanceof EE_Event ? sprintf( __('%s Viewing registrations for the event: %s%s', 'event_espresso'), '<h2>', '<a href="' . EE_Admin_Page::add_query_args_and_nonce( array('action' => 'edit', 'post' => $event->ID() ), EVENTS_ADMIN_URL ) . '">' . $event->get('EVT_name') . '</a>', '</h2>' ) : ''; |
||
822 | } |
||
823 | $this->_template_args['after_list_table'] = $this->_display_legend( $this->_registration_legend_items() ); |
||
824 | $this->display_admin_list_table_page_with_no_sidebar(); |
||
825 | } |
||
826 | |||
827 | |||
828 | |||
829 | |||
830 | /** |
||
831 | * This sets the _registration property for the registration details screen |
||
832 | * |
||
833 | * @access private |
||
834 | * @return bool |
||
835 | */ |
||
836 | private function _set_registration_object() { |
||
837 | //get out if we've already set the object |
||
838 | if ( is_object( $this->_registration )) { |
||
839 | return TRUE; |
||
840 | } |
||
841 | |||
842 | $REG = EEM_Registration::instance(); |
||
843 | |||
844 | $REG_ID = ( ! empty( $this->_req_data['_REG_ID'] )) ? absint( $this->_req_data['_REG_ID'] ) : FALSE; |
||
845 | |||
846 | if ( $this->_registration = $REG->get_one_by_ID( $REG_ID )) |
||
847 | return TRUE; |
||
848 | else { |
||
849 | $error_msg = sprintf( __('An error occurred and the details for Registration ID #%s could not be retrieved.', 'event_espresso'), $REG_ID ); |
||
850 | EE_Error::add_error( $error_msg, __FILE__, __FUNCTION__, __LINE__ ); |
||
851 | $this->_registration = NULL; |
||
852 | return FALSE; |
||
853 | } |
||
854 | } |
||
855 | |||
856 | |||
857 | |||
858 | /** |
||
859 | * get registrations for given parameters (used by list table) |
||
860 | * |
||
861 | * @param int $per_page how many registrations displayed per page |
||
862 | * @param boolean $count return the count or objects |
||
863 | * @param boolean $this_month whether to return for just this month |
||
864 | * @param boolean $today whether to return results for just today |
||
865 | * @throws \EE_Error |
||
866 | * @internal param bool $all whether to ignore all query params and just return ALL registrations (or count if count is set) |
||
867 | * @return mixed (int|array) int = count || array of registration objects |
||
868 | */ |
||
869 | public function get_registrations( $per_page = 10, $count = FALSE, $this_month = FALSE, $today = FALSE ) { |
||
870 | |||
871 | $EVT_ID = ! empty( $this->_req_data['event_id'] ) && $this->_req_data['event_id'] > 0 ? absint( $this->_req_data['event_id'] ) : FALSE; |
||
872 | $CAT_ID = ! empty( $this->_req_data['EVT_CAT'] ) && (int) $this->_req_data['EVT_CAT'] > 0? absint( $this->_req_data['EVT_CAT'] ) : FALSE; |
||
873 | $reg_status = ! empty( $this->_req_data['_reg_status'] ) ? sanitize_text_field( $this->_req_data['_reg_status'] ) : FALSE; |
||
874 | $month_range = ! empty( $this->_req_data['month_range'] ) ? sanitize_text_field( $this->_req_data['month_range'] ) : FALSE;//should be like 2013-april |
||
875 | $today_a = ! empty( $this->_req_data['status'] ) && $this->_req_data['status'] == 'today' ? TRUE : FALSE; |
||
876 | $this_month_a = ! empty( $this->_req_data['status'] ) && $this->_req_data['status'] == 'month' ? TRUE : FALSE; |
||
877 | $start_date = FALSE; |
||
878 | $end_date = FALSE; |
||
879 | $_where = array(); |
||
880 | $trash = ! empty( $this->_req_data['status'] ) && $this->_req_data['status'] == 'trash' ? TRUE : FALSE; |
||
881 | $incomplete = ! empty( $this->_req_data['status'] ) && $this->_req_data['status'] == 'incomplete' ? TRUE : FALSE; |
||
882 | |||
883 | //set orderby |
||
884 | $this->_req_data['orderby'] = ! empty($this->_req_data['orderby']) ? $this->_req_data['orderby'] : ''; |
||
885 | |||
886 | |||
887 | switch ( $this->_req_data['orderby'] ) { |
||
888 | case '_REG_ID': |
||
889 | $orderby = 'REG_ID'; |
||
890 | break; |
||
891 | case '_Reg_status': |
||
892 | $orderby = 'STS_ID'; |
||
893 | break; |
||
894 | case 'ATT_fname': |
||
895 | $orderby = 'Attendee.ATT_lname'; |
||
896 | break; |
||
897 | case 'event_name': |
||
898 | $orderby = 'Event.EVT_name'; |
||
899 | break; |
||
900 | case 'DTT_EVT_start': |
||
901 | $orderby = 'Event.Datetime.DTT_EVT_start'; |
||
902 | break; |
||
903 | default: //'REG_date' |
||
904 | $orderby = 'REG_date'; |
||
905 | } |
||
906 | |||
907 | $sort = ( isset( $this->_req_data['order'] ) && ! empty( $this->_req_data['order'] )) ? $this->_req_data['order'] : 'DESC'; |
||
908 | $current_page = isset( $this->_req_data['paged'] ) && !empty( $this->_req_data['paged'] ) ? $this->_req_data['paged'] : 1; |
||
909 | $per_page = isset( $this->_req_data['perpage'] ) && !empty( $this->_req_data['perpage'] ) ? $this->_req_data['perpage'] : $per_page; |
||
910 | |||
911 | |||
912 | $offset = ($current_page-1)*$per_page; |
||
913 | $limit = $count ? NULL : array( $offset, $per_page ); |
||
914 | |||
915 | if($EVT_ID){ |
||
916 | $_where['EVT_ID']=$EVT_ID; |
||
917 | } |
||
918 | if($CAT_ID){ |
||
919 | $_where['Event.Term_Taxonomy.term_id'] = $CAT_ID; |
||
920 | } |
||
921 | if ( $incomplete ) { |
||
922 | $_where['STS_ID'] = EEM_Registration::status_id_incomplete; |
||
923 | } else if ( ! $trash) { |
||
924 | $_where['STS_ID'] = array( '!=', EEM_Registration::status_id_incomplete ); |
||
925 | } |
||
926 | if($reg_status){ |
||
927 | $_where['STS_ID'] = $reg_status; |
||
928 | } |
||
929 | |||
930 | |||
931 | |||
932 | $this_year_r = date('Y', current_time('timestamp')); |
||
933 | |||
934 | |||
935 | $time_start = ' 00:00:00'; |
||
936 | $time_end = ' 23:59:59'; |
||
937 | |||
938 | if($today_a || $today ){ |
||
939 | $curdate = date('Y-m-d', current_time('timestamp')); |
||
940 | $_where['REG_date']= array('BETWEEN', |
||
941 | array( |
||
942 | EEM_Registration::instance()->convert_datetime_for_query( 'REG_date', $curdate . $time_start, 'Y-m-d H:i:s' ), |
||
943 | EEM_Registration::instance()->convert_datetime_for_query( 'REG_date', $curdate . $time_end, 'Y-m-d H:i:s' ), |
||
944 | )); |
||
945 | }elseif($this_month_a || $this_month){ |
||
946 | $this_month_r = date('m', current_time('timestamp')); |
||
947 | $days_this_month = date( 't', current_time('timestamp') ); |
||
948 | $_where['REG_date']= array('BETWEEN', |
||
949 | array( |
||
950 | EEM_Registration::instance()->convert_datetime_for_query( 'REG_date', $this_year_r . '-' . $this_month_r . '-01' . ' ' . $time_start, 'Y-m-d H:i:s' ), |
||
951 | EEM_Registration::instance()->convert_datetime_for_query( 'REG_date', $this_year_r . '-' . $this_month_r . '-' . $days_this_month . ' ' . $time_end, 'Y-m-d H:i:s' ) |
||
952 | )); |
||
953 | }elseif($month_range){ |
||
954 | $pieces = explode(' ', $this->_req_data['month_range'], 3); |
||
955 | $month_r = !empty($pieces[0]) ? date('m', strtotime($pieces[0])) : ''; |
||
956 | $year_r = !empty($pieces[1]) ? $pieces[1] : ''; |
||
957 | $days_in_month = date('t', strtotime($year_r . '-' . $month_r . '-' . '01') ); |
||
958 | $_where['REG_date']= array('BETWEEN', |
||
959 | array( EEM_Registration::instance()->convert_datetime_for_query( 'REG_date', $year_r . '-' . $month_r . '-01 00:00:00', 'Y-m-d H:i:s'), EEM_Registration::instance()->convert_datetime_for_query( 'REG_date', $year_r . '-' . $month_r . '-' . $days_in_month . ' 23:59:59', 'Y-m-d H:i:s' ) ) ); |
||
960 | }elseif($start_date && $end_date){ |
||
961 | throw new EE_Error("not yet supported"); |
||
962 | }elseif($start_date){ |
||
963 | throw new EE_Error("not yet supported"); |
||
964 | }elseif($end_date){ |
||
965 | throw new EE_Error("not yet supported"); |
||
966 | } |
||
967 | |||
968 | if ( ! empty( $this->_req_data['s'] ) ) { |
||
969 | $sstr = '%' . $this->_req_data['s'] . '%'; |
||
970 | $_where['OR'] = array( |
||
971 | 'Event.EVT_name' => array( 'LIKE', $sstr), |
||
972 | 'Event.EVT_desc' => array( 'LIKE', $sstr ), |
||
973 | 'Event.EVT_short_desc' => array( 'LIKE' , $sstr ), |
||
974 | 'Attendee.ATT_full_name' => array( 'LIKE', $sstr ), |
||
975 | 'Attendee.ATT_fname' => array( 'LIKE', $sstr ), |
||
976 | 'Attendee.ATT_lname' => array( 'LIKE', $sstr ), |
||
977 | 'Attendee.ATT_short_bio' => array( 'LIKE', $sstr ), |
||
978 | 'Attendee.ATT_email' => array('LIKE', $sstr ), |
||
979 | 'Attendee.ATT_address' => array( 'LIKE', $sstr ), |
||
980 | 'Attendee.ATT_address2' => array( 'LIKE', $sstr ), |
||
981 | 'Attendee.ATT_city' => array( 'LIKE', $sstr ), |
||
982 | 'REG_final_price' => array( 'LIKE', $sstr ), |
||
983 | 'REG_code' => array( 'LIKE', $sstr ), |
||
984 | 'REG_count' => array( 'LIKE' , $sstr ), |
||
985 | 'REG_group_size' => array( 'LIKE' , $sstr ), |
||
986 | 'Ticket.TKT_name' => array( 'LIKE', $sstr ), |
||
987 | 'Ticket.TKT_description' => array( 'LIKE', $sstr ), |
||
988 | 'Transaction.Payment.PAY_txn_id_chq_nmbr' => array( 'LIKE', $sstr ) |
||
989 | ); |
||
990 | } |
||
991 | |||
992 | //capability checks |
||
993 | if ( ! EE_Registry::instance()->CAP->current_user_can('ee_read_others_registrations', 'get_registrations' ) ) { |
||
994 | $_where['AND'] = array( |
||
995 | 'Event.EVT_wp_user' => get_current_user_id() |
||
996 | ); |
||
997 | } |
||
998 | |||
999 | |||
1000 | if( $count ){ |
||
1001 | if ( $trash ) { |
||
1002 | return EEM_Registration::instance()->count_deleted( array( $_where )); |
||
1003 | } else if ( $incomplete ) { |
||
1004 | return EEM_Registration::instance()->count( array( $_where )); |
||
1005 | } else { |
||
1006 | return EEM_Registration::instance()->count( array( $_where, 'default_where_conditions' => 'this_model_only' )); |
||
1007 | } |
||
1008 | } else { |
||
1009 | //make sure we remove default where conditions cause all registrations matching query are returned |
||
1010 | $query_params = array( $_where, 'order_by' => array( $orderby => $sort ), 'default_where_conditions' => 'this_model_only' ); |
||
1011 | if ( $per_page !== -1 ) { |
||
1012 | $query_params['limit'] = $limit; |
||
1013 | } |
||
1014 | $registrations = $trash ? EEM_Registration::instance()->get_all_deleted($query_params) : EEM_Registration::instance()->get_all($query_params); |
||
1015 | |||
1016 | |||
1017 | if ( $EVT_ID && isset( $registrations[0] ) && $registrations[0] instanceof EE_Registration && $registrations[0]->event_obj()) { |
||
1018 | $first_registration = $registrations[0]; |
||
1019 | //EEH_Debug_Tools::printr( $registrations[0], '$registrations <br /><span style="font-size:10px;font-weight:normal;">' . __FILE__ . '<br />line no: ' . __LINE__ . '</span>', 'auto' ); |
||
1020 | $event_name = $first_registration->event_obj()->name(); |
||
1021 | $event_date = $first_registration->date_obj()->start_date_and_time('l F j, Y,', 'g:i:s a');// isset( $registrations[0]->DTT_EVT_start ) ? date( 'l F j, Y, g:i:s a', $registrations[0]->DTT_EVT_start ) : ''; |
||
1022 | // edit event link |
||
1023 | View Code Duplication | if ( $event_name != '' ) { |
|
1024 | $edit_event_url = self::add_query_args_and_nonce( array( 'action'=>'edit_event', 'EVT_ID'=>$EVT_ID ), EVENTS_ADMIN_URL ); |
||
1025 | $edit_event_lnk = '<a href="'.$edit_event_url.'" title="' . esc_attr__( 'Edit ', 'event_espresso' ) . $event_name . '">' . __( 'Edit Event', 'event_espresso' ) . '</a>'; |
||
1026 | $event_name .= ' <span class="admin-page-header-edit-lnk not-bold">' . $edit_event_lnk . '</span>' ; |
||
1027 | } |
||
1028 | |||
1029 | $back_2_reg_url = self::add_query_args_and_nonce( array( 'action'=>'default' ), REG_ADMIN_URL ); |
||
1030 | $back_2_reg_lnk = '<a href="'.$back_2_reg_url.'" title="' . esc_attr__( 'click to return to viewing all registrations ', 'event_espresso' ) . '">« ' . __( 'Back to All Registrations', 'event_espresso' ) . '</a>'; |
||
1031 | |||
1032 | $this->_template_args['before_admin_page_content'] = ' |
||
1033 | <div id="admin-page-header"> |
||
1034 | <h1><span class="small-text not-bold">'.__( 'Event: ', 'event_espresso' ).'</span>'. $event_name .'</h1> |
||
1035 | <h3><span class="small-text not-bold">'.__( 'Date: ', 'event_espresso' ). '</span>'. $event_date .'</h3> |
||
1036 | <span class="admin-page-header-go-back-lnk not-bold">' . $back_2_reg_lnk . '</span> |
||
1037 | </div> |
||
1038 | '; |
||
1039 | |||
1040 | } |
||
1041 | return $registrations; |
||
1042 | } |
||
1043 | } |
||
1044 | |||
1045 | |||
1046 | |||
1047 | |||
1048 | |||
1049 | |||
1050 | public function get_registration_status_array() { |
||
1051 | return self::$_reg_status; |
||
1052 | } |
||
1053 | |||
1054 | |||
1055 | |||
1056 | |||
1057 | /*************************************** REGISTRATION DETAILS ***************************************/ |
||
1058 | |||
1059 | |||
1060 | |||
1061 | |||
1062 | |||
1063 | /** |
||
1064 | * generates HTML for the View Registration Details Admin page |
||
1065 | * @access protected |
||
1066 | * @return void |
||
1067 | */ |
||
1068 | protected function _registration_details() { |
||
1069 | |||
1070 | $this->_template_args = array(); |
||
1071 | |||
1072 | $this->_set_registration_object(); |
||
1073 | |||
1074 | if ( is_object( $this->_registration )) { |
||
1075 | $transaction = $this->_registration->transaction() ? $this->_registration->transaction() : EE_Transaction::new_instance(); |
||
1076 | $this->_session = $transaction->session_data(); |
||
1077 | |||
1078 | $event_id = $this->_registration->event_ID(); |
||
1079 | |||
1080 | |||
1081 | $this->_template_args['reg_nmbr']['value'] = $this->_registration->ID(); |
||
1082 | $this->_template_args['reg_nmbr']['label'] = __( 'Registration Number', 'event_espresso' ); |
||
1083 | |||
1084 | $this->_template_args['reg_datetime']['value'] = $this->_registration->pretty_date('l F j, Y','g:i:s a') ; |
||
1085 | $this->_template_args['reg_datetime']['label'] = __( 'Date', 'event_espresso' ); |
||
1086 | |||
1087 | $this->_template_args['grand_total'] = $transaction->total(); |
||
1088 | |||
1089 | $this->_template_args['currency_sign'] = EE_Registry::instance()->CFG->currency->sign; |
||
1090 | // link back to overview |
||
1091 | $this->_template_args['reg_overview_url'] = REG_ADMIN_URL; |
||
1092 | $this->_template_args['registration'] = $this->_registration; |
||
1093 | $this->_template_args['filtered_registrations_link'] = EE_Admin_Page::add_query_args_and_nonce( array( 'action' => 'default', 'event_id' => $event_id ), REG_ADMIN_URL ); |
||
1094 | $this->_template_args['filtered_transactions_link'] = EE_Admin_Page::add_query_args_and_nonce( array( 'action' => 'default', 'EVT_ID' => $event_id, 'page' => 'espresso_transactions' ), admin_url( 'admin.php' ) ); |
||
1095 | $this->_template_args['event_link'] = EE_Admin_Page::add_query_args_and_nonce( array( 'page' => 'espresso_events', 'action' => 'edit', 'post' => $event_id ), admin_url( 'admin.php' ) ); |
||
1096 | |||
1097 | //next and previous links |
||
1098 | $next_reg = $this->_registration->next(null, array(), 'REG_ID' ); |
||
1099 | $this->_template_args['next_registration'] = $next_reg ? $this->_next_link( EE_Admin_Page::add_query_args_and_nonce( array( 'action' => 'view_registration', '_REG_ID' => $next_reg['REG_ID'] ), REG_ADMIN_URL ), 'dashicons dashicons-arrow-right ee-icon-size-22' ) : ''; |
||
1100 | $previous_reg = $this->_registration->previous( null, array(), 'REG_ID' ); |
||
1101 | $this->_template_args['previous_registration'] = $previous_reg ? $this->_previous_link( EE_Admin_Page::add_query_args_and_nonce( array( 'action' => 'view_registration', '_REG_ID' => $previous_reg['REG_ID'] ), REG_ADMIN_URL ), 'dashicons dashicons-arrow-left ee-icon-size-22' ) : ''; |
||
1102 | |||
1103 | // grab header |
||
1104 | $template_path = REG_TEMPLATE_PATH . 'reg_admin_details_header.template.php'; |
||
1105 | $this->_template_args['admin_page_header'] = EEH_Template::display_template( $template_path, $this->_template_args, TRUE ); |
||
1106 | |||
1107 | } else { |
||
1108 | |||
1109 | $this->_template_args['admin_page_header'] = $this->display_espresso_notices(); |
||
1110 | |||
1111 | } |
||
1112 | |||
1113 | // the details template wrapper |
||
1114 | $this->display_admin_page_with_sidebar(); |
||
1115 | |||
1116 | } |
||
1117 | |||
1118 | |||
1119 | |||
1120 | |||
1121 | |||
1122 | |||
1123 | protected function _registration_details_metaboxes() { |
||
1124 | $this->_set_registration_object(); |
||
1125 | $attendee = $this->_registration instanceof EE_Registration ? $this->_registration->attendee() : null; |
||
1126 | add_meta_box( 'edit-reg-status-mbox', __( 'Registration Status', 'event_espresso' ), array( $this, 'set_reg_status_buttons_metabox' ), $this->wp_page_slug, 'normal', 'high' ); |
||
1127 | add_meta_box( 'edit-reg-details-mbox', __( 'Registration Details', 'event_espresso' ), array( $this, '_reg_details_meta_box' ), $this->wp_page_slug, 'normal', 'high' ); |
||
1128 | if ( $attendee instanceof EE_Attendee && EE_Registry::instance()->CAP->current_user_can('ee_edit_registration', 'edit-reg-questions-mbox' ) ) { |
||
1129 | add_meta_box( 'edit-reg-questions-mbox', __( 'Registration Form Answers', 'event_espresso' ), array( $this, '_reg_questions_meta_box' ), $this->wp_page_slug, 'normal', 'high' ); |
||
1130 | } |
||
1131 | add_meta_box( 'edit-reg-registrant-mbox', __( 'Contact Details', 'event_espresso' ), array( $this, '_reg_registrant_side_meta_box' ), $this->wp_page_slug, 'side', 'high' ); |
||
1132 | if ( $this->_registration->group_size() > 1 ) { |
||
1133 | add_meta_box( 'edit-reg-attendees-mbox', __( 'Other Registrations in this Transaction', 'event_espresso' ), array( $this, '_reg_attendees_meta_box' ), $this->wp_page_slug, 'normal', 'high' ); |
||
1134 | } |
||
1135 | } |
||
1136 | |||
1137 | |||
1138 | |||
1139 | |||
1140 | |||
1141 | |||
1142 | /** |
||
1143 | * _set_approve_or_decline_reg_status_buttons |
||
1144 | * @access protected |
||
1145 | * @return string |
||
1146 | */ |
||
1147 | public function set_reg_status_buttons_metabox() { |
||
1148 | |||
1149 | //is registration for free event OR for a completed transaction? This will determine whether the set to pending option is shown. |
||
1150 | $is_complete = $this->_registration->transaction()->is_completed(); |
||
1151 | |||
1152 | //let's get an array of all possible buttons that we can just reference |
||
1153 | $status_buttons = $this->_get_reg_status_buttons(); |
||
1154 | $template_args[ 'reg_status_value' ] = $this->_registration->pretty_status(); |
||
1155 | $template_args[ 'reg_status_class' ] = 'status-' . $this->_registration->status_ID(); |
||
1156 | $template_args['attendee'] = $this->_registration->attendee(); |
||
1157 | $template = REG_TEMPLATE_PATH . 'reg_status_change_buttons.template.php'; |
||
1158 | if ( $this->_set_registration_object() ) { |
||
1159 | $current_status = $this->_registration->status_ID(); |
||
1160 | unset( $status_buttons[$current_status] ); |
||
1161 | if ( $current_status != EEM_Registration::status_id_pending_payment && $is_complete ) { |
||
1162 | unset( $status_buttons[EEM_Registration::status_id_pending_payment] ); |
||
1163 | } |
||
1164 | $template_args['status_buttons'] = implode( "\n", $status_buttons ); |
||
1165 | } |
||
1166 | $template_args['form_url'] = REG_ADMIN_URL; |
||
1167 | $template_args['REG_ID'] = $this->_registration->ID(); |
||
1168 | $template_args['nonce'] = wp_nonce_field( 'change_reg_status_nonce', 'change_reg_status_nonce', FALSE, FALSE ); |
||
1169 | |||
1170 | EEH_Template::display_template( $template, $template_args ); |
||
1171 | |||
1172 | } |
||
1173 | |||
1174 | |||
1175 | |||
1176 | |||
1177 | /** |
||
1178 | * Returns an array of all the buttons for the various statuses and switch status actions |
||
1179 | * @return array |
||
1180 | */ |
||
1181 | private function _get_reg_status_buttons() { |
||
1182 | |||
1183 | $buttons = array( |
||
1184 | EEM_Registration::status_id_approved => '<input type="submit" name="_reg_status_id" class="button-secondary ee-status-strip reg-status-' . EEM_Registration::status_id_approved . '" value="' . EEH_Template::pretty_status( EEM_Registration::status_id_approved, FALSE, 'sentence' ) . '">', |
||
1185 | EEM_Registration::status_id_pending_payment => '<input type="submit" name="_reg_status_id" class="button-secondary ee-status-strip reg-status-' . EEM_Registration::status_id_pending_payment . '" value="' . EEH_Template::pretty_status( EEM_Registration::status_id_pending_payment, FALSE, 'sentence' ) . '">', |
||
1186 | EEM_Registration::status_id_not_approved => '<input type="submit" name="_reg_status_id" class="button-secondary ee-status-strip reg-status-' . EEM_Registration::status_id_not_approved . '" value="' . EEH_Template::pretty_status( EEM_Registration::status_id_not_approved, FALSE, 'sentence' ) . '">', |
||
1187 | EEM_Registration::status_id_declined => '<input type="submit" name="_reg_status_id" class="button-secondary ee-status-strip reg-status-' . EEM_Registration::status_id_declined . '" value="' . EEH_Template::pretty_status( EEM_Registration::status_id_declined, FALSE, 'sentence' ) . '">', |
||
1188 | EEM_Registration::status_id_cancelled =>'<input type="submit" name="_reg_status_id" class="button-secondary ee-status-strip reg-status-' . EEM_Registration::status_id_cancelled . '" value="' . EEH_Template::pretty_status( EEM_Registration::status_id_cancelled, FALSE, 'sentence' ) . '">', |
||
1189 | ); |
||
1190 | return $buttons; |
||
1191 | } |
||
1192 | |||
1193 | |||
1194 | /** |
||
1195 | * This method is used when using _REG_ID from request which may or may not be an array of reg_ids. |
||
1196 | * |
||
1197 | * @param bool $status REG status given for changing registrations to. |
||
1198 | * @param bool $notify Whether to send messages notifications or not. |
||
1199 | * |
||
1200 | * @return array (array with reg_id(s) updated and whether update was successful. |
||
1201 | */ |
||
1202 | protected function _set_registration_status_from_request( $status = false, $notify = false ) { |
||
1203 | $REG_ID = isset( $this->_req_data['_REG_ID'] ) ? (array) $this->_req_data['_REG_ID'] : array(); |
||
1204 | |||
1205 | $success = $this->_set_registration_status( $REG_ID, $status ); |
||
1206 | |||
1207 | //notify? |
||
1208 | if ( $success && $notify && EE_Registry::instance()->CAP->current_user_can( 'ee_send_message', 'espresso_registrations_resend_registration' ) ) { |
||
1209 | $this->_process_resend_registration(); |
||
1210 | } |
||
1211 | |||
1212 | return $success; |
||
1213 | } |
||
1214 | |||
1215 | |||
1216 | |||
1217 | /** |
||
1218 | * Set the registration status for the given reg_id (which may or may not be an array, it gets typecast to an array). |
||
1219 | * |
||
1220 | * Note, this method does NOT take care of possible notifications. That is required by calling code. |
||
1221 | * |
||
1222 | * @param bool $REG_ID |
||
1223 | * @param bool $status |
||
1224 | * @return array (an array with 'success' key representing whether status change was successful, and 'REG_ID' as the array of updated registrations). |
||
1225 | */ |
||
1226 | protected function _set_registration_status( $REG_ID, $status = false ) { |
||
1227 | $success = true; |
||
1228 | // set default status if none is passed |
||
1229 | $status = $status ? $status : EEM_Registration::status_id_pending_payment; |
||
1230 | |||
1231 | //typecast and sanitize reg_id |
||
1232 | $reg_ids = array_filter( (array) $REG_ID, 'absint' ); |
||
1233 | |||
1234 | //loop through REG_ID's and change status |
||
1235 | foreach ( $reg_ids as $r_id ) { |
||
1236 | $registration = EEM_Registration::instance()->get_one_by_ID( $r_id ); |
||
1237 | if ( $registration instanceof EE_Registration ) { |
||
1238 | $registration->set_status( $status ); |
||
1239 | $result = $registration->save(); |
||
1240 | |||
1241 | //verifying explicit fails because update *may* just return 0 for 0 rows affected |
||
1242 | $success = $success !== false && $result !== false; |
||
1243 | } |
||
1244 | } |
||
1245 | |||
1246 | //reset _req_data['_REG_ID'] for any potential future messages notifications |
||
1247 | $this->_req_data['_REG_ID'] = $reg_ids; |
||
1248 | |||
1249 | //return $success and processed registrations |
||
1250 | return array( 'REG_ID' => $reg_ids, 'success' => $success ); |
||
1251 | } |
||
1252 | |||
1253 | |||
1254 | |||
1255 | |||
1256 | /** |
||
1257 | * Common logic for setting up success message and redirecting to appropriate route |
||
1258 | * @param string $STS_ID status id for the registration changed to |
||
1259 | * @param bool $notify indicates whether the _set_registration_status_from_request does notifications or not. |
||
1260 | * @return void |
||
1261 | */ |
||
1262 | protected function _reg_status_change_return( $STS_ID, $notify = false ) { |
||
1263 | |||
1264 | $result = ! empty( $STS_ID ) ? $this->_set_registration_status_from_request( $STS_ID, $notify ) : array( 'success' => false ); |
||
1265 | |||
1266 | |||
1267 | $success = isset( $result['success'] ) && $result['success']; |
||
1268 | |||
1269 | //setup success message |
||
1270 | if ( $success ) { |
||
1271 | $msg = is_array( $result['REG_ID'] ) && count( $result['REG_ID'] ) > 1 ? sprintf( __('Registration status has been set to %s', 'event_espresso'), EEH_Template::pretty_status($STS_ID, false, 'lower' ) ) : sprintf( __('Registrations have been set to %s.', 'event_espresso'), EEH_Template::pretty_status($STS_ID, false, 'lower' ) ) ; |
||
1272 | EE_Error::add_success( $msg ); |
||
1273 | } else { |
||
1274 | EE_Error::add_error( __('Something went wrong, and the status was not changed', 'event_espresso' ), __FILE__, __LINE__, __FUNCTION__ ); |
||
1275 | } |
||
1276 | |||
1277 | $route = isset( $this->_req_data['return'] ) && $this->_req_data['return'] == 'view_registration' ? array( 'action' => 'view_registration', '_REG_ID' => $result['REG_ID'][0] ) : array( 'action' => 'default' ); |
||
1278 | //unset nonces |
||
1279 | foreach ( $this->_req_data as $ref => $value ) { |
||
1280 | if ( strpos( $ref, 'nonce' ) !== false ) { |
||
1281 | unset( $this->_req_data[$ref] ); |
||
1282 | continue; |
||
1283 | } |
||
1284 | |||
1285 | $value = is_array( $value ) ? array_map( 'urlencode', $value ) : urlencode( $value ); |
||
1286 | $this->_req_data[$ref] = $value; |
||
1287 | } |
||
1288 | |||
1289 | //merge request vars so that the reloaded list table contains any existing filter query params |
||
1290 | $route = array_merge( $this->_req_data, $route ); |
||
1291 | |||
1292 | $this->_redirect_after_action( $success, '', '', $route, true ); |
||
1293 | |||
1294 | } |
||
1295 | |||
1296 | |||
1297 | |||
1298 | /** |
||
1299 | * incoming reg status change from reg details page. |
||
1300 | * @return void |
||
1301 | */ |
||
1302 | protected function _change_reg_status() { |
||
1303 | $this->_req_data['return'] = 'view_registration'; |
||
1304 | //set notify based on whether the send notifications toggle is set or not |
||
1305 | $notify = ! empty( $this->_req_data['txn_reg_status_change']['send_notifications'] ); |
||
1306 | $this->_req_data[ '_reg_status_id' ] = isset( $this->_req_data[ '_reg_status_id' ] ) ? $this->_req_data[ '_reg_status_id' ] : ''; |
||
1307 | |||
1308 | switch ( $this->_req_data['_reg_status_id'] ) { |
||
1309 | case EEH_Template::pretty_status( EEM_Registration::status_id_approved, false, 'sentence' ) : |
||
1310 | $this->approve_registration( $notify ); |
||
1311 | break; |
||
1312 | case EEH_Template::pretty_status( EEM_Registration::status_id_pending_payment, false, 'sentence' ) : |
||
1313 | $this->pending_registration( $notify ); |
||
1314 | break; |
||
1315 | case EEH_Template::pretty_status( EEM_Registration::status_id_not_approved, false, 'sentence' ) : |
||
1316 | $this->not_approve_registration( $notify ); |
||
1317 | break; |
||
1318 | case EEH_Template::pretty_status( EEM_Registration::status_id_declined, false, 'sentence' ) : |
||
1319 | $this->decline_registration( $notify ); |
||
1320 | break; |
||
1321 | case EEH_Template::pretty_status( EEM_Registration::status_id_cancelled, false, 'sentence' ) : |
||
1322 | $this->cancel_registration( $notify ); |
||
1323 | break; |
||
1324 | default : |
||
1325 | $result['success'] = false; |
||
1326 | unset( $this->_req_data['return'] ); |
||
1327 | $this->_reg_status_change_return( '', false ); |
||
1328 | break; |
||
1329 | } |
||
1330 | } |
||
1331 | |||
1332 | |||
1333 | |||
1334 | /** |
||
1335 | * approve_registration |
||
1336 | * @access protected |
||
1337 | * @param bool $notify whether or not to notify the registrant about their approval. |
||
1338 | * @return void |
||
1339 | */ |
||
1340 | protected function approve_registration( $notify = false ) { |
||
1341 | $this->_reg_status_change_return( EEM_Registration::status_id_approved, $notify ); |
||
1342 | } |
||
1343 | |||
1344 | |||
1345 | |||
1346 | |||
1347 | /** |
||
1348 | * decline_registration |
||
1349 | * @access protected |
||
1350 | * @param bool $notify whether or not to notify the registrant about their approval. |
||
1351 | * @return void |
||
1352 | */ |
||
1353 | protected function decline_registration( $notify = false ) { |
||
1354 | $this->_reg_status_change_return( EEM_Registration::status_id_declined, $notify ); |
||
1355 | } |
||
1356 | |||
1357 | |||
1358 | |||
1359 | |||
1360 | /** |
||
1361 | * cancel_registration |
||
1362 | * @access protected |
||
1363 | * @param bool $notify whether or not to notify the registrant about their approval. |
||
1364 | * @return void |
||
1365 | */ |
||
1366 | protected function cancel_registration( $notify = false ) { |
||
1367 | $this->_reg_status_change_return( EEM_Registration::status_id_cancelled, $notify ); |
||
1368 | } |
||
1369 | |||
1370 | |||
1371 | |||
1372 | |||
1373 | |||
1374 | /** |
||
1375 | * not_approve_registration |
||
1376 | * @access protected |
||
1377 | * @param bool $notify whether or not to notify the registrant about their approval. |
||
1378 | * @return void |
||
1379 | */ |
||
1380 | protected function not_approve_registration( $notify = false ) { |
||
1381 | $this->_reg_status_change_return( EEM_Registration::status_id_not_approved, $notify ); |
||
1382 | } |
||
1383 | |||
1384 | |||
1385 | |||
1386 | /** |
||
1387 | * decline_registration |
||
1388 | * @access protected |
||
1389 | * @param bool $notify whether or not to notify the registrant about their approval. |
||
1390 | * @return void |
||
1391 | */ |
||
1392 | protected function pending_registration( $notify = false ) { |
||
1393 | $this->_reg_status_change_return( EEM_Registration::status_id_pending_payment, $notify ); |
||
1394 | } |
||
1395 | |||
1396 | |||
1397 | |||
1398 | |||
1399 | /** |
||
1400 | * generates HTML for the Registration main meta box |
||
1401 | * @access public |
||
1402 | * @return void |
||
1403 | */ |
||
1404 | public function _reg_details_meta_box() { |
||
1405 | EEH_Autoloader::register_line_item_display_autoloaders(); |
||
1406 | EEH_Autoloader::register_line_item_filter_autoloaders(); |
||
1407 | EE_Registry::instance()->load_Helper( 'Line_Item' ); |
||
1408 | $transaction = $this->_registration->transaction() ? $this->_registration->transaction() : EE_Transaction::new_instance(); |
||
1409 | $this->_session = $transaction->session_data(); |
||
1410 | |||
1411 | $filters = new EE_Line_Item_Filter_Collection(); |
||
1412 | $filters->add( new EE_Single_Registration_Line_Item_Filter( $this->_registration ) ); |
||
1413 | $filters->add( new EE_Non_Zero_Line_Item_Filter() ); |
||
1414 | $line_item_filter_processor = new EE_Line_Item_Filter_Processor( $filters, $transaction->total_line_item() ); |
||
1415 | $filtered_line_item_tree = $line_item_filter_processor->process(); |
||
1416 | |||
1417 | $this->_template_args['REG_ID'] = $this->_registration->ID(); |
||
1418 | $line_item_display = new EE_Line_Item_Display( 'reg_admin_table', 'EE_Admin_Table_Registration_Line_Item_Display_Strategy' ); |
||
1419 | $this->_template_args['line_item_table'] = $line_item_display->display_line_item( $filtered_line_item_tree, array( 'EE_Registration' => $this->_registration ) ); |
||
1420 | |||
1421 | |||
1422 | $attendee = $this->_registration->attendee(); |
||
1423 | |||
1424 | |||
1425 | $this->_template_args['view_transaction_button'] = EE_Registry::instance()->CAP->current_user_can( 'ee_read_transaction', 'espresso_transactions_view_transaction' ) ?EEH_Template::get_button_or_link( EE_Admin_Page::add_query_args_and_nonce( array('action'=> 'view_transaction', 'TXN_ID' => $transaction->ID() ), TXN_ADMIN_URL ), __(' View Transaction'), 'button secondary-button right', 'dashicons dashicons-cart' ) : ''; |
||
1426 | $this->_template_args['resend_registration_button'] = $attendee instanceof EE_Attendee && EE_Registry::instance()->CAP->current_user_can( 'ee_send_message', 'espresso_registrations_resend_registration' ) ?EEH_Template::get_button_or_link( EE_Admin_Page::add_query_args_and_nonce( array( 'action'=>'resend_registration', '_REG_ID'=>$this->_registration->ID(), 'redirect_to' => 'view_registration' ), REG_ADMIN_URL ), __(' Resend Registration'), 'button secondary-button right', 'dashicons dashicons-email-alt' ) : ''; |
||
1427 | |||
1428 | |||
1429 | $this->_template_args['currency_sign'] = EE_Registry::instance()->CFG->currency->sign; |
||
1430 | $payment = $transaction->get_first_related( 'Payment' ); |
||
1431 | $payment = ! $payment instanceof EE_Payment ? EE_Payment::new_instance() : $payment; |
||
1432 | $payment_method = $payment->get_first_related( 'Payment_Method' ); |
||
1433 | $payment_method = ! $payment_method instanceof EE_Payment_Method ? EE_Payment_Method::new_instance() : $payment_method; |
||
1434 | $reg_status_class = 'status-' . $this->_registration->status_ID(); |
||
1435 | $reg_details = array( |
||
1436 | 'payment_method' => $payment_method->name(), |
||
1437 | 'response_msg' => $payment->gateway_response(), |
||
1438 | 'registration_id' => $this->_registration->get( 'REG_code' ), |
||
1439 | 'registration_session' => $this->_registration->session_ID(), |
||
1440 | 'ip_address' => isset( $this->_session['ip_address'] ) ? $this->_session['ip_address'] : '', |
||
1441 | 'user_agent' => isset( $this->_session['user_agent'] ) ? $this->_session['user_agent'] : '', |
||
1442 | ); |
||
1443 | |||
1444 | |||
1445 | if ( isset( $reg_details['registration_id'] )) { |
||
1446 | $this->_template_args['reg_details']['registration_id']['value'] = $reg_details['registration_id']; |
||
1447 | $this->_template_args['reg_details']['registration_id']['label'] = __( 'Registration ID', 'event_espresso' ); |
||
1448 | $this->_template_args['reg_details']['registration_id']['class'] = 'regular-text'; |
||
1449 | } |
||
1450 | |||
1451 | if ( isset( $reg_details['payment_method'] ) ) { |
||
1452 | $this->_template_args['reg_details']['payment_method']['value'] = $reg_details['payment_method']; |
||
1453 | $this->_template_args['reg_details']['payment_method']['label'] = __( 'Most Recent Payment Method', 'event_espresso' ); |
||
1454 | $this->_template_args['reg_details']['payment_method']['class'] = 'regular-text'; |
||
1455 | $this->_template_args['reg_details']['response_msg']['value'] = $reg_details['response_msg']; |
||
1456 | $this->_template_args['reg_details']['response_msg']['label'] = __( 'Payment method response', 'event_espresso' ); |
||
1457 | $this->_template_args['reg_details']['response_msg']['class'] = 'regular-text'; |
||
1458 | } |
||
1459 | |||
1460 | $this->_template_args['reg_details']['registration_session']['value'] = $reg_details['registration_session']; |
||
1461 | $this->_template_args['reg_details']['registration_session']['label'] = __( 'Registration Session', 'event_espresso' ); |
||
1462 | $this->_template_args['reg_details']['registration_session']['class'] = 'regular-text'; |
||
1463 | |||
1464 | $this->_template_args['reg_details']['ip_address']['value'] = $reg_details['ip_address']; |
||
1465 | $this->_template_args['reg_details']['ip_address']['label'] = __( 'Registration placed from IP', 'event_espresso' ); |
||
1466 | $this->_template_args['reg_details']['ip_address']['class'] = 'regular-text'; |
||
1467 | |||
1468 | $this->_template_args['reg_details']['user_agent']['value'] = $reg_details['user_agent']; |
||
1469 | $this->_template_args['reg_details']['user_agent']['label'] = __( 'Registrant User Agent', 'event_espresso' ); |
||
1470 | $this->_template_args['reg_details']['user_agent']['class'] = 'large-text'; |
||
1471 | |||
1472 | $this->_template_args['event_link'] = EE_Admin_Page::add_query_args_and_nonce( array( 'action' => 'default', 'event_id' => $this->_registration->event_ID()), REG_ADMIN_URL ); |
||
1473 | |||
1474 | $template_path = REG_TEMPLATE_PATH . 'reg_admin_details_main_meta_box_reg_details.template.php'; |
||
1475 | echo EEH_Template::display_template( $template_path, $this->_template_args, TRUE ); |
||
1476 | |||
1477 | } |
||
1478 | |||
1479 | |||
1480 | |||
1481 | |||
1482 | |||
1483 | |||
1484 | /** |
||
1485 | * generates HTML for the Registration Questions meta box |
||
1486 | * @access public |
||
1487 | * @return void |
||
1488 | */ |
||
1489 | public function _reg_questions_meta_box() { |
||
1510 | |||
1511 | |||
1512 | |||
1513 | |||
1514 | |||
1515 | /** |
||
1516 | * form_before_question_group |
||
1517 | * |
||
1518 | * @access public |
||
1519 | * @param string $output |
||
1520 | * @return string |
||
1521 | */ |
||
1522 | public function form_before_question_group( $output ) { |
||
1528 | |||
1529 | |||
1530 | |||
1531 | |||
1532 | /** |
||
1533 | * form_after_question_group |
||
1534 | * |
||
1535 | * @access public |
||
1536 | * @param string $output |
||
1537 | * @return string |
||
1538 | */ |
||
1539 | public function form_after_question_group( $output ) { |
||
1554 | |||
1555 | |||
1556 | |||
1557 | |||
1558 | /** |
||
1559 | * form_form_field_label_wrap |
||
1560 | * |
||
1561 | * @access public |
||
1562 | * @param string $label |
||
1563 | * @return string |
||
1564 | */ |
||
1565 | public function form_form_field_label_wrap( $label ) { |
||
1572 | |||
1573 | |||
1574 | |||
1575 | |||
1576 | /** |
||
1577 | * form_form_field_input__wrap |
||
1578 | * |
||
1579 | * @access public |
||
1580 | * @param string $label |
||
1581 | * @return string |
||
1582 | */ |
||
1583 | public function form_form_field_input__wrap( $input ) { |
||
1590 | |||
1591 | |||
1592 | |||
1593 | |||
1594 | /** |
||
1595 | * generates HTML for the Registration main meta box |
||
1596 | * @access protected |
||
1597 | * @return void |
||
1598 | */ |
||
1599 | protected function _update_attendee_registration_form() { |
||
1609 | |||
1610 | |||
1611 | |||
1612 | /** |
||
1613 | * _save_attendee_registration_form |
||
1614 | * @access private |
||
1615 | * @param bool $REG_ID |
||
1616 | * @param bool $qstns |
||
1617 | * @return bool |
||
1618 | */ |
||
1619 | private function _save_attendee_registration_form( $REG_ID = FALSE, $qstns = FALSE ) { |
||
1661 | |||
1662 | |||
1663 | //TODO: try changing this to use the model directly... not indirectly through creating a default object... |
||
1664 | private function _save_new_answer( $REG_ID, $QST_ID, $ans ) { |
||
1673 | |||
1674 | |||
1675 | |||
1676 | |||
1677 | |||
1678 | /** |
||
1679 | * generates HTML for the Registration main meta box |
||
1680 | * @access public |
||
1681 | * @return void |
||
1682 | */ |
||
1683 | public function _reg_attendees_meta_box() { |
||
1730 | |||
1731 | |||
1732 | |||
1733 | |||
1734 | |||
1735 | |||
1736 | /** |
||
1737 | * generates HTML for the Edit Registration side meta box |
||
1738 | * @access public |
||
1739 | * @return void |
||
1740 | */ |
||
1741 | public function _reg_registrant_side_meta_box() { |
||
1742 | |||
1743 | /*@var $attendee EE_Attendee */ |
||
1744 | $att_check = $this->_registration->attendee(); |
||
1745 | $attendee = $att_check instanceof EE_Attendee ? $att_check : EEM_Attendee::instance()->create_default_object(); |
||
1746 | |||
1747 | //now let's determine if this is not the primary registration. If it isn't then we set the primary_registration object for reference BUT ONLY if the Attendee object loaded is not the same as the primary registration object (that way we know if we need to show cereate button or not) |
||
1748 | if ( ! $this->_registration->is_primary_registrant() ) { |
||
1749 | $primary_registration = $this->_registration->get_primary_registration(); |
||
1750 | $primary_attendee = $primary_registration->attendee(); |
||
1751 | |||
1752 | if ( ! $primary_attendee instanceof EE_Attendee || $attendee->ID() !== $primary_attendee->ID() ) { |
||
1753 | //in here? This means the displayed registration is not the primary registrant but ALREADY HAS its own custom attendee object so let's not worry about the primary reg. |
||
1754 | $primary_registration = NULL; |
||
1755 | } |
||
1756 | } else { |
||
1757 | $primary_registration = NULL; |
||
1758 | } |
||
1759 | |||
1760 | $this->_template_args['ATT_ID'] = $attendee->ID(); |
||
1761 | $this->_template_args['fname'] = $attendee->fname();//$this->_registration->ATT_fname; |
||
1762 | $this->_template_args['lname'] = $attendee->lname();//$this->_registration->ATT_lname; |
||
1763 | $this->_template_args['email'] = $attendee->email();//$this->_registration->ATT_email; |
||
1764 | $this->_template_args['phone'] = $attendee->phone(); |
||
1765 | |||
1766 | EE_Registry::instance()->load_helper( 'Formatter' ); |
||
1767 | $this->_template_args[ 'formatted_address' ] = EEH_Address::format( $attendee ); |
||
1768 | |||
1769 | |||
1770 | //edit link |
||
1771 | $this->_template_args['att_edit_link'] = EE_Admin_Page::add_query_args_and_nonce( array( 'action'=>'edit_attendee', 'post'=>$attendee->ID() ), REG_ADMIN_URL ); |
||
1772 | $this->_template_args['att_edit_label'] = __('View/Edit Contact' ); |
||
1773 | |||
1774 | //create link |
||
1775 | $this->_template_args['create_link'] = $primary_registration instanceof EE_Registration ? EE_Admin_Page::add_query_args_and_nonce( array( 'action' => 'duplicate_attendee', '_REG_ID' => $this->_registration->ID() ), REG_ADMIN_URL ): ''; |
||
1776 | $this->_template_args['create_label'] = __('Create Contact', 'event_espresso'); |
||
1777 | |||
1778 | $this->_template_args['att_check'] = $att_check; |
||
1779 | |||
1780 | |||
1781 | $template_path = REG_TEMPLATE_PATH . 'reg_admin_details_side_meta_box_registrant.template.php'; |
||
1782 | echo EEH_Template::display_template( $template_path, $this->_template_args, TRUE ); |
||
1783 | } |
||
1784 | |||
1785 | |||
1786 | |||
1787 | |||
1788 | |||
1789 | /** |
||
1790 | * trash or restore registrations |
||
1791 | * @param boolean $trash whether to archive or restore |
||
1792 | * @access protected |
||
1793 | * @return void |
||
1794 | */ |
||
1795 | protected function _trash_or_restore_registrations( $trash = TRUE ) { |
||
1796 | $REGM = EEM_Registration::instance(); |
||
1797 | |||
1798 | $success = 1; |
||
1799 | $error = 0; |
||
1800 | |||
1801 | $tickets = array(); |
||
1802 | $dtts = array(); |
||
1803 | |||
1804 | //if empty _REG_ID then get out because there's nothing to do |
||
1805 | View Code Duplication | if ( empty( $this->_req_data['_REG_ID'] ) ) { |
|
1806 | $msg = $trash ? __('In order to trash registrations you must select which ones you wish to trash by clicking the checkboxes.', 'event_espresso') : __('In order to restore registrations you must select which ones you wish to restore by clicking the checkboxes.', 'event_espresso'); |
||
1807 | EE_Error::add_error( $msg, __FILE__, __LINE__, __FUNCTION__ ); |
||
1808 | $this->_redirect_after_action(FALSE, '', '', array(), TRUE ); |
||
1809 | } |
||
1810 | |||
1811 | //Checkboxes |
||
1812 | if (!empty($this->_req_data['_REG_ID']) && is_array($this->_req_data['_REG_ID'])) { |
||
1813 | // if array has more than one element than success message should be plural |
||
1814 | $success = count( $this->_req_data['_REG_ID'] ) > 1 ? 2 : 1; |
||
1815 | // cycle thru checkboxes |
||
1816 | while (list( $ind, $REG_ID ) = each($this->_req_data['_REG_ID'])) { |
||
1817 | |||
1818 | $REG = $REGM->get_one_by_ID($REG_ID); |
||
1819 | $payment_count = $REG->get_first_related('Transaction')->count_related('Payment'); |
||
1820 | if ( $payment_count > 0 ) { |
||
1821 | $name = $REG->attendee() instanceof EE_Attendee ? $REG->attendee()->full_name() : __( 'Unknown Attendee', 'event_espresso' ); |
||
1822 | $error = 1; |
||
1823 | $success = 0; |
||
1824 | EE_Error::add_error( sprintf( __('The registration for %s could not be trashed because it has payments attached to the related transaction. If you wish to trash this registration you must first delete the payments on the related transaction.', 'event_espresso'), $name ), __FILE__, __FUNCTION__, __LINE__ ); |
||
1825 | continue; //can't trash this registration because it has payments. |
||
1826 | } |
||
1827 | $ticket = $REG->get_first_related('Ticket'); |
||
1828 | $tickets[$ticket->ID()] = $ticket; |
||
1829 | $dtt = $ticket->get_many_related('Datetime'); |
||
1830 | $dtts = array_merge($dtts, $dtt); |
||
1831 | |||
1832 | $updated = $trash ? $REG->delete() : $REG->restore(); |
||
1833 | if ( !$updated ) { |
||
1834 | $success = 0; |
||
1835 | } else { |
||
1836 | $success = 2; |
||
1837 | }/**/ |
||
1838 | } |
||
1839 | |||
1840 | } else { |
||
1841 | // grab single id and delete |
||
1842 | $REG_ID = absint($this->_req_data['_REG_ID']); |
||
1843 | $REG = $REGM->get_one_by_ID($REG_ID); |
||
1844 | $ticket = $REG->get_first_related('Ticket'); |
||
1845 | $tickets[$ticket->ID()] = $ticket; |
||
1846 | $dtts = $ticket->get_many_related('Datetime'); |
||
1847 | $updated = $trash ? $REG->delete() : $REG->restore(); |
||
1848 | if ( ! $updated ) { |
||
1849 | $success = 0; |
||
1850 | } |
||
1851 | |||
1852 | } |
||
1853 | |||
1854 | //now let's update counts |
||
1855 | EEM_Ticket::instance()->update_tickets_sold($tickets); |
||
1856 | EEM_Datetime::instance()->update_sold($dtts); |
||
1857 | |||
1858 | $what = $success > 1 ? __( 'Registrations', 'event_espresso' ) : __( 'Registration', 'event_espresso' ); |
||
1859 | $action_desc = $trash ? __( 'moved to the trash', 'event_espresso' ) : __( 'restored', 'event_espresso' ); |
||
1860 | $overwrite_msgs = $error ? TRUE : FALSE; |
||
1861 | $this->_redirect_after_action( $success, $what, $action_desc, array( 'action' => 'default' ), $overwrite_msgs ); |
||
1862 | } |
||
1863 | |||
1864 | |||
1865 | |||
1866 | |||
1867 | |||
1868 | /** |
||
1869 | * This is used to permanently delete registrations. Note, this will handle not only deleting permanently the registration but also. |
||
1870 | * |
||
1871 | * 1. Removing relations to EE_Attendee |
||
1872 | * 2. Deleting permanently the related transaction, but ONLY if all related registrations to the transaction are ALSO trashed. |
||
1873 | * 3. Deleting permanently any related Line items but only if the above conditions are met. |
||
1874 | * 4. Removing relationships between all tickets and the related registrations |
||
1875 | * 5. Deleting permanently any related Answers (and the answers for other related registrations that were deleted.) |
||
1876 | * 6. Deleting permanently any related Checkins. |
||
1877 | * @return void |
||
1878 | */ |
||
1879 | protected function _delete_registrations() { |
||
1880 | $REG_MDL = EEM_Registration::instance(); |
||
1881 | |||
1882 | $success = 1; |
||
1883 | |||
1884 | //Checkboxes |
||
1885 | if (!empty($this->_req_data['_REG_ID']) && is_array($this->_req_data['_REG_ID'])) { |
||
1886 | // if array has more than one element than success message should be plural |
||
1887 | $success = count( $this->_req_data['_REG_ID'] ) > 1 ? 2 : 1; |
||
1888 | // cycle thru checkboxes |
||
1889 | while (list( $ind, $REG_ID ) = each($this->_req_data['_REG_ID'])) { |
||
1890 | $REG = $REG_MDL->get_one_by_ID($REG_ID); |
||
1891 | if ( ! $REG instanceof EE_Registration ) |
||
1892 | continue; |
||
1893 | $deleted = $this->_delete_registration($REG); |
||
1894 | if ( !$deleted ) { |
||
1895 | $success = 0; |
||
1896 | } |
||
1897 | } |
||
1898 | |||
1899 | } else { |
||
1900 | // grab single id and delete |
||
1901 | $REG_ID = $this->_req_data['_REG_ID']; |
||
1902 | $REG = $REG_MDL->get_one_by_ID($REG_ID); |
||
1903 | $deleted = $this->_delete_registration($REG); |
||
1904 | if ( ! $deleted ) { |
||
1905 | $success = 0; |
||
1906 | } |
||
1907 | |||
1908 | } |
||
1909 | |||
1910 | $what = $success > 1 ? __( 'Registrations', 'event_espresso' ) : __( 'Registration', 'event_espresso' ); |
||
1911 | $action_desc = __( 'permanently deleted.', 'event_espresso' ); |
||
1912 | $this->_redirect_after_action( $success, $what, $action_desc, array( 'action' => 'default' ), TRUE ); |
||
1913 | } |
||
1914 | |||
1915 | |||
1916 | |||
1917 | |||
1918 | |||
1919 | /** |
||
1920 | * handles the permanent deletion of a registration. See comments with _delete_registrations() for details on what models get affected. |
||
1921 | * @param EE_Registration $REG registration to be deleted permenantly |
||
1922 | * @return boolean true = successful deletion, false = fail. |
||
1923 | */ |
||
1924 | protected function _delete_registration( EE_Registration $REG ) { |
||
1925 | //first we start with the transaction... ultimately, we WILL not delete permanently if there are any related registrations on the transaction that are NOT trashed. |
||
1926 | $TXN = $REG->get_first_related('Transaction'); |
||
1927 | $REGS = $TXN->get_many_related('Registration'); |
||
1928 | |||
1929 | $all_trashed = TRUE; |
||
1930 | foreach ( $REGS as $registration ) { |
||
1931 | if ( ! $registration->get('REG_deleted') ) |
||
1932 | $all_trashed = FALSE; |
||
1933 | } |
||
1934 | |||
1935 | if ( ! $all_trashed ) { |
||
1936 | EE_Error::add_error( __('Unable to permanently delete this registration. Before this registration can be permanently deleted, all registrations made in the same transaction must be trashed as well. These registrations will be permanently deleted in the same action.', 'event_espresso'), __FILE__, __FUNCTION__, __LINE__ ); |
||
1937 | return false; |
||
1938 | } |
||
1939 | |||
1940 | //k made it here so that means we can delete all the related transactions and their answers (but let's do them separately from THIS one). |
||
1941 | foreach ( $REGS as $registration ) { |
||
1942 | |||
1943 | //delete related answers |
||
1944 | $registration->delete_related_permanently('Answer'); |
||
1945 | |||
1946 | //remove relationship to EE_Attendee (but we ALWAYS leave the contact record intact) |
||
1947 | $attendee = $registration->get_first_related('Attendee'); |
||
1948 | if ( $attendee instanceof EE_Attendee ) { |
||
1949 | $registration->_remove_relation_to($attendee, 'Attendee'); |
||
1950 | } |
||
1951 | |||
1952 | //now remove relationships to tickets on this registration. |
||
1953 | $registration->_remove_relations('Ticket'); |
||
1954 | |||
1955 | //now delete permanently the checkins related to this registration. |
||
1956 | $registration->delete_related_permanently('Checkin'); |
||
1957 | |||
1958 | if ( $registration->ID() === $REG->ID() ) |
||
1959 | continue; //we don't want to delete permanently the existing registration just yet. |
||
1960 | |||
1961 | //remove relation to transaction for these registrations if NOT the existing registrations |
||
1962 | $registration->_remove_relations('Transaction'); |
||
1963 | |||
1964 | //now delete this registration permanently |
||
1965 | $registration->delete_permanently(); |
||
1966 | } |
||
1967 | |||
1968 | //now all related registrations on the transaction are handled. So let's just handle this registration itself (the transaction and line items should be all that's left). |
||
1969 | //delete the line items related to the transaction for this registration. |
||
1970 | $TXN->delete_related_permanently('Line_Item'); |
||
1971 | |||
1972 | //we need to remove all the relationships on the transaction |
||
1973 | $TXN->delete_related_permanently('Payment'); |
||
1974 | $TXN->delete_related_permanently('Extra_Meta'); |
||
1975 | |||
1976 | //now we can delete this REG permanently (and the transaction of course) |
||
1977 | $REG->delete_related_permanently('Transaction'); |
||
1978 | return $REG->delete_permanently(); |
||
1979 | } |
||
1980 | |||
1981 | |||
1982 | |||
1983 | /** |
||
1984 | * generates HTML for the Register New Attendee Admin page |
||
1985 | * |
||
1986 | * @access private |
||
1987 | * @throws \EE_Error |
||
1988 | * @return void |
||
1989 | */ |
||
1990 | public function new_registration() { |
||
1991 | if ( ! $this->_set_reg_event() ) { |
||
1992 | throw new EE_Error(__('Unable to continue with registering because there is no Event ID in the request', 'event_espresso') ); |
||
1993 | } |
||
1994 | EE_Registry::instance()->REQ->set_espresso_page( TRUE ); |
||
1995 | |||
1996 | // gotta start with a clean slate if we're not coming here via ajax |
||
1997 | if ( ! defined('DOING_AJAX' ) && ( ! isset( $this->_req_data['processing_registration'] ) || isset( $this->_req_data['step_error'] ))) { |
||
1998 | EE_Registry::instance()->SSN->clear_session( __CLASS__, __FUNCTION__ ); |
||
1999 | } |
||
2000 | |||
2001 | $this->_template_args['event_name'] = '' ; |
||
2002 | // event name |
||
2003 | if ( $this->_reg_event ) { |
||
2004 | $this->_template_args['event_name'] = $this->_reg_event->name(); |
||
2005 | $edit_event_url = self::add_query_args_and_nonce( array( 'action'=>'edit', 'post'=>$this->_reg_event->ID() ), EVENTS_ADMIN_URL ); |
||
2006 | $edit_event_lnk = '<a href="'.$edit_event_url.'" title="' . esc_attr__( 'Edit ', 'event_espresso' ) . $this->_reg_event->name() . '">' . __( 'Edit Event', 'event_espresso' ) . '</a>'; |
||
2007 | $this->_template_args['event_name'] .= ' <span class="admin-page-header-edit-lnk not-bold">' . $edit_event_lnk . '</span>' ; |
||
2008 | } |
||
2009 | |||
2010 | $this->_template_args['step_content'] = $this->_get_registration_step_content(); |
||
2011 | |||
2012 | if ( defined('DOING_AJAX' ) ) |
||
2013 | $this->_return_json(); |
||
2014 | |||
2015 | |||
2016 | // grab header |
||
2017 | $template_path = REG_TEMPLATE_PATH . 'reg_admin_register_new_attendee.template.php'; |
||
2018 | $this->_template_args['admin_page_content'] = EEH_Template::display_template( $template_path, $this->_template_args, TRUE ); |
||
2019 | |||
2020 | //$this->_set_publish_post_box_vars( NULL, FALSE, FALSE, NULL, FALSE ); |
||
2021 | // the details template wrapper |
||
2022 | $this->display_admin_page_with_sidebar(); |
||
2023 | } |
||
2024 | |||
2025 | |||
2026 | |||
2027 | |||
2028 | /** |
||
2029 | * This returns the content for a registration step |
||
2030 | * |
||
2031 | * @access protected |
||
2032 | * @return string html |
||
2033 | */ |
||
2034 | protected function _get_registration_step_content() { |
||
2035 | |||
2036 | $template_path = REG_TEMPLATE_PATH . 'reg_admin_register_new_attendee_step_content.template.php'; |
||
2037 | $template_args = array( |
||
2038 | 'title' => '', |
||
2039 | 'content' => '', |
||
2040 | 'step_button_text' => '' |
||
2041 | ); |
||
2042 | |||
2043 | //to indicate we're processing a new registration |
||
2044 | $hidden_fields = array( |
||
2045 | 'processing_registration' => array( |
||
2046 | 'type' => 'hidden', |
||
2047 | 'value' => 1 |
||
2048 | ), |
||
2049 | 'event_id' => array( |
||
2050 | 'type' => 'hidden', |
||
2051 | 'value' => $this->_reg_event->ID() |
||
2052 | ) |
||
2053 | ); |
||
2054 | |||
2055 | //if the cart is empty then we know we're at step one so we'll display ticket selector |
||
2056 | $cart = EE_Registry::instance()->SSN->get_session_data('cart'); |
||
2057 | $step = empty( $cart ) ? 'ticket' : 'questions'; |
||
2058 | switch ( $step ) { |
||
2059 | case 'ticket' : |
||
2060 | $template_args['title'] = __('Step One: Select the Ticket for this registration', 'event_espresso'); |
||
2061 | $template_args['content'] = EED_Ticket_Selector::instance()->display_ticket_selector( $this->_reg_event ); |
||
2062 | $template_args['step_button_text'] = __('Add Tickets and Continue to Registrant Details', 'event_espresso'); |
||
2063 | $template_args['show_notification_toggle'] = FALSE; |
||
2064 | break; |
||
2065 | case 'questions' : |
||
2066 | $template_args['title'] = __('Step Two: Add Registrant Details for this Registration', 'event_espresso'); |
||
2067 | //in theory we should be able to run EED_SPCO at this point because the cart should have been setup properly by the first process_reg_step run. |
||
2068 | $template_args['content'] = EED_Single_Page_Checkout::registration_checkout_for_admin(); |
||
2069 | $template_args['step_button_text'] = __('Save Registration and Continue to Details', 'event_espresso'); |
||
2070 | $template_args['show_notification_toggle'] = TRUE; |
||
2071 | break; |
||
2072 | } |
||
2073 | |||
2074 | $this->_set_add_edit_form_tags( 'process_reg_step', $hidden_fields ); //we come back to the process_registration_step route. |
||
2075 | |||
2076 | return EEH_Template::display_template( $template_path, $template_args, TRUE ); |
||
2077 | } |
||
2078 | |||
2079 | |||
2080 | |||
2081 | |||
2082 | |||
2083 | |||
2084 | /** |
||
2085 | * set_reg_event |
||
2086 | * @access private |
||
2087 | * @return boolean |
||
2088 | */ |
||
2089 | private function _set_reg_event() { |
||
2090 | if ( is_object( $this->_reg_event )) { |
||
2091 | return TRUE; |
||
2092 | } |
||
2093 | $EVT_ID = ( ! empty( $this->_req_data['event_id'] )) ? absint( $this->_req_data['event_id'] ) : FALSE; |
||
2094 | if ( ! $EVT_ID ) { |
||
2095 | return FALSE; |
||
2096 | } |
||
2097 | |||
2098 | $this->_reg_event = EEM_Event::instance()->get_one_by_ID($EVT_ID); |
||
2099 | return TRUE; |
||
2100 | } |
||
2101 | |||
2102 | |||
2103 | |||
2104 | |||
2105 | |||
2106 | /** |
||
2107 | * process_reg_step |
||
2108 | * |
||
2109 | * @access public |
||
2110 | * @return string |
||
2111 | */ |
||
2112 | public function process_reg_step() { |
||
2113 | |||
2114 | $this->_set_reg_event(); |
||
2115 | EE_Registry::instance()->REQ->set_espresso_page( TRUE ); |
||
2116 | |||
2117 | //what step are we on? |
||
2118 | $cart = EE_Registry::instance()->SSN->get_session_data( 'cart' ); |
||
2119 | $step = empty( $cart ) ? 'ticket' : 'questions'; |
||
2120 | |||
2121 | //if doing ajax then we need to verify the nonce |
||
2122 | View Code Duplication | if ( 'DOING_AJAX' ) { |
|
2123 | $nonce = isset( $this->_req_data[$this->_req_nonce] ) ? sanitize_text_field( $this->_req_data[$this->_req_nonce] ) : ''; |
||
2124 | $this->_verify_nonce( $nonce, $this->_req_nonce ); |
||
2125 | } |
||
2126 | |||
2127 | switch ( $step ) { |
||
2128 | case 'ticket' : |
||
2129 | //process ticket selection |
||
2130 | $success = EED_Ticket_Selector::instance()->process_ticket_selections(); |
||
2131 | if ( $success ) { |
||
2132 | EE_Error::add_success( __('Tickets Selected. Now complete the registration.'), 'event_espresso'); |
||
2133 | } else { |
||
2134 | $query_args['step_error'] = $this->_req_data['step_error'] = TRUE; |
||
2135 | } |
||
2136 | if ( defined('DOING_AJAX') ) { |
||
2137 | $this->new_registration(); //display next step |
||
2138 | } else { |
||
2139 | $query_args['action'] = 'new_registration'; |
||
2140 | $query_args['processing_registration'] = true; |
||
2141 | $query_args['event_id'] = $this->_reg_event->ID(); |
||
2142 | $this->_redirect_after_action( FALSE, '', '', $query_args, TRUE ); |
||
2143 | } |
||
2144 | break; |
||
2145 | case 'questions' : |
||
2146 | if( ! isset( $this->_req_data[ 'txn_reg_status_change' ], $this->_req_data[ 'txn_reg_status_change' ][ 'send_notifications' ] ) ) { |
||
2147 | add_filter( 'FHEE__EED_Messages___maybe_registration__deliver_notifications', '__return_false', 15 ); |
||
2148 | } |
||
2149 | //process registration |
||
2150 | $transaction = EED_Single_Page_Checkout::instance()->process_registration_from_admin(); |
||
2151 | if ( ! $transaction instanceof EE_Transaction ) { |
||
2152 | $query_args = array( |
||
2153 | 'action' => 'new_registration', |
||
2154 | 'processing_registration' => true, |
||
2155 | 'event_id' => $this->_reg_event->ID() |
||
2156 | ); |
||
2157 | |||
2158 | View Code Duplication | if ( defined('DOING_AJAX' )) { |
|
2159 | //display registration form again because there are errors (maybe validation?) |
||
2160 | $this->new_registration(); |
||
2161 | return; |
||
2162 | } else { |
||
2163 | $this->_redirect_after_action( FALSE, '', '', $query_args, TRUE ); |
||
2164 | return; |
||
2165 | } |
||
2166 | } |
||
2167 | /** @type EE_Transaction_Payments $transaction_payments */ |
||
2168 | $transaction_payments = EE_Registry::instance()->load_class( 'Transaction_Payments' ); |
||
2169 | // maybe update status, and make sure to save transaction if not done already |
||
2170 | if ( ! $transaction_payments->update_transaction_status_based_on_total_paid( $transaction )) { |
||
2171 | $transaction->save(); |
||
2172 | } |
||
2173 | $query_args = array( |
||
2174 | 'action' => 'view_transaction', |
||
2175 | 'TXN_ID' => $transaction->ID(), |
||
2176 | 'page' => 'espresso_transactions' |
||
2177 | ); |
||
2178 | EE_Error::add_success( __('Registration Created. Please review the transaction and add any payments as necessary', 'event_espresso') ); |
||
2179 | $this->_redirect_after_action( FALSE, '', '', $query_args, TRUE ); |
||
2180 | break; |
||
2181 | } |
||
2182 | |||
2183 | //what are you looking here for? Should be nothing to do at this point. |
||
2184 | } |
||
2185 | |||
2186 | |||
2187 | |||
2188 | |||
2189 | |||
2190 | |||
2191 | |||
2192 | |||
2193 | /** |
||
2194 | * generates HTML for the Attendee Contact List |
||
2195 | * @access protected |
||
2196 | * @return void |
||
2197 | */ |
||
2198 | protected function _attendee_contact_list_table() { |
||
2199 | do_action( 'AHEE_log', __FILE__, __FUNCTION__, '' ); |
||
2200 | $this->_search_btn_label = __('Contacts', 'event_espresso'); |
||
2201 | $this->display_admin_list_table_page_with_no_sidebar(); |
||
2202 | } |
||
2203 | |||
2204 | |||
2205 | |||
2206 | |||
2207 | |||
2208 | /** |
||
2209 | * get_attendees |
||
2210 | * @param bool $count whether to return count or data. |
||
2211 | * @access public |
||
2212 | * @return array |
||
2213 | */ |
||
2214 | public function get_attendees( $per_page, $count = FALSE, $trash = FALSE ) { |
||
2215 | |||
2216 | do_action( 'AHEE_log', __FILE__, __FUNCTION__, '' ); |
||
2217 | require_once( REG_ADMIN . 'EE_Attendee_Contact_List_Table.class.php' ); |
||
2218 | $ATT_MDL = EEM_Attendee::instance(); |
||
2219 | |||
2220 | $this->_req_data['orderby'] = ! empty($this->_req_data['orderby']) ? $this->_req_data['orderby'] : ''; |
||
2221 | |||
2222 | switch ($this->_req_data['orderby']) { |
||
2223 | case 'ATT_ID': |
||
2224 | $orderby = 'ATT_ID'; |
||
2225 | break; |
||
2226 | case 'ATT_fname': |
||
2227 | $orderby = 'ATT_fname'; |
||
2228 | break; |
||
2229 | case 'ATT_email': |
||
2230 | $orderby = 'ATT_email'; |
||
2231 | break; |
||
2232 | case 'ATT_city': |
||
2233 | $orderby = 'ATT_city'; |
||
2234 | break; |
||
2235 | case 'STA_ID': |
||
2236 | $orderby = 'STA_ID'; |
||
2237 | break; |
||
2238 | case 'CNT_ID': |
||
2239 | $orderby = 'CNT_ID'; |
||
2240 | break; |
||
2241 | default: |
||
2242 | $orderby = 'ATT_lname'; |
||
2243 | } |
||
2244 | |||
2245 | $sort = ( isset( $this->_req_data['order'] ) && ! empty( $this->_req_data['order'] )) ? $this->_req_data['order'] : 'ASC'; |
||
2246 | |||
2247 | $current_page = isset( $this->_req_data['paged'] ) && !empty( $this->_req_data['paged'] ) ? $this->_req_data['paged'] : 1; |
||
2248 | $per_page = isset( $per_page ) && !empty( $per_page ) ? $per_page : 10; |
||
2249 | $per_page = isset( $this->_req_data['perpage'] ) && !empty( $this->_req_data['perpage'] ) ? $this->_req_data['perpage'] : $per_page; |
||
2250 | |||
2251 | $_where = array(); |
||
2252 | |||
2253 | if ( isset( $this->_req_data['s'] ) ) { |
||
2254 | $sstr = '%' . $this->_req_data['s'] . '%'; |
||
2255 | $_where['OR'] = array( |
||
2256 | 'Registration.Event.EVT_name' => array( 'LIKE', $sstr), |
||
2257 | 'Registration.Event.EVT_desc' => array( 'LIKE', $sstr ), |
||
2258 | 'Registration.Event.EVT_short_desc' => array( 'LIKE' , $sstr ), |
||
2259 | 'ATT_fname' => array( 'LIKE', $sstr ), |
||
2260 | 'ATT_lname' => array( 'LIKE', $sstr ), |
||
2261 | 'ATT_short_bio' => array( 'LIKE', $sstr ), |
||
2262 | 'ATT_email' => array('LIKE', $sstr ), |
||
2263 | 'ATT_address' => array( 'LIKE', $sstr ), |
||
2264 | 'ATT_address2' => array( 'LIKE', $sstr ), |
||
2265 | 'ATT_city' => array( 'LIKE', $sstr ), |
||
2266 | 'Country.CNT_name' => array( 'LIKE', $sstr ), |
||
2267 | 'State.STA_name' => array('LIKE', $sstr ), |
||
2268 | 'ATT_phone' => array( 'LIKE', $sstr ), |
||
2269 | 'Registration.REG_final_price' => array( 'LIKE', $sstr ), |
||
2270 | 'Registration.REG_code' => array( 'LIKE', $sstr ), |
||
2271 | 'Registration.REG_count' => array( 'LIKE' , $sstr ), |
||
2272 | 'Registration.REG_group_size' => array( 'LIKE' , $sstr ) |
||
2273 | ); |
||
2274 | } |
||
2275 | |||
2276 | |||
2277 | $offset = ($current_page-1)*$per_page; |
||
2278 | $limit = $count ? NULL : array( $offset, $per_page ); |
||
2279 | |||
2280 | if ( $trash ) { |
||
2281 | $_where['status'] = array( '!=', 'publish' ); |
||
2282 | $all_attendees = $count ? $ATT_MDL->count( array($_where,'order_by'=>array($orderby=>$sort), 'limit'=>$limit)): $ATT_MDL->get_all( array($_where,'order_by'=>array($orderby=>$sort), 'limit'=>$limit)); |
||
2283 | } else { |
||
2284 | $_where['status'] = array( 'IN', array( 'publish' ) ); |
||
2285 | $all_attendees = $count ? $ATT_MDL->count( array($_where, 'order_by'=>array($orderby=>$sort),'limit'=>$limit)) : $ATT_MDL->get_all( array($_where, 'order_by'=>array($orderby=>$sort), 'limit'=>$limit) ); |
||
2286 | } |
||
2287 | |||
2288 | return $all_attendees; |
||
2289 | } |
||
2290 | |||
2291 | |||
2292 | |||
2293 | |||
2294 | /** |
||
2295 | * This is just taking care of resending the registration confirmation |
||
2296 | * |
||
2297 | * @access protected |
||
2298 | * @return void |
||
2299 | */ |
||
2300 | protected function _resend_registration() { |
||
2301 | $this->_process_resend_registration(); |
||
2302 | $query_args = isset($this->_req_data['redirect_to'] ) ? array('action' => $this->_req_data['redirect_to'], '_REG_ID' => $this->_req_data['_REG_ID'] ) : array( |
||
2303 | 'action' => 'default' |
||
2304 | ); |
||
2305 | $this->_redirect_after_action(FALSE, '', '', $query_args, TRUE ); |
||
2306 | } |
||
2307 | |||
2308 | |||
2309 | |||
2310 | |||
2311 | |||
2312 | |||
2313 | public function _registrations_report(){ |
||
2339 | |||
2340 | |||
2341 | |||
2342 | public function _contact_list_export(){ |
||
2343 | EE_Registry::instance()->load_helper( 'File' ); |
||
2344 | if ( is_readable(EE_CLASSES . 'EE_Export.class.php')) { |
||
2345 | require_once(EE_CLASSES . 'EE_Export.class.php'); |
||
2346 | $EE_Export = EE_Export::instance($this->_req_data); |
||
2347 | $EE_Export->export_attendees(); |
||
2348 | } |
||
2349 | } |
||
2350 | |||
2351 | public function _contact_list_report(){ |
||
2369 | |||
2370 | |||
2371 | |||
2372 | |||
2373 | |||
2374 | |||
2375 | /*************************************** ATTENDEE DETAILS ***************************************/ |
||
2376 | |||
2377 | |||
2378 | /** |
||
2379 | * This duplicates the attendee object for the given incoming registration id and attendee_id. |
||
2380 | * @return void |
||
2381 | */ |
||
2382 | protected function _duplicate_attendee() { |
||
2383 | $action = !empty( $this->_req_data['return'] ) ? $this->_req_data['return'] : 'default'; |
||
2384 | //verify we have necessary info |
||
2385 | View Code Duplication | if ( empty($this->_req_data['_REG_ID'] ) ) { |
|
2386 | EE_Error::add_error( __('Unable to create the contact for the registration because the required paramaters are not present (_REG_ID )', 'event_espresso'), __FILE__, __LINE__, __FUNCTION__ ); |
||
2387 | $query_args = array( 'action' => $action ); |
||
2388 | $this->_redirect_after_action('', '', '', $query_args, TRUE); |
||
2389 | } |
||
2390 | |||
2391 | //okay necessary deets present... let's dupe the incoming attendee and attach to incoming registration. |
||
2392 | $registration = EEM_Registration::instance()->get_one_by_ID( $this->_req_data['_REG_ID'] ); |
||
2393 | $attendee = $registration->attendee(); |
||
2394 | |||
2395 | //remove relation of existing attendee on registration |
||
2396 | $registration->_remove_relation_to($attendee, 'Attendee' ); |
||
2397 | //new attendee |
||
2398 | $new_attendee = clone $attendee; |
||
2399 | $new_attendee->set( 'ATT_ID', 0 ); |
||
2400 | $new_attendee->save(); |
||
2401 | |||
2402 | //add new attendee to reg |
||
2403 | $registration->_add_relation_to( $new_attendee, 'Attendee'); |
||
2404 | |||
2405 | EE_Error::add_success( __('New Contact record created. Now make any edits you wish to make for this contact.', 'event_espresso') ); |
||
2406 | |||
2407 | //redirect to edit page for attendee |
||
2408 | $query_args = array( 'post' => $new_attendee->ID(), 'action' => 'edit_attendee' ); |
||
2409 | |||
2410 | $this->_redirect_after_action( '', '', '', $query_args, TRUE ); |
||
2411 | } |
||
2412 | |||
2413 | |||
2414 | //related to cpt routes |
||
2415 | protected function _insert_update_cpt_item($post_id, $post) { |
||
2416 | $success = true; |
||
2417 | $attendee = EEM_Attendee::instance()->get_one_by_ID( $post_id ); |
||
2418 | //for attendee updates |
||
2419 | if ( $post->post_type = 'espresso_attendees' && !empty( $attendee ) ) { |
||
2420 | //note we should only be UPDATING attendees at this point. |
||
2421 | $updated_fields = array( |
||
2422 | 'ATT_fname' => $this->_req_data['ATT_fname'], |
||
2423 | 'ATT_lname' => $this->_req_data['ATT_lname'], |
||
2452 | |||
2453 | |||
2454 | |||
2455 | |||
2456 | public function trash_cpt_item($post_id) {} |
||
2460 | |||
2461 | |||
2462 | public function attendee_editor_metaboxes() { |
||
2481 | |||
2482 | |||
2483 | /** |
||
2484 | * Metabox for attendee contact info |
||
2485 | * @param WP_Post $post wp post object |
||
2486 | * @return string attendee contact info ( and form ) |
||
2487 | */ |
||
2488 | public function attendee_contact_info( $post ) { |
||
2494 | |||
2495 | |||
2496 | |||
2497 | /** |
||
2498 | * Metabox for attendee details |
||
2499 | * @param WP_Post $post wp post object |
||
2500 | * @return string attendee address details (and form) |
||
2501 | */ |
||
2502 | public function attendee_address_details($post) { |
||
2545 | |||
2546 | |||
2547 | /** |
||
2548 | * _attendee_details |
||
2549 | * @access protected |
||
2550 | * @return void |
||
2551 | */ |
||
2552 | public function attendee_registrations_meta_box( $post ) { |
||
2560 | |||
2561 | |||
2562 | |||
2563 | |||
2564 | /** |
||
2565 | * add in the form fields for the attendee edit |
||
2566 | * @param WP_Post $post wp post object |
||
2567 | * @return string html for new form. |
||
2568 | */ |
||
2569 | public function after_title_form_fields($post) { |
||
2576 | |||
2577 | |||
2578 | |||
2579 | |||
2580 | |||
2581 | |||
2582 | /** |
||
2583 | * _trash_or_restore_attendee |
||
2584 | * @param boolean $trash - whether to move item to trash (TRUE) or restore it (FALSE) |
||
2585 | * @access protected |
||
2586 | * @return void |
||
2587 | */ |
||
2588 | protected function _trash_or_restore_attendees( $trash = TRUE ) { |
||
2625 | |||
2626 | } |
||
2627 | |||
2631 |
Adding a
@return
annotation to a constructor is not recommended, since a constructor does not have a meaningful return value.Please refer to the PHP core documentation on constructors.