| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217 |
- <?php
- if(!class_exists('Booked_AJAX')) {
- class Booked_AJAX {
- public function __construct() {
- // ------------ Guests & Logged-in Users ------------ //
- // Actions
- add_action('wp_ajax_booked_ajax_login', array(&$this,'booked_ajax_login'));
- add_action('wp_ajax_nopriv_booked_ajax_login', array(&$this,'booked_ajax_login'));
- add_action('wp_ajax_booked_ajax_forgot', array(&$this,'booked_ajax_forgot'));
- add_action('wp_ajax_nopriv_booked_ajax_forgot', array(&$this,'booked_ajax_forgot'));
- add_action('wp_ajax_booked_add_appt', array(&$this,'booked_add_appt'));
- add_action('wp_ajax_nopriv_booked_add_appt', array(&$this,'booked_add_appt'));
- // Loaders
- add_action('wp_ajax_booked_calendar_month', array(&$this,'booked_calendar_month'));
- add_action('wp_ajax_nopriv_booked_calendar_month', array(&$this,'booked_calendar_month'));
- add_action('wp_ajax_booked_calendar_date', array(&$this,'booked_calendar_date'));
- add_action('wp_ajax_nopriv_booked_calendar_date', array(&$this,'booked_calendar_date'));
- add_action('wp_ajax_booked_appointment_list_date', array(&$this,'booked_appointment_list_date'));
- add_action('wp_ajax_nopriv_booked_appointment_list_date', array(&$this,'booked_appointment_list_date'));
- add_action('wp_ajax_booked_new_appointment_form', array(&$this,'booked_new_appointment_form'));
- add_action('wp_ajax_nopriv_booked_new_appointment_form', array(&$this,'booked_new_appointment_form'));
- // ------------ Logged-in Users Only ------------ //
- // Actions
- add_action('wp_ajax_booked_cancel_appt', array(&$this,'booked_cancel_appt'));
- }
- // ------------ LOADERS ------------ //
- // Calendar Month
- public function booked_calendar_month(){
- booked_wpml_ajax();
- if (isset($_POST['gotoMonth'])):
- $calendar_id = (isset($_POST['calendar_id']) ? $_POST['calendar_id'] : false);
- $force_default = (isset($_POST['force_default']) ? $_POST['force_default'] : false);
- $timestamp = ($_POST['gotoMonth'] != 'false' ? strtotime($_POST['gotoMonth']) : current_time('timestamp'));
- $year = date_i18n('Y',$timestamp);
- $month = date_i18n('m',$timestamp);
- booked_fe_calendar($year,$month,$calendar_id,$force_default);
- endif;
- wp_die();
- }
- // Calendar Date
- public function booked_calendar_date(){
- booked_wpml_ajax();
- if (isset($_POST['date'])):
- $calendar_id = (isset($_POST['calendar_id']) ? $_POST['calendar_id'] : false);
- booked_fe_calendar_date_content($_POST['date'],$calendar_id);
- endif;
- wp_die();
- }
- // Appointment List Date
- public function booked_appointment_list_date(){
- booked_wpml_ajax();
- if (isset($_POST['date'])):
- $date = date_i18n('Ymd',strtotime($_POST['date']));
- $calendar_id = (isset($_POST['calendar_id']) ? $_POST['calendar_id'] : false);
- $force_default = (isset($_POST['force_default']) ? $_POST['force_default'] : false);
- booked_fe_appointment_list_content($date,$calendar_id,$force_default);
- endif;
- wp_die();
- }
- // New Appointment Form
- public function booked_new_appointment_form(){
- booked_wpml_ajax();
- if ( apply_filters( 'booked_show_new_appointment_form', true ) ):
- include(BOOKED_AJAX_INCLUDES_DIR . 'front/appointment-form.php');
- endif;
- wp_die();
- }
- // ------------ ACTIONS ------------ //
- public function booked_ajax_login(){
- booked_wpml_ajax();
- if (isset($_POST['security']) && isset($_POST['username']) && isset($_POST['password'])):
- $nonce_check = wp_verify_nonce( $_POST['security'], 'ajax_login_nonce' );
- if ($nonce_check){
- if (is_email($_POST['username'])) {
- $user = get_user_by('email', $_POST['username']);
- } else {
- $user = get_user_by('login', $_POST['username']);
- }
- $creds = array();
- if ($user && wp_check_password( $_POST['password'], $user->data->user_pass, $user->ID)) {
- $creds = array('user_login' => $user->data->user_login, 'user_password' => $_POST['password']);
- $creds['remember'] = true;
- }
- $user = wp_signon( $creds, false );
- if ( !is_wp_error($user) ):
- echo 'success';
- endif;
- }
- endif;
- wp_die();
- }
- public function booked_ajax_forgot(){
- booked_wpml_ajax();
- global $wpdb, $wp_hasher;
- if (isset($_POST['security']) && isset($_POST['username'])):
- $nonce_check = wp_verify_nonce( $_POST['security'], 'ajax_forgot_nonce' );
- if ($nonce_check){
- $password_reset = booked_reset_password( $_POST['username'] );
- if ( $password_reset ):
- echo 'success';
- endif;
- }
- endif;
- wp_die();
- }
- public function booked_add_appt(){
- booked_wpml_ajax();
- $can_add_appt = apply_filters(
- 'booked_can_add_appt',
- isset($_POST['date']) && isset($_POST['timestamp']) && isset($_POST['timeslot']) && isset($_POST['customer_type'])
- );
- if ( $can_add_appt ):
- include(BOOKED_AJAX_INCLUDES_DIR . 'front/book-appointment.php');
- endif;
- wp_die();
- }
- public function booked_cancel_appt(){
- booked_wpml_ajax();
- if (is_user_logged_in() && isset($_POST['appt_id'])):
- include(BOOKED_AJAX_INCLUDES_DIR . 'front/cancel-appointment.php');
- endif;
- wp_die();
- }
- }
- }
|