function event_espresso_manage_events() { global $wpdb, $org_options; ?> <div id="configure_organization_form" class="wrap meta-box-sortables ui-sortable"> <div id="event_reg_theme" class="wrap"> <div id="icon-options-event" class="icon32"></div> <h2> <?php if ($_REQUEST['page'] == 'events' && isset($_REQUEST['event_admin_reports'])) { switch ($_REQUEST['event_admin_reports']) { case 'charts': _e('Attendee Reports', 'event_espresso'); break; case 'event_list_attendees': case 'resend_email': case 'list_attendee_payments': _e('Attendee Reports', 'event_espresso'); if (!empty($_REQUEST['event_id']) && $_REQUEST['event_admin_reports'] != 'add_new_attendee') { echo '<a href="admin.php?page=events&event_admin_reports=add_new_attendee&event_id=' . $_REQUEST['event_id'] . '" class="button add-new-h2" style="margin-left: 20px;">' . __('Add New Attendee', 'event_espresso') . '</a>'; } break; case 'edit_attendee_record': _e('Edit Attendee Data', 'event_espresso'); break; case 'enter_attendee_payments': _e('Edit Attendee Payment Record', 'event_espresso'); break; case 'add_new_attendee': _e('Add New Attendee', 'event_espresso'); break; case 'event_newsletter': _e('Email Event Attendees', 'event_espresso'); break; } } else { _e('Event Overview', 'event_espresso'); if (isset($_REQUEST['action']) && ($_REQUEST['action'] == 'edit' || $_REQUEST['action'] == 'add_new_event')) { } else { echo '<a href="admin.php?page=events&action=add_new_event" class="button add-new-h2" style="margin-left: 20px;">' . __('Add New Event', 'event_espresso') . '</a>'; } } ?> </h2> <?php if (isset($_REQUEST['action']) && $_REQUEST['action'] == 'copy_event') { require_once "copy_event.php"; copy_event(); } if (isset($_REQUEST['action']) && $_REQUEST['action'] == 'delete') { event_espresso_delete_event(); } //Delete recurrence series of events if (isset($_REQUEST['action']) && $_REQUEST['action'] == 'delete_recurrence_series') { $r = $wpdb->get_results("SELECT id FROM " . EVENTS_DETAIL_TABLE . " ed WHERE recurrence_id = " . $_REQUEST['recurrence_id']); if ($wpdb->num_rows > 0) { foreach ($r as $row) { event_espresso_delete_event($row->id); } } } if (isset($_REQUEST['action']) && $_REQUEST['action'] == 'csv_import') { require_once 'csv_import.php'; csv_import(); } if (isset($_REQUEST['action']) && $_REQUEST['action'] == 'add') { require_once "insert_event.php"; add_event_to_db(); } //Update the event if (isset($_REQUEST['edit_action']) && $_REQUEST['edit_action'] == 'update') { require_once "update_event.php"; update_event(); } //If we need to add or edit a new event then we show the add or edit forms if (isset($_REQUEST['action']) && ($_REQUEST['action'] == 'add_new_event' || $_REQUEST['action'] == 'edit')) { ?> <form id="espresso_event_editor" name="form" method="post" action="<?php echo $_SERVER["REQUEST_URI"]; ?> "> <?php if ($_REQUEST['action'] == 'edit') { //show the edit form require_once "edit_event.php"; edit_event($_REQUEST['event_id']); } else { //Show the add new event form require_once "add_new_event.php"; add_new_event(); } ?> <br class="clear" /> </form> <!-- /event_reg_theme --> <?php } else { //If we are not adding or editing an event then show the list of events if (isset($_REQUEST['event_admin_reports'])) { switch ($_REQUEST['event_admin_reports']) { case 'charts': require_once EVENT_ESPRESSO_INCLUDES_DIR . "admin-reports/event_list_attendees.php"; require_once EVENT_ESPRESSO_INCLUDES_DIR . "admin-reports/charts.php"; espresso_charts(); break; case 'list_attendee_payments': require_once EVENT_ESPRESSO_INCLUDES_DIR . "admin-reports/event_list_attendees.php"; event_list_attendees(); break; case 'event_list_attendees': require_once EVENT_ESPRESSO_INCLUDES_DIR . "admin-reports/event_list_attendees.php"; event_list_attendees(); break; case 'edit_attendee_record': require_once EVENT_ESPRESSO_INCLUDES_DIR . "admin-reports/event_list_attendees.php"; require_once EVENT_ESPRESSO_INCLUDES_DIR . "admin-reports/edit_attendee_record.php"; edit_attendee_record(); break; case 'enter_attendee_payments': require_once EVENT_ESPRESSO_INCLUDES_DIR . "admin-reports/event_list_attendees.php"; require_once EVENT_ESPRESSO_INCLUDES_DIR . "admin-reports/enter_attendee_payments.php"; enter_attendee_payments(); break; case 'add_new_attendee': require_once EVENT_ESPRESSO_INCLUDES_DIR . "admin-reports/event_list_attendees.php"; require_once EVENT_ESPRESSO_INCLUDES_DIR . "admin-reports/add_new_attendee.php"; add_new_attendee($_REQUEST['event_id']); break; case 'event_newsletter': if (file_exists(EVENT_ESPRESSO_INCLUDES_DIR . "admin-files/event_newsletter.php")) { require_once EVENT_ESPRESSO_INCLUDES_DIR . "admin-files/event_newsletter.php"; event_newsletter($_REQUEST['event_id']); } else { require_once "event_newsletter.php"; } break; case 'resend_email': require_once EVENT_ESPRESSO_INCLUDES_DIR . "/admin-reports/event_list_attendees.php"; echo '<div id="message" class="updated fade"><p><strong>Resending email to attendee.</strong></p></div>'; event_espresso_email_confirmations(array('registration_id' => $_REQUEST['registration_id'], 'send_admin_email' => 'false', 'send_attendee_email' => 'true')); event_list_attendees(); break; default: event_espresso_edit_list(); break; } } else { event_espresso_edit_list(); } } //Do not remove anything below this line. These are the color box popups. ?> </div> </div> <div id="email_manager_info" style="display:none"> <h2><?php _e('Pre-existing Emails', 'event_espresso'); ?> </h2> <p><?php _e('These emails will override the custom email if a pre-existing email is selected. You must select "Yes" in the "Send custom confirmation emails for this event?" above.', 'event_espresso'); ?> </p> </div> <div id="coupon_code_info" style="display:none"> <h2><?php _e('Coupon/Promo Code', 'event_espresso'); ?> </h2><p><?php _e('This is used to apply discounts to events.', 'event_espresso'); ?> </p><p><?php _e('A coupon or promo code could can be anything you want. For example: Say you have an event that costs', 'event_espresso'); ?> <?php echo $org_options['currency_symbol']; ?> 200. <?php _e('If you supplied a promo like "PROMO50" and entered 50.00 into the "Discount w/Promo Code" field your event will be discounted', 'event_espresso'); ?> <?php echo $org_options['currency_symbol']; ?> 50.00, <?php _e('Bringing the cost of the event to', 'event_espresso'); ?> <?php echo $org_options['currency_symbol']; ?> 150. </p> <p><?php _e("Note: Promo Codes which are marked to 'apply to all events', although not explicitly enumerated, can also be used for this event, provided it allows promo codes.", "event_espresso"); ?> </p> </div> <div id="unique_id_info" style="display:none"> <h2><?php _e('Event Identifier', 'event_espresso'); ?> </h2><p><?php _e('This should be a unique identifier for the event. Example: "Event1" (without quotes.)</p><p>The unique ID can also be used in individual pages using the', 'event_espresso'); ?> [SINGLEEVENT single_event_id="<?php _e('Unique Event ID', 'event_espresso'); ?> "] <?php _e('shortcode', 'event_espresso'); ?> .</p> </div> <div id="secondary_info" style="display:none"> <h2><?php _e('Waitlist Events', 'event_espresso'); ?> </h2> <p><?php _e('These types of events can be used as a overflow or waiting list events.', 'event_espresso'); ?> </p> <p><?php _e('If an event is set up as an "Waitlist Event," it can be set to not appear in your event listings template. You may need to customize your event_listing.php file to make this work. For more information, please', 'event_espresso'); ?> <a href="http://eventespresso.com/forums/?p=512" target="_blank"><?php _e('visit the forums', 'event_espresso'); ?> </a>.</p> </div> <div id="external_URL_info" style="display:none"> <h2><?php _e('Off-site Registration Page', 'event_espresso'); ?> </h2> <p><?php _e('If an off-site registration page is entered, it will override your registration page and send attendees to the URL that is entered.', 'event_espresso'); ?> </p> </div> <div id="alt_email_info" style="display:none"> <h2><?php _e('Alternate Email Address', 'event_espresso'); ?> </h2> <p><?php _e('If an alternate email address is entered. Admin email notifications wil be sent to this address instead.', 'event_espresso'); ?> </p> </div> <div id="status_types_info" style="display:none;"> <h2><?php _e('Event Status Types', 'event_espresso'); ?> </h2> <ul> <li><strong><?php _e('Public', 'event_espresso'); ?> </strong><br /><?php _e('This type if event will appear in the event listings. It is a live event (not deleted, ongoing or secondary.)', 'event_espresso'); ?> </li> <li><strong><?php _e('Waitlist', 'event_espresso'); ?> </strong><br /><?php _e('This type of event can be hidden and used as a waiting list for a primary event. Template customizations may be required. For more information, please', 'event_espresso'); ?> <a href="http://eventespresso.com/forums/?p=512" target="_blank"><?php _e('visit the forums', 'event_espresso'); ?> </a></li> <li><strong><?php _e('Ongoing', 'event_espresso'); ?> </strong><br /><?php _e('This type of an event can be set to appear in your event listings and display a registration page. Template customizations are required. For more information, please', 'event_espresso'); ?> <a href="http://eventespresso.com/forums/?p=518" target="_blank"><?php _e('visit the forums', 'event_espresso'); ?> </a></li> <li><strong><?php _e('Deleted', 'event_espresso'); ?> </strong><br /><?php _e('This is event type will not appear in the event listings and will not dispaly a registrations page. Deleted events can still be accessed in the', 'event_espresso'); ?> <a href="admin.php?page=events"><?php _e('Attendee Reports', 'event_espresso'); ?> </a> <?php _e('page', 'event_espresso'); ?> .</li> </ul> </div> <?php echo event_espresso_custom_email_info(); }
function add_event_to_db($recurrence_arr = array()) { // echo "<pre>"; //print_r($_POST); //echo "</pre>"; global $wpdb, $org_options, $current_user, $espresso_premium; $wpdb->show_errors(); static $recurrence_id; if (get_option('event_espresso_re_active') == 1) { require_once EVENT_ESPRESSO_RECURRENCE_FULL_PATH . "functions/re_functions.php"; $recurrence_id = array_key_exists('recurrence_id', $recurrence_arr) ? $recurrence_arr['recurrence_id'] : Null; if ($_POST['recurrence'] == 'Y' && count($recurrence_arr) < 2) { if (is_null($recurrence_id)) { $recurrence_id = add_recurrence_master_record(); } $re_params = array('start_date' => $_POST['recurrence_type'] == 'a' ? $_POST['recurrence_start_date'] : $_POST['recurrence_manual_dates'], 'event_end_date' => $_POST['recurrence_type'] == 'a' ? $_POST['recurrence_event_end_date'] : $_POST['recurrence_manual_end_dates'], 'end_date' => $_POST['recurrence_type'] == 'a' ? $_POST['recurrence_end_date'] : $_POST['end_date'], 'registration_start' => $_POST['recurrence_regis_start_date'], 'registration_end' => $_POST['recurrence_regis_end_date'], 'frequency' => $_POST['recurrence_frequency'], 'interval' => $_POST['recurrence_interval'], 'type' => $_POST['recurrence_type'], 'weekdays' => $_POST['recurrence_weekday'], 'repeat_by' => $_POST['recurrence_repeat_by'], 'recurrence_regis_date_increment' => $_POST['recurrence_regis_date_increment'], 'recurrence_manual_dates' => $_POST['recurrence_manual_dates'], 'recurrence_manual_end_dates' => $_POST['recurrence_manual_end_dates'], 'recurrence_visibility' => $_POST['recurrence_visibility'], 'recurrence_id' => $recurrence_id, 'adding_to_db' => 'Y'); $recurrence_dates = $_POST['recurrence_type'] == 'm' ? find_recurrence_manual_dates($re_params) : find_recurrence_dates($re_params); } } //echo_f('re array', $recurrence_dates); if (defined('EVENT_ESPRESSO_RECURRENCE_MODULE_ACTIVE') && $_POST['recurrence'] == 'Y' && count($recurrence_arr) == 0) { //skip the first insert because we do not have the start dates } else { $event_mata = array(); //will be used to hold event meta data //If the Espresso Facebook Events is installed, add the event to Facebook //$fb = new FacebookEvents(); //echo $fb->espresso_createevent(); //echo $_POST['event']; $event_name = $_REQUEST['event']; $event_code = uniqid($current_user->ID . '-'); $event_identifier = $_REQUEST['event_identifier'] == '' ? $event_identifier = sanitize_title_with_dashes($event_name . '-' . $event_code) : ($event_identifier = sanitize_title_with_dashes($_REQUEST['event_identifier']) . $event_code); $event_desc = $_REQUEST['event_desc']; $display_desc = $_REQUEST['display_desc']; $display_reg_form = $_REQUEST['display_reg_form']; $address = esc_html($_REQUEST['address']); $address2 = esc_html($_REQUEST['address2']); $city = esc_html($_REQUEST['city']); $state = esc_html($_REQUEST['state']); $zip = esc_html($_REQUEST['zip']); $country = esc_html($_REQUEST['country']); $phone = esc_html($_REQUEST['phone']); $externalURL = esc_html($_REQUEST['externalURL']); $post_type = $_REQUEST['espresso_post_type']; //$event_location = $address . ' ' . $city . ', ' . $state . ' ' . $zip; $event_location = ($address != '' ? $address . ' ' : '') . ($address2 != '' ? '<br />' . $address2 : '') . ($city != '' ? '<br />' . $city : '') . ($state != '' ? ', ' . $state : '') . ($zip != '' ? '<br />' . $zip : '') . ($country != '' ? '<br />' . $country : ''); $reg_limit = $_REQUEST['reg_limit']; $allow_multiple = $_REQUEST['allow_multiple']; $additional_limit = $_REQUEST['additional_limit']; $member_only = isset($_REQUEST['member_only']) ? $_REQUEST['member_only'] : ''; $is_active = $_REQUEST['is_active']; $event_status = $_REQUEST['event_status']; //Get the first instance of the start and end times $start_time = $_REQUEST['start_time'][0]; $end_time = $_REQUEST['end_time'][0]; // Add registration times $registration_startT = event_date_display($_REQUEST['registration_startT'], 'H:i'); $registration_endT = event_date_display($_REQUEST['registration_endT'], 'H:i'); // Add Timezone $timezone_string = isset($_REQUEST['timezone_string']) ? $_REQUEST['timezone_string'] : ''; //Early discounts $early_disc = $_REQUEST['early_disc']; $early_disc_date = $_REQUEST['early_disc_date']; $early_disc_percentage = $_REQUEST['early_disc_percentage']; $conf_mail = $_REQUEST['conf_mail']; $use_coupon_code = $_REQUEST['use_coupon_code']; $alt_email = $_REQUEST['alt_email']; $send_mail = $_REQUEST['send_mail']; $email_id = isset($_REQUEST['email_name']) ? $_REQUEST['email_name'] : ''; //Venue Information $venue_title = $_REQUEST['venue_title']; $venue_url = $_REQUEST['venue_url']; $venue_phone = $_REQUEST['venue_phone']; $venue_image = $_REQUEST['venue_image']; //Virtual location $virtual_url = $_REQUEST['virtual_url']; $virtual_phone = $_REQUEST['virtual_phone']; $registration_start = array_key_exists('registration_start', $recurrence_arr) ? $recurrence_arr['registration_start'] : $_REQUEST['registration_start']; $registration_end = array_key_exists('registration_end', $recurrence_arr) ? $recurrence_arr['registration_end'] : $_REQUEST['registration_end']; //Check which start/end date to use. Will be determined by recurrenig events addon, if installed. if (array_key_exists('recurrence_start_date', $recurrence_arr)) { //Recurring event $start_date = $recurrence_arr['recurrence_start_date']; } elseif ($_REQUEST['start_date'] == '' && $_REQUEST['recurrence_start_date'] != '') { //If they leave the Event Start Date empty, the First Event Date in the recurrence module is selected $start_date = $_REQUEST['recurrence_start_date']; } elseif (isset($_POST['recurrence']) && $_POST['recurrence'] == 'Y' && $_REQUEST['start_date'] == '') { $start_date = $_REQUEST['recurrence_manual_dates'][0]; } else { $start_date = $_REQUEST['start_date']; } if (array_key_exists('recurrence_event_end_date', $recurrence_arr)) { //Recurring event $end_date = $recurrence_arr['recurrence_event_end_date']; } elseif ($_REQUEST['end_date'] == '' && $_REQUEST['recurrence_event_end_date'] != '') { //If they leave the Event Start Date empty, the First Event Date in the recurrence module is selected $end_date = $_REQUEST['recurrence_event_end_date']; } elseif (isset($_POST['recurrence']) && $_POST['recurrence'] == 'Y' && $_REQUEST['end_date'] == '') { $end_date = $_REQUEST['recurrence_manual_end_dates'][count($_REQUEST['recurrence_manual_end_dates']) - 1]; } else { $end_date = $_REQUEST['end_date']; } //$start_date = array_key_exists('recurrence_start_date', $recurrence_arr)?$recurrence_arr['recurrence_start_date']:($_REQUEST['start_date']==''?$_REQUEST['recurrence_start_date']:$_REQUEST['start_date']); //$end_date = array_key_exists('recurrence_start_date', $recurrence_arr)?$recurrence_arr['recurrence_start_date']:($_REQUEST['end_date']==''?$_REQUEST['recurrence_start_date']:$_REQUEST['end_date']); if (array_key_exists('visible_on', $recurrence_arr)) { //Recurring event $visible_on = $recurrence_arr['visible_on']; } elseif (isset($_REQUEST['visible_on']) && $_REQUEST['visible_on'] != '') { $visible_on = $_REQUEST['visible_on']; } elseif (isset($_REQUEST['visible_on']) && $_REQUEST['visible_on'] == '' && count($recurrence_dates) > 0) { $visible_on = $recurrence_dates[$start_date]['visible_on']; } else { $visible_on = date("Y-m-d"); } if ($reg_limit == '') { $reg_limit = 999; } $question_groups = empty($_REQUEST['question_groups']) ? '' : serialize($_REQUEST['question_groups']); $add_attendee_question_groups = empty($_REQUEST['add_attendee_question_groups']) ? '' : serialize($_REQUEST['add_attendee_question_groups']); $event_mata['venue_id'] = isset($_REQUEST['venue_id']) ? $_REQUEST['venue_id'][0] : ''; $event_mata['additional_attendee_reg_info'] = $_REQUEST['additional_attendee_reg_info']; $event_mata['add_attendee_question_groups'] = $add_attendee_question_groups; $event_mata['date_submitted'] = date("Y-m-d H:i:s"); $event_mata['default_payment_status'] = $_REQUEST['default_payment_status']; if ($_REQUEST['emeta'] != '') { foreach ($_REQUEST['emeta'] as $k => $v) { $event_mata[$v] = strlen(trim($_REQUEST['emetad'][$k])) > 0 ? $_REQUEST['emetad'][$k] : ''; } } //echo strlen(trim($_REQUEST['emetad'][$k])); //print_r($_REQUEST['emeta'] ); $event_mata = serialize($event_mata); ############ Added by wp-developers ###################### $require_pre_approval = 0; if (isset($_REQUEST['require_pre_approval'])) { $require_pre_approval = $_REQUEST['require_pre_approval']; } ################# END ################# //When adding colums to the following arrays, be sure both arrays have equal values. $sql = array('event_code' => $event_code, 'event_name' => $event_name, 'event_desc' => $event_desc, 'display_desc' => $display_desc, 'display_reg_form' => $display_reg_form, 'event_identifier' => $event_identifier, 'address' => $address, 'address2' => $address2, 'city' => $city, 'state' => $state, 'zip' => $zip, 'country' => $country, 'phone' => $phone, 'virtual_url' => $virtual_url, 'virtual_phone' => $virtual_phone, 'venue_title' => $venue_title, 'venue_url' => $venue_url, 'venue_phone' => $venue_phone, 'venue_image' => $venue_image, 'registration_start' => $registration_start, 'registration_end' => $registration_end, 'start_date' => $start_date, 'end_date' => $end_date, 'allow_multiple' => $allow_multiple, 'send_mail' => $send_mail, 'is_active' => $is_active, 'event_status' => $event_status, 'conf_mail' => $conf_mail, 'use_coupon_code' => $use_coupon_code, 'member_only' => $member_only, 'externalURL' => $externalURL, 'early_disc' => $early_disc, 'early_disc_date' => $early_disc_date, 'early_disc_percentage' => $early_disc_percentage, 'alt_email' => $alt_email, 'question_groups' => $question_groups, 'registration_startT' => $registration_startT, 'registration_endT' => $registration_endT, 'reg_limit' => $reg_limit, 'additional_limit' => $additional_limit, 'recurrence_id' => $recurrence_id, 'email_id' => $email_id, 'wp_user' => $current_user->ID, 'event_meta' => $event_mata, 'require_pre_approval' => $require_pre_approval, 'timezone_string' => $timezone_string, 'submitted' => date('Y-m-d H:i:s', time())); $sql_data = array('%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%d', '%d', '%d', '%d', '%d', '%s', '%s', '%s', '%s'); /* echo 'Debug: <br />'; print_r($sql); echo '<br />'; print 'Number of vars: ' . count ($sql); echo '<br />'; print 'Number of cols: ' . count($sql_data); */ //Add groupon reference if installed if (function_exists('event_espresso_add_event_to_db_groupon')) { $sql = event_espresso_add_event_to_db_groupon($sql, $_REQUEST['use_groupon_code']); //print count ($sql); $sql_data = array_merge((array) $sql_data, (array) '%s'); //print count($sql_data); if (!$wpdb->insert(EVENTS_DETAIL_TABLE, $sql, $sql_data)) { $error = true; } } else { if (!$wpdb->insert(EVENTS_DETAIL_TABLE, $sql, $sql_data)) { $error = true; } } $last_event_id = $wpdb->insert_id; ############# MailChimp Integration ############## if (get_option('event_mailchimp_active') == 'true' && $espresso_premium == true) { MailChimpController::add_event_list_rel($last_event_id); } if (function_exists('espresso_fb_createevent') == 'true' && $espresso_premium == true) { espresso_fb_createevent($last_event_id); } /* * Added for seating chart addon */ if (isset($_REQUEST['seating_chart_id'])) { $cls_seating_chart = new seating_chart(); $cls_seating_chart->associate_event_seating_chart($_REQUEST['seating_chart_id'], $last_event_id); } /* * End */ //Add event to a category if (isset($_REQUEST['event_category']) && $_REQUEST['event_category'] != '') { foreach ($_REQUEST['event_category'] as $k => $v) { if ($v != '') { $sql_cat = "INSERT INTO " . EVENTS_CATEGORY_REL_TABLE . " (event_id, cat_id) VALUES ('" . $last_event_id . "', '" . $v . "')"; //echo "$sql3 <br>"; if (!$wpdb->query($sql_cat)) { $error = true; } } } } if (!empty($_REQUEST['event_person'])) { foreach ($_REQUEST['event_person'] as $k => $v) { if ($v != '') { $sql_ppl = "INSERT INTO " . EVENTS_PERSONNEL_REL_TABLE . " (event_id, person_id) VALUES ('" . $last_event_id . "', '" . $v . "')"; //echo "$sql_ppl <br>"; $wpdb->query($sql_ppl); } } } if (!empty($_REQUEST['venue_id'])) { foreach ($_REQUEST['venue_id'] as $k => $v) { if ($v != '' && $v != 0) { $sql_venues = "INSERT INTO " . EVENTS_VENUE_REL_TABLE . " (event_id, venue_id) VALUES ('" . $last_event_id . "', '" . $v . "')"; //echo "$sql_venues <br>"; $wpdb->query($sql_venues); } } } if (!empty($_REQUEST['event_discount'])) { foreach ($_REQUEST['event_discount'] as $k => $v) { if ($v != '') { $sql_cat = "INSERT INTO " . EVENTS_DISCOUNT_REL_TABLE . " (event_id, discount_id) VALUES ('" . $last_event_id . "', '" . $v . "')"; //echo "$sql3 <br>"; if (!$wpdb->query($sql_cat)) { $error = true; } } } } if (!empty($_REQUEST['start_time'])) { foreach ($_REQUEST['start_time'] as $k => $v) { if ($v != '') { $time_qty = $_REQUEST['time_qty'][$k] == '' ? '0' : "'" . $_REQUEST['time_qty'][$k] . "'"; $sql3 = "INSERT INTO " . EVENTS_START_END_TABLE . " (event_id, start_time, end_time, reg_limit) VALUES ('" . $last_event_id . "', '" . event_date_display($v, 'H:i') . "', '" . event_date_display($_REQUEST['end_time'][$k], 'H:i') . "', " . $time_qty . ")"; //echo "$sql3 <br>"; if (!$wpdb->query($sql3)) { $error = true; } } } } if (!empty($_REQUEST['event_cost'])) { foreach ($_REQUEST['event_cost'] as $k => $v) { if ($v != '') { $price_type = $_REQUEST['price_type'][$k] != '' ? $_REQUEST['price_type'][$k] : __('General Admission', 'event_espresso'); $member_price_type = !empty($_REQUEST['member_price_type'][$k]) ? $_REQUEST['member_price_type'][$k] : __('Members Admission', 'event_espresso'); $member_price = !empty($_REQUEST['member_price'][$k]) ? $_REQUEST['member_price'][$k] : $v; $sql_price = "INSERT INTO " . EVENTS_PRICES_TABLE . " (event_id, event_cost, surcharge, surcharge_type, price_type, member_price, member_price_type) VALUES ('" . $last_event_id . "', '" . $v . "', '" . $_REQUEST['surcharge'][$k] . "', '" . $_REQUEST['surcharge_type'][$k] . "', '" . $price_type . "', '" . $member_price . "', '" . $member_price_type . "')"; //echo "$sql3 <br>"; if (!$wpdb->query($sql_price)) { $error = true; } } } } elseif ($_REQUEST['event_cost'][0] == 0) { $sql_price = "INSERT INTO " . EVENTS_PRICES_TABLE . " (event_id, event_cost, surcharge, price_type, member_price, member_price_type) VALUES ('" . $last_event_id . "', '0.00', '0.00', '" . __('Free', 'event_espresso') . "', '0.00', '" . __('Free', 'event_espresso') . "')"; if (!$wpdb->query($sql_price)) { $error = true; } } // Create Event Post Code Here if ($_REQUEST['create_post'] == 'Y') { $post_type = $_REQUEST['espresso_post_type']; if ($post_type == 'post') { if (file_exists(EVENT_ESPRESSO_TEMPLATE_DIR . "event_post.php") || file_exists(EVENT_ESPRESSO_PLUGINFULLPATH . "templates/event_post.php")) { // Load message from template into message post variable ob_start(); if (file_exists(EVENT_ESPRESSO_TEMPLATE_DIR . "event_post.php")) { require_once EVENT_ESPRESSO_TEMPLATE_DIR . "event_post.php"; } else { require_once EVENT_ESPRESSO_PLUGINFULLPATH . "templates/event_post.php"; } $post_content = ob_get_contents(); ob_end_clean(); } else { _e('There was error finding a post template. Please verify your post templates are available.', 'event_espresso'); } } elseif ($post_type == 'espresso_event') { ob_start(); echo $event_desc; $post_content = ob_get_contents(); ob_end_clean(); } $my_post = array(); $my_post['post_title'] = esc_html($_REQUEST['event']); $my_post['post_content'] = $post_content; $my_post['post_status'] = 'publish'; $my_post['post_author'] = $_REQUEST['user']; $my_post['post_category'] = $_REQUEST['post_category']; $my_post['tags_input'] = $_REQUEST['post_tags']; $my_post['post_type'] = $post_type; //print_r($my_post); // Insert the post into the database $post_id = wp_insert_post($my_post); // Store the POST ID so it can be displayed on the edit page $sql = array('post_id' => $post_id, 'post_type' => $post_type); add_post_meta($post_id, 'event_id', $last_event_id); add_post_meta($post_id, 'event_identifier', $event_identifier); add_post_meta($post_id, 'event_start_date', $_REQUEST['start_date']); add_post_meta($post_id, 'event_end_date', $_REQUEST['end_date']); add_post_meta($post_id, 'event_location', $event_location); add_post_meta($post_id, 'virtual_url', $virtual_url); add_post_meta($post_id, 'virtual_phone', $virtual_phone); add_post_meta($post_id, 'event_address', $address); add_post_meta($post_id, 'event_address2', $address2); add_post_meta($post_id, 'event_city', $city); add_post_meta($post_id, 'event_state', $state); add_post_meta($post_id, 'event_country', $country); add_post_meta($post_id, 'event_phone', $phone); add_post_meta($post_id, 'venue_title', $venue_title); add_post_meta($post_id, 'venue_url', $venue_url); add_post_meta($post_id, 'venue_phone', $venue_phone); add_post_meta($post_id, 'venue_image', $venue_image); add_post_meta($post_id, 'event_externalURL', $externalURL); add_post_meta($post_id, 'event_reg_limit', $reg_limit); add_post_meta($post_id, 'event_start_time', time_to_24hr($start_time)); add_post_meta($post_id, 'event_end_time', time_to_24hr($end_time)); add_post_meta($post_id, 'event_registration_start', $registration_start); add_post_meta($post_id, 'event_registration_end', $registration_end); add_post_meta($post_id, 'event_registration_startT', $registration_startT); add_post_meta($post_id, 'event_registration_endT', $registration_endT); //add_post_meta( $post_id, 'timezone_string', $_REQUEST['timezone_string'] ); $sql_data = array('%d', '%s'); $update_id = array('id' => $last_event_id); $wpdb->update(EVENTS_DETAIL_TABLE, $sql, $update_id, $sql_data, array('%d')); } if (empty($error)) { ?> <div id="message" class="updated fade"><p><strong><?php _e('The event', 'event_espresso'); ?> <a href="<?php echo espresso_reg_url($last_event_id); ?> " target="_blank"><?php echo stripslashes_deep($_REQUEST['event']); ?> </a> <?php _e('has been added for ', 'event_espresso'); echo date("m/d/Y", strtotime($start_date)); ?> <a href="admin.php?page=events&action=edit&event_id=<?php echo $last_event_id; ?> "><?php _e('Edit this event?', 'event_espresso'); ?> </a></strong></p></div> <?php } else { ?> <div id="message" class="error"><p><strong><?php _e('There was an error in your submission, please try again. The event was not saved!', 'event_espresso'); print $wpdb->print_error(); ?> .</strong></p></div> <?php } } /* * With the recursion of this function, additional recurring events will be added */ if (isset($recurrence_dates) && count($recurrence_dates) > 0) { foreach ($recurrence_dates as $k => $v) { add_event_to_db(array('recurrence_id' => $recurrence_id, 'recurrence_start_date' => $v['start_date'], 'recurrence_event_end_date' => $v['event_end_date'], 'registration_start' => $v['registration_start'], 'registration_end' => $v['registration_end'], 'visible_on' => $v['visible_on'])); } } /* * End recursion, as part of recurring events. */ return $last_event_id; }
function add_event_to_db($recurrence_arr = array()) { global $wpdb, $org_options, $current_user, $espresso_premium; //Security check using nonce if (empty($_POST['nonce_verify_insert_event']) || !wp_verify_nonce($_POST['nonce_verify_insert_event'], 'espresso_verify_insert_event_nonce')) { if (!isset($recurrence_arr['bypass_nonce'])) { print '<h3 class="error">' . __('Sorry, there was a security error and your event was not saved.', 'event_espresso') . '</h3>'; return; } } //Set FEM to false $use_fem = FALSE; $is_espresso_event_manager = false; //If using FEM if (isset($_REQUEST['ee_fem_action']) && $_REQUEST['ee_fem_action'] == 'ee_fem_add') { $use_fem = TRUE; if (function_exists('espresso_member_data') && espresso_member_data('role') == 'espresso_event_manager') { global $espresso_manager; $event_manager_approval = isset($espresso_manager['event_manager_approval']) && $espresso_manager['event_manager_approval'] == 'Y' ? true : false; $is_espresso_event_manager = TRUE; } } //Don't show sql errors if using the FEM if ($use_fem === FALSE) { $wpdb->show_errors(); } static $recurrence_id = null; if (defined('EVENT_ESPRESSO_RECURRENCE_TABLE')) { require_once EVENT_ESPRESSO_RECURRENCE_FULL_PATH . "functions/re_functions.php"; $recurrence_id = array_key_exists('recurrence_id', $recurrence_arr) ? $recurrence_arr['recurrence_id'] : Null; if ($_POST['recurrence'] == 'Y' && count($recurrence_arr) < 2) { if (is_null($recurrence_id)) { $recurrence_id = add_recurrence_master_record(); } $re_params = array('start_date' => $_POST['recurrence_type'] == 'a' ? sanitize_text_field($_POST['recurrence_start_date']) : sanitize_text_field($_POST['recurrence_manual_dates']), 'event_end_date' => $_POST['recurrence_type'] == 'a' ? sanitize_text_field($_POST['recurrence_event_end_date']) : sanitize_text_field($_POST['recurrence_manual_end_dates']), 'end_date' => $_POST['recurrence_type'] == 'a' ? sanitize_text_field($_POST['recurrence_end_date']) : sanitize_text_field($_POST['end_date']), 'registration_start' => sanitize_text_field($_POST['recurrence_regis_start_date']), 'registration_end' => sanitize_text_field($_POST['recurrence_regis_end_date']), 'frequency' => sanitize_text_field($_POST['recurrence_frequency']), 'interval' => sanitize_text_field($_POST['recurrence_interval']), 'type' => sanitize_text_field($_POST['recurrence_type']), 'weekdays' => isset($_POST['recurrence_weekday']) ? $_POST['recurrence_weekday'] : '', 'repeat_by' => $_POST['recurrence_repeat_by'], 'recurrence_regis_date_increment' => $_POST['recurrence_regis_date_increment'], 'recurrence_manual_dates' => $_POST['recurrence_manual_dates'], 'recurrence_manual_end_dates' => $_POST['recurrence_manual_end_dates'], 'recurrence_id' => $recurrence_id, 'adding_to_db' => 'Y'); $recurrence_dates = $_POST['recurrence_type'] == 'm' ? find_recurrence_manual_dates($re_params) : find_recurrence_dates($re_params); } } //echo_f('re array', $recurrence_dates); if (defined('EVENT_ESPRESSO_RECURRENCE_MODULE_ACTIVE') && $_POST['recurrence'] == 'Y' && count($recurrence_arr) == 0) { //skip the first insert because we do not have the start dates } else { $event_meta = array(); //will be used to hold event meta data //Filters the event description based on user level $user_access = apply_filters('filter_hook_espresso_event_unfiltered_description', current_user_can('administrator')); $_REQUEST['event_desc'] = is_admin() || $user_access ? $_REQUEST['event_desc'] : apply_filters('filter_hook_espresso_event_wp_kses_post_description', wp_kses_post($_REQUEST['event_desc'])); $event_code = uniqid($current_user->ID . '-'); $event_name = !empty($_REQUEST['event']) ? sanitize_text_field($_REQUEST['event']) : $event_code; if (!isset($_REQUEST['event_identifier']) || $_REQUEST['event_identifier'] == '') { $event_identifier = sanitize_title_with_dashes($event_name . '-' . $event_code); } else { $event_identifier = sanitize_title_with_dashes($_REQUEST['event_identifier']) . $event_code; } $event_desc = !empty($_REQUEST['event_desc']) ? $_REQUEST['event_desc'] : ''; $display_desc = !empty($_REQUEST['display_desc']) ? sanitize_text_field($_REQUEST['display_desc']) : 'Y'; $display_reg_form = !empty($_REQUEST['display_reg_form']) ? sanitize_text_field($_REQUEST['display_reg_form']) : 'Y'; $externalURL = isset($_REQUEST['externalURL']) ? sanitize_text_field($_REQUEST['externalURL']) : ''; $post_type = !empty($_REQUEST['espresso_post_type']) ? sanitize_text_field($_REQUEST['espresso_post_type']) : ''; $reg_limit = !empty($_REQUEST['reg_limit']) ? sanitize_text_field($_REQUEST['reg_limit']) : '999999'; $_REQUEST['reg_limit'] = $reg_limit; $allow_multiple = !empty($_REQUEST['allow_multiple']) ? sanitize_text_field($_REQUEST['allow_multiple']) : 'N'; $additional_limit = !empty($_REQUEST['additional_limit']) && $_REQUEST['additional_limit'] > 0 ? sanitize_text_field($_REQUEST['additional_limit']) : '5'; $_REQUEST['additional_limit'] = $additional_limit; $member_only = !empty($_REQUEST['member_only']) ? sanitize_text_field($_REQUEST['member_only']) : 'N'; $is_active = !empty($_REQUEST['is_active']) ? sanitize_text_field($_REQUEST['is_active']) : 'Y'; $event_status = !empty($_REQUEST['event_status']) ? sanitize_text_field($_REQUEST['event_status']) : 'A'; $use_coupon_code = !empty($_REQUEST['use_coupon_code']) ? sanitize_text_field($_REQUEST['use_coupon_code']) : 'N'; $ticket_id = empty($_REQUEST['ticket_id']) ? 0 : sanitize_text_field($_REQUEST['ticket_id']); //Get the first instance of the start and end times $start_time = !empty($_REQUEST['start_time'][0]) ? sanitize_text_field($_REQUEST['start_time'][0]) : '8:00 AM'; $_REQUEST['event_start_time'] = $start_time; $end_time = !empty($_REQUEST['end_time'][0]) ? sanitize_text_field($_REQUEST['end_time'][0]) : '5:00 PM'; $_REQUEST['event_end_time'] = $end_time; // Add Timezone $timezone_string = isset($_REQUEST['timezone_string']) ? sanitize_text_field($_REQUEST['timezone_string']) : ''; //Early discounts $early_disc = !empty($_REQUEST['early_disc']) ? sanitize_text_field($_REQUEST['early_disc']) : ''; $early_disc_date = !empty($_REQUEST['early_disc_date']) ? sanitize_text_field($_REQUEST['early_disc_date']) : ''; $early_disc_percentage = !empty($_REQUEST['early_disc_percentage']) ? sanitize_text_field($_REQUEST['early_disc_percentage']) : ''; //Alternate email address field $alt_email = !empty($_REQUEST['alt_email']) ? sanitize_text_field($_REQUEST['alt_email']) : ''; //Send a custom emal $send_mail = !empty($_REQUEST['send_mail']) ? sanitize_text_field($_REQUEST['send_mail']) : 'N'; //Custom email content $conf_mail = !empty($_REQUEST['conf_mail']) ? esc_html($_REQUEST['conf_mail']) : ''; //Use a premade custom email $email_id = isset($_REQUEST['email_name']) ? (int) $_REQUEST['email_name'] : '0'; //Venue Information $venue_title = isset($_REQUEST['venue_title']) ? sanitize_text_field($_REQUEST['venue_title']) : ''; $venue_url = isset($_REQUEST['venue_url']) ? sanitize_text_field($_REQUEST['venue_url']) : ''; $venue_phone = isset($_REQUEST['venue_phone']) ? sanitize_text_field($_REQUEST['venue_phone']) : ''; $venue_image = isset($_REQUEST['venue_image']) ? sanitize_text_field($_REQUEST['venue_image']) : ''; //Virtual location $virtual_url = !empty($_REQUEST['virtual_url']) ? sanitize_text_field($_REQUEST['virtual_url']) : ''; $virtual_phone = !empty($_REQUEST['virtual_phone']) ? sanitize_text_field($_REQUEST['virtual_phone']) : ''; //Address/venue information $address = isset($_REQUEST['address']) ? sanitize_text_field($_REQUEST['address']) : ''; $address2 = isset($_REQUEST['address2']) ? sanitize_text_field($_REQUEST['address2']) : ''; $city = isset($_REQUEST['city']) ? sanitize_text_field($_REQUEST['city']) : ''; $state = isset($_REQUEST['state']) ? sanitize_text_field($_REQUEST['state']) : ''; $zip = isset($_REQUEST['zip']) ? sanitize_text_field($_REQUEST['zip']) : ''; $country = isset($_REQUEST['country']) ? sanitize_text_field($_REQUEST['country']) : ''; $phone = isset($_REQUEST['phone']) ? sanitize_text_field($_REQUEST['phone']) : ''; $event_location = ''; if (!empty($address)) { $event_location .= $address . ' '; } if (!empty($address2)) { $event_location .= '<br />' . $address2; } if (!empty($city)) { $event_location .= '<br />' . $city; } if (!empty($state)) { $event_location .= ', ' . $state; } if (!empty($zip)) { $event_location .= ', ' . $state; } if (!empty($country)) { $event_location .= '<br />' . $country; } if ($is_espresso_event_manager == true && $use_fem == true && $event_manager_approval == true) { $event_status = 'P'; } //Get the registration start and end times $_REQUEST['registration_startT'] = !empty($_REQUEST['registration_startT']) ? sanitize_text_field($_REQUEST['registration_startT']) : '12:01 AM'; $_REQUEST['registration_endT'] = !empty($_REQUEST['registration_endT']) ? sanitize_text_field($_REQUEST['registration_endT']) : '11:59 PM'; // Add registration times $registration_startT = event_date_display($_REQUEST['registration_startT'], 'H:i'); $registration_endT = event_date_display($_REQUEST['registration_endT'], 'H:i'); $_REQUEST['registration_start'] = !empty($_REQUEST['registration_start']) ? sanitize_text_field($_REQUEST['registration_start']) : date('Y-m-d'); $_REQUEST['registration_end'] = !empty($_REQUEST['registration_end']) ? sanitize_text_field($_REQUEST['registration_end']) : date('Y-m-d', time() + 60 * 60 * 24 * 29); $registration_start = array_key_exists('registration_start', $recurrence_arr) ? $recurrence_arr['registration_start'] : $_REQUEST['registration_start']; $registration_end = array_key_exists('registration_end', $recurrence_arr) ? $recurrence_arr['registration_end'] : $_REQUEST['registration_end']; //Check which start/end date to use. Will be determined by recurring events addon, if installed. if (array_key_exists('recurrence_start_date', $recurrence_arr)) { //Recurring event $start_date = $recurrence_arr['recurrence_start_date']; } elseif (!empty($_REQUEST['start_date']) && !empty($_REQUEST['recurrence_start_date'])) { //If they leave the Event Start Date empty, the First Event Date in the recurrence module is selected $start_date = sanitize_text_field($_REQUEST['recurrence_start_date']); } elseif (isset($_POST['recurrence']) && $_POST['recurrence'] == 'Y' && !empty($_REQUEST['start_date'])) { $start_date = sanitize_text_field($_REQUEST['recurrence_manual_dates'][0]); } else { $start_date = !empty($_REQUEST['start_date']) ? sanitize_text_field($_REQUEST['start_date']) : date('Y-m-d', time() + 60 * 60 * 24 * 30); } $_REQUEST['start_date'] = $start_date; if (array_key_exists('recurrence_event_end_date', $recurrence_arr)) { //If this is a Recurring event $end_date = $recurrence_arr['recurrence_event_end_date']; } elseif (!empty($_REQUEST['end_date']) && !empty($_REQUEST['recurrence_event_end_date'])) { //If they leave the Event Start Date empty, the First Event Date in the recurrence module is selected $end_date = $_REQUEST['recurrence_event_end_date']; } elseif (isset($_POST['recurrence']) && $_POST['recurrence'] == 'Y' && !empty($_REQUEST['end_date'])) { $end_date = $_REQUEST['recurrence_manual_end_dates'][count($_REQUEST['recurrence_manual_end_dates']) - 1]; } else { $end_date = !empty($_REQUEST['end_date']) ? $_REQUEST['end_date'] : date('Y-m-d', time() + 60 * 60 * 24 * 30); } $_REQUEST['end_date'] = $end_date; if (array_key_exists('visible_on', $recurrence_arr)) { //If this is a Recurring event $visible_on = $recurrence_arr['visible_on']; } elseif (isset($_REQUEST['visible_on']) && $_REQUEST['visible_on'] != '') { $visible_on = $_REQUEST['visible_on']; } elseif (isset($_REQUEST['visible_on']) && $_REQUEST['visible_on'] == '' && count($recurrence_dates) > 0) { $visible_on = $recurrence_dates[$start_date]['visible_on']; } else { $visible_on = date("Y-m-d"); } //Questions/question groups $question_groups = empty($_REQUEST['question_groups']) ? serialize(array(1)) : serialize($_REQUEST['question_groups']); $add_attendee_question_groups = empty($_REQUEST['add_attendee_question_groups']) ? '' : $_REQUEST['add_attendee_question_groups']; //Process event meta data $event_meta['venue_id'] = isset($_REQUEST['venue_id']) ? $_REQUEST['venue_id'][0] : 0; $event_meta['additional_attendee_reg_info'] = !empty($_REQUEST['additional_attendee_reg_info']) ? sanitize_text_field($_REQUEST['additional_attendee_reg_info']) : '2'; $event_meta['add_attendee_question_groups'] = $add_attendee_question_groups; $event_meta['date_submitted'] = date("Y-m-d H:i:s"); $event_meta['default_payment_status'] = !empty($_REQUEST['default_payment_status']) ? sanitize_text_field($_REQUEST['default_payment_status']) : ''; //Process thumbnail uploads $event_thumbnail_url = ''; if (isset($_REQUEST['upload_image']) && !empty($_REQUEST['upload_image'])) { $event_meta['event_thumbnail_url'] = sanitize_text_field($_REQUEST['upload_image']); $event_thumbnail_url = sanitize_text_field($event_meta['event_thumbnail_url']); } if (isset($_REQUEST['emeta']) && !empty($_REQUEST['emeta'])) { foreach ($_REQUEST['emeta'] as $k => $v) { $event_meta[$v] = strlen(trim($_REQUEST['emetad'][$k])) > 0 ? sanitize_text_field($_REQUEST['emetad'][$k]) : ''; } } $event_meta = serialize($event_meta); //echo strlen(trim($_REQUEST['emetad'][$k])); //print_r($_REQUEST['emeta'] ); ############ Added by wp-developers ###################### $require_pre_approval = 0; if (isset($_REQUEST['require_pre_approval'])) { $require_pre_approval = sanitize_text_field($_REQUEST['require_pre_approval']); } ################# END ################# //When adding colums to the following arrays, be sure both arrays have equal values. $sql = array('event_code' => $event_code, 'event_name' => $event_name, 'event_desc' => $event_desc, 'display_desc' => $display_desc, 'display_reg_form' => $display_reg_form, 'event_identifier' => $event_identifier, 'address' => $address, 'address2' => $address2, 'city' => $city, 'state' => $state, 'zip' => $zip, 'country' => $country, 'phone' => $phone, 'virtual_url' => $virtual_url, 'virtual_phone' => $virtual_phone, 'venue_title' => $venue_title, 'venue_url' => $venue_url, 'venue_phone' => $venue_phone, 'venue_image' => $venue_image, 'registration_start' => $registration_start, 'registration_end' => $registration_end, 'start_date' => $start_date, 'end_date' => $end_date, 'allow_multiple' => $allow_multiple, 'send_mail' => $send_mail, 'is_active' => $is_active, 'event_status' => $event_status, 'conf_mail' => $conf_mail, 'use_coupon_code' => $use_coupon_code, 'member_only' => $member_only, 'externalURL' => $externalURL, 'early_disc' => $early_disc, 'early_disc_date' => $early_disc_date, 'early_disc_percentage' => $early_disc_percentage, 'alt_email' => $alt_email, 'question_groups' => $question_groups, 'registration_startT' => $registration_startT, 'registration_endT' => $registration_endT, 'reg_limit' => (int) $reg_limit, 'additional_limit' => (int) $additional_limit, 'recurrence_id' => $recurrence_id, 'email_id' => (int) $email_id, 'wp_user' => (int) $current_user->ID, 'event_meta' => $event_meta, 'require_pre_approval' => $require_pre_approval, 'timezone_string' => $timezone_string, 'submitted' => date('Y-m-d H:i:s', time()), 'ticket_id' => (int) $ticket_id); $sql_data = array('%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%d', '%d', '%d', '%d', '%d', '%s', '%s', '%s', '%s', '%d'); /* echo 'Debug: <br />'; print_r($sql); echo '<br />'; print 'Number of vars: ' . count ($sql); echo '<br />'; print 'Number of cols: ' . count($sql_data); */ //Add groupon reference if installed if (function_exists('event_espresso_add_event_to_db_groupon')) { $sql = event_espresso_add_event_to_db_groupon($sql, sanitize_text_field($_REQUEST['use_groupon_code'])); //print count ($sql); $sql_data = array_merge((array) $sql_data, (array) '%s'); //print count($sql_data); if (!$wpdb->insert(EVENTS_DETAIL_TABLE, $sql, $sql_data)) { $error = true; } } else { if (!$wpdb->insert(EVENTS_DETAIL_TABLE, $sql, $sql_data)) { $error = true; } } $last_event_id = $wpdb->insert_id; ############# MailChimp Integration ############## if (defined('EVENTS_MAILCHIMP_ATTENDEE_REL_TABLE') && $espresso_premium == true) { MailChimpController::add_event_list_rel($last_event_id); } if (function_exists('espresso_fb_createevent') == 'true' && $espresso_premium == true) { espresso_fb_createevent($last_event_id); } //Added for seating chart addon if (isset($_REQUEST['seating_chart_id'])) { $cls_seating_chart = new seating_chart(); $cls_seating_chart->associate_event_seating_chart($_REQUEST['seating_chart_id'], $last_event_id); } //Add event to a category $string_cat = ''; if (isset($_REQUEST['event_category']) && $_REQUEST['event_category'] != '') { foreach ($_REQUEST['event_category'] as $k => $v) { if ($v != '') { $sql_cat = "INSERT INTO " . EVENTS_CATEGORY_REL_TABLE . " (event_id, cat_id) VALUES ('" . $last_event_id . "', '" . (int) $v . "')"; if (!$wpdb->query($wpdb->prepare($sql_cat, NULL))) { $error = true; } //We get the category id's of the event and put them in events_detail_table.category_id as a well-formatted string (id,n id) $string_cat .= $v . ","; } } if ($string_cat != "" && $string_cat != ",") { $cleaned_string_cat = substr($string_cat, 0, -1); $tmp = explode(",", $cleaned_string_cat); sort($tmp); $cleaned_string_cat = implode(",", $tmp); trim($cleaned_string_cat); $sql_insert_event_detail_category_id = "UPDATE " . EVENTS_DETAIL_TABLE . " SET category_id = '" . $cleaned_string_cat . "' WHERE id='" . $last_event_id . "'"; $wpdb->query($wpdb->prepare($sql_insert_event_detail_category_id, NULL)); } } //Process staff assignments if (isset($_REQUEST['event_person']) && !empty($_REQUEST['event_person'])) { foreach ($_REQUEST['event_person'] as $k => $v) { if ($v != '') { $sql_ppl = "INSERT INTO " . EVENTS_PERSONNEL_REL_TABLE . " (event_id, person_id) VALUES ('" . $last_event_id . "', '" . $v . "')"; //echo "$sql_ppl <br>"; $wpdb->query($wpdb->prepare($sql_ppl, NULL)); } } } //Process dynamic adding of venues //If we are adding an venue from within the event editor. //Then we need to add it to the venue database and add the id to the event. if (isset($_REQUEST['add_new_venue_dynamic']) && $_REQUEST['add_new_venue_dynamic'] == 'true' && $_REQUEST['venue_id'][0] == '0') { require_once EVENT_ESPRESSO_INCLUDES_DIR . 'admin-files/venue-management/add_venue_to_db.php'; $_REQUEST['venue_id'][0] = add_venue_to_db(); } //Process venues if (isset($_REQUEST['venue_id']) && !empty($_REQUEST['venue_id'])) { foreach ($_REQUEST['venue_id'] as $k => $v) { if ($v != '' && $v != 0) { $sql_venues = "INSERT INTO " . EVENTS_VENUE_REL_TABLE . " (event_id, venue_id) VALUES ('" . $last_event_id . "', '" . $v . "')"; $wpdb->query($wpdb->prepare($sql_venues, NULL)); } } } //Process the discounts if (isset($_REQUEST['event_discount']) && !empty($_REQUEST['event_discount']) && $_REQUEST['use_coupon_code'] == 'Y') { //if they have specified to use specific coupon codes, THEN we add entries ot teh discount rel table //otherwise we shouldn't foreach ($_REQUEST['event_discount'] as $k => $v) { if ($v != '') { $sql_cat = "INSERT INTO " . EVENTS_DISCOUNT_REL_TABLE . " (event_id, discount_id) VALUES ('" . $last_event_id . "', '" . $v . "')"; if (!$wpdb->query($wpdb->prepare($sql_cat, NULL))) { $error = true; } } } } //Process event times if (isset($_REQUEST['start_time']) && !empty($_REQUEST['start_time'])) { foreach ($_REQUEST['start_time'] as $k => $v) { $time_qty = isset($_REQUEST['time_qty']) && strlen(trim($_REQUEST['time_qty'][$k])) > 0 ? "'" . $_REQUEST['time_qty'][$k] . "'" : '0'; $v = !empty($v) ? $v : $start_time; $_REQUEST['end_time'][$k] = !empty($_REQUEST['end_time'][$k]) ? $_REQUEST['end_time'][$k] : $end_time; $sql3 = "INSERT INTO " . EVENTS_START_END_TABLE . " (event_id, start_time, end_time, reg_limit) VALUES ('" . $last_event_id . "', '" . event_date_display($v, 'H:i') . "', '" . event_date_display($_REQUEST['end_time'][$k], 'H:i') . "', " . $time_qty . ")"; if (!$wpdb->query($wpdb->prepare($sql3, NULL))) { $error = true; } } } //Process event costs if (isset($_REQUEST['event_cost']) && !empty($_REQUEST['event_cost'])) { foreach ($_REQUEST['event_cost'] as $k => $v) { if ($v != '') { $v = (double) preg_replace('/[^0-9\\.]/ui', '', $v); //Removes non-integer characters $price_type = !empty($_REQUEST['price_type'][$k]) ? sanitize_text_field(stripslashes_deep($_REQUEST['price_type'][$k])) : __('General Admission', 'event_espresso'); $member_price_type = !empty($_REQUEST['member_price_type'][$k]) ? sanitize_text_field(stripslashes_deep($_REQUEST['member_price_type'][$k])) : __('Members Admission', 'event_espresso'); $member_price = !empty($_REQUEST['member_price'][$k]) ? $_REQUEST['member_price'][$k] : $v; //$sql_price = "INSERT INTO " . EVENTS_PRICES_TABLE . " (event_id, event_cost, surcharge, surcharge_type, price_type, member_price, member_price_type) VALUES ('" . $last_event_id . "', '" . $v . "', '" . $_REQUEST['surcharge'][$k] . "', '" . $_REQUEST['surcharge_type'][$k] . "', '" . $price_type . "', '" . $member_price . "', '" . $member_price_type . "')"; //echo "$sql3 <br>"; $sql_price = array('event_id' => $last_event_id, 'event_cost' => $v, 'surcharge' => $_REQUEST['surcharge'][$k], 'surcharge_type' => $_REQUEST['surcharge_type'][$k], 'price_type' => $price_type, 'member_price' => $member_price, 'member_price_type' => $member_price_type); $sql_price_data = array('%d', '%s', '%s', '%s', '%s', '%s', '%s'); if (!$wpdb->insert(EVENTS_PRICES_TABLE, $sql_price, $sql_price_data)) { $error = true; } } } } elseif (isset($_REQUEST['event_cost']) && $_REQUEST['event_cost'][0] == 0) { $sql_price = "INSERT INTO " . EVENTS_PRICES_TABLE . " (event_id, event_cost, surcharge, price_type, member_price, member_price_type) VALUES ('" . $last_event_id . "', '0.00', '0.00', '" . __('Free', 'event_espresso') . "', '0.00', '" . __('Free', 'event_espresso') . "')"; if (!$wpdb->query($wpdb->prepare($sql_price, NULL))) { $error = true; } } //Process blog or custom post if (isset($_REQUEST['create_post']) && $_REQUEST['create_post'] == 'Y') { $post_type = !empty($_REQUEST['espresso_post_type']) ? $_REQUEST['espresso_post_type'] : 'post'; if ($post_type == 'post') { if (file_exists(EVENT_ESPRESSO_TEMPLATE_DIR . "event_post.php") || file_exists(EVENT_ESPRESSO_PLUGINFULLPATH . "templates/event_post.php")) { // Load message from template into message post variable ob_start(); if (file_exists(EVENT_ESPRESSO_TEMPLATE_DIR . "event_post.php")) { require_once EVENT_ESPRESSO_TEMPLATE_DIR . "event_post.php"; } else { require_once EVENT_ESPRESSO_PLUGINFULLPATH . "templates/event_post.php"; } $post_content = ob_get_contents(); ob_end_clean(); } else { _e('There was error finding a post template. Please verify your post templates are available.', 'event_espresso'); } } elseif ($post_type == 'espresso_event') { ob_start(); echo $event_desc; $post_content = ob_get_contents(); ob_end_clean(); // if there's a cart link shortcode in the post, replace the shortcode with one that includes the event_id if (preg_match("/ESPRESSO_CART_LINK/", $post_content)) { $post_content = preg_replace('/ESPRESSO_CART_LINK/', 'ESPRESSO_CART_LINK event_id=' . $event_id, $post_content); } } $my_post = array(); $my_post['post_title'] = sanitize_text_field($_REQUEST['event']); $my_post['post_content'] = $post_content; $my_post['post_status'] = 'publish'; $my_post['post_author'] = !empty($_REQUEST['user']) ? $_REQUEST['user'] : ''; $my_post['post_category'] = !empty($_REQUEST['post_category']) ? $_REQUEST['post_category'] : ''; $my_post['tags_input'] = !empty($_REQUEST['post_tags']) ? $_REQUEST['post_tags'] : ''; $my_post['post_type'] = !empty($post_type) ? $post_type : 'post'; //print_r($my_post); // Insert the post into the database $post_id = wp_insert_post($my_post); // Store the POST ID so it can be displayed on the edit page $sql = array('post_id' => $post_id, 'post_type' => $post_type); add_post_meta($post_id, 'event_id', $last_event_id); add_post_meta($post_id, 'event_meta', $event_meta); add_post_meta($post_id, 'event_identifier', $event_identifier); add_post_meta($post_id, 'event_start_date', $start_date); add_post_meta($post_id, 'event_end_date', $end_date); add_post_meta($post_id, 'event_location', $event_location); add_post_meta($post_id, 'event_thumbnail_url', $event_thumbnail_url); add_post_meta($post_id, 'virtual_url', $virtual_url); add_post_meta($post_id, 'virtual_phone', $virtual_phone); add_post_meta($post_id, 'event_address', $address); add_post_meta($post_id, 'event_address2', $address2); add_post_meta($post_id, 'event_city', $city); add_post_meta($post_id, 'event_state', $state); add_post_meta($post_id, 'event_country', $country); add_post_meta($post_id, 'event_phone', $phone); add_post_meta($post_id, 'venue_title', $venue_title); add_post_meta($post_id, 'venue_url', $venue_url); add_post_meta($post_id, 'venue_phone', $venue_phone); add_post_meta($post_id, 'venue_image', $venue_image); add_post_meta($post_id, 'event_externalURL', $externalURL); add_post_meta($post_id, 'event_reg_limit', $reg_limit); add_post_meta($post_id, 'event_start_time', time_to_24hr($start_time)); add_post_meta($post_id, 'event_end_time', time_to_24hr($end_time)); add_post_meta($post_id, 'event_registration_start', $registration_start); add_post_meta($post_id, 'event_registration_end', $registration_end); add_post_meta($post_id, 'event_registration_startT', $registration_startT); add_post_meta($post_id, 'event_registration_endT', $registration_endT); //add_post_meta( $post_id, 'timezone_string', $_REQUEST['timezone_string'] ); $sql_data = array('%d', '%s'); $update_id = array('id' => $last_event_id); $wpdb->update(EVENTS_DETAIL_TABLE, $sql, $update_id, $sql_data, array('%d')); } if (empty($error)) { ?> <div id="message" class="updated fade"><p><strong><?php _e('The event', 'event_espresso'); ?> <a href="<?php echo espresso_reg_url($last_event_id); ?> " target="_blank"> <?php echo htmlentities(stripslashes(sanitize_text_field($_REQUEST['event'])), ENT_QUOTES, 'UTF-8'); ?> </a> <?php _e('has been added for ', 'event_espresso'); echo date("m/d/Y", strtotime($start_date)); ?> <a href="<?php echo admin_url(); ?> admin.php?page=events&action=edit&event_id=<?php echo $last_event_id; ?> "><?php _e('Edit this event?', 'event_espresso'); ?> </a></strong></p></div> <?php } else { ?> <div id="message" class="error"><p><strong><?php _e('There was an error in your submission. The event was not saved! Please try again.', 'event_espresso'); ?> <?php print $wpdb->print_error(); ?> </strong></p></div> <?php } } //With the recursion of this function, additional recurring events will be added if (isset($recurrence_dates) && count($recurrence_dates) > 0) { foreach ($recurrence_dates as $k => $v) { add_event_to_db(array('recurrence_id' => $recurrence_id, 'recurrence_start_date' => $v['start_date'], 'recurrence_event_end_date' => $v['event_end_date'], 'registration_start' => $v['registration_start'], 'registration_end' => $v['registration_end'])); } } $_REQUEST['event_id'] = !empty($last_event_id) ? $last_event_id : ''; do_action('action_hook_espresso_insert_event_success', $_REQUEST); //If not using the FEM addon, then we return the event id if (!$use_fem === TRUE) { return @$last_event_id; } }
function update_event($recurrence_arr = array()) { //print_r($_REQUEST); global $wpdb, $org_options, $current_user, $espresso_premium; $wpdb->show_errors(); /* * Begin Recurrence handling * * Will clean up in V 1.2.0 * */ if (get_option('event_espresso_re_active') == 1) { require_once EVENT_ESPRESSO_RECURRENCE_FULL_PATH . "functions/re_functions.php"; if ($_POST['recurrence_id'] > 0) { /* * If the array is empty, then find the recurring dates */ if (count($recurrence_arr) == 0) { // Prepare the parameters array for use with various RE functions $re_params = array('start_date' => $_POST['recurrence_start_date'], 'event_end_date' => $_POST['recurrence_event_end_date'], 'end_date' => $_POST['recurrence_end_date'], 'registration_start' => $_POST['recurrence_regis_start_date'], 'registration_end' => $_POST['recurrence_regis_end_date'], 'frequency' => $_POST['recurrence_frequency'], 'interval' => $_POST['recurrence_interval'], 'recurrence_type' => $_POST['recurrence_type'], 'weekdays' => $_POST['recurrence_weekday'], 'repeat_by' => $_POST['recurrence_repeat_by'], 'recurrence_regis_date_increment' => $_POST['recurrence_regis_date_increment'], 'recurrence_manual_dates' => $_POST['recurrence_manual_dates'], 'recurrence_manual_end_dates' => $_POST['recurrence_manual_end_dates'], 'recurrence_visibility' => $_POST['recurrence_visibility'], 'recurrence_id' => $_POST['recurrence_id']); //$re_params['adding_to_db'] = 'Y'; //Has the form been modified $recurrence_form_modified = recurrence_form_modified($re_params); //echo ($recurrence_form_modified) ? "Yes" : 'No'; if ($_POST['recurrence_apply_changes_to'] == 2) { //Update all events in the series based on recurrence id $recurrence_dates = $_POST['recurrence_type'] == 'm' ? find_recurrence_manual_dates($re_params) : find_recurrence_dates($re_params); //$DEL_SQL = 'UPDATE ' . EVENTS_DETAIL_TABLE . " SET event_status = 'D' WHERE start_date NOT IN (" . $delete_in . ") AND recurrence_id = " . $wpdb->escape($_POST['recurrence_id']); $UPDATE_SQL = "SELECT id,start_date,event_identifier FROM " . EVENTS_DETAIL_TABLE . " WHERE recurrence_id = %d AND NOT event_status = 'D'"; } else { //Update this and upcoming events based on recurrence id and start_date >=start_date $re_params['start_date'] = $_POST['start_date']; $recurrence_dates = find_recurrence_dates($re_params); //$DEL_SQL = 'UPDATE ' . EVENTS_DETAIL_TABLE . " SET event_status = 'D' WHERE start_date >='" . $wpdb->escape($_POST['start_date']) . "' AND start_date NOT IN (" . $delete_in . ") AND recurrence_id = " . $_POST['recurrence_id']; $UPDATE_SQL = "SELECT id,start_date,event_identifier FROM " . EVENTS_DETAIL_TABLE . " WHERE start_date >='" . $wpdb->escape($_POST['start_date']) . "' AND recurrence_id = %d and NOT event_status = 'D' "; } //Recurrence Form modified and changes need to apply to all if ($recurrence_form_modified && $_POST['recurrence_apply_changes_to'] > 1) { //Update the recurrence table record with the new RE selections update_recurrence_master_record(); /* * Delete the records that don't belong in the formula */ if (count($recurrence_dates) > 0) { $delete_in = ''; foreach ($recurrence_dates as $k => $v) { $delete_in .= "'" . $k . "',"; } $delete_in = substr($delete_in, 0, -1); } if ($_POST['recurrence_apply_changes_to'] == 2) { //Update all events in the series based on recurrence id //$DEL_SQL = 'UPDATE ' . EVENTS_DETAIL_TABLE . " SET event_status = 'D' WHERE start_date NOT IN (" . $delete_in . ") AND recurrence_id = " . $_POST['recurrence_id']; $DEL_SQL = 'DELETE EDT, EAT FROM ' . EVENTS_DETAIL_TABLE . " EDT\n LEFT JOIN " . EVENTS_ATTENDEE_TABLE . " EAT\n ON EDT.id = EAT.event_id\n WHERE EAT.id IS NULL\n AND EDT.start_date NOT IN (" . $delete_in . ")\n AND recurrence_id = " . $_POST['recurrence_id']; $UPDATE_SQL = "SELECT id,start_date,event_identifier FROM " . EVENTS_DETAIL_TABLE . " WHERE recurrence_id = %d and NOT event_status = 'D' ORDER BY start_date"; } else { //Update this and upcoming events based on recurrence id and start_date >=start_date //$DEL_SQL = 'UPDATE ' . EVENTS_DETAIL_TABLE . " SET event_status = 'D' WHERE start_date >='" . $wpdb->escape($_POST['start_date']) . "' AND start_date NOT IN (" . $delete_in . ") AND recurrence_id = " . $_POST['recurrence_id']; $DEL_SQL = 'DELETE EDT, EAT FROM ' . EVENTS_DETAIL_TABLE . " EDT\n LEFT JOIN " . EVENTS_ATTENDEE_TABLE . " EAT\n ON EDT.id = EAT.event_id\n WHERE EAT.id IS NULL\n AND EDT.start_date >='" . $wpdb->escape($_POST['start_date']) . "'\n AND start_date NOT IN (" . $delete_in . ")\n AND recurrence_id = " . $_POST['recurrence_id']; $UPDATE_SQL = "SELECT id,start_date,event_identifier FROM " . EVENTS_DETAIL_TABLE . " WHERE start_date >='" . $wpdb->escape($_POST['start_date']) . "' AND recurrence_id = %d AND NOT event_status = 'D' ORDER BY start_date"; } if ($delete_in != '') { $wpdb->query($DEL_SQL); } /* * Add the new records based on the new formula * The $recurrence_dates array will contain the new dates */ if (!function_exists('add_event_to_db')) { require_once 'insert_event.php'; } foreach ($recurrence_dates as $k => $v) { $result = $wpdb->get_row($wpdb->prepare("SELECT ID FROM " . EVENTS_DETAIL_TABLE . " WHERE recurrence_id = %d and start_date = %s and NOT event_status = 'D'", array($_POST['recurrence_id'], $k))); if ($wpdb->num_rows == 0) { add_event_to_db(array('recurrence_id' => $_POST['recurrence_id'], 'recurrence_start_date' => $v['start_date'], 'recurrence_event_end_date' => $v['end_date'], 'recurrence_end_date' => $v['start_date'], 'registration_start' => $v['registration_start'], 'registration_end' => $v['registration_end'])); } else { } } /* * Find all the event ids in the series and feed into the $recurrence_dates array * This array will be used at the end of this document to invoke the recursion of update_event function so all the events in the series * can be updated with the information. */ } $result = $wpdb->get_results($wpdb->prepare($UPDATE_SQL, array($_POST['recurrence_id']))); foreach ($result as $row) { if ($row->start_date != '') { $recurrence_dates[$row->start_date]['event_id'] = $row->id; $recurrence_dates[$row->start_date]['event_identifier'] = $row->event_identifier; } } } } } // echo_f('rd',$recurrence_dates); if (defined('EVENT_ESPRESSO_RECURRENCE_MODULE_ACTIVE') && !empty($_POST['recurrence']) && $_POST['recurrence'] == 'Y' && count($recurrence_arr) == 0 && $_POST['recurrence_apply_changes_to'] > 1) { //skip the first update } else { $event_mata = array(); //will be used to hold event meta data $event_id = array_key_exists('event_id', $recurrence_arr) ? $recurrence_arr['event_id'] : $_REQUEST['event_id']; $event_name = $_REQUEST['event']; //$event_identifier=array_key_exists('event_identifier', $recurrence_arr)?$recurrence_arr['event_identifier']:($_REQUEST['event_identifier'] == '') ? $event_identifier = sanitize_title_with_dashes($event_name.'-'.rand()) : $event_identifier = sanitize_title_with_dashes($_REQUEST['event_identifier']); $event_desc = $_REQUEST['event_desc']; $display_desc = $_REQUEST['display_desc']; $display_reg_form = $_REQUEST['display_reg_form']; $reg_limit = $_REQUEST['reg_limit']; $allow_multiple = $_REQUEST['allow_multiple']; $overflow_event_id = empty($_REQUEST['overflow_event_id']) ? '0' : $_REQUEST['overflow_event_id']; $allow_overflow = empty($_REQUEST['allow_overflow']) ? 'N' : $_REQUEST['allow_overflow']; $additional_limit = $_REQUEST['additional_limit']; //$member_only=$_REQUEST['member_only']; $member_only = empty($_REQUEST['member_only']) ? 'N' : $_REQUEST['member_only']; $is_active = $_REQUEST['is_active']; $event_status = $_REQUEST['event_status']; $address = !empty($_REQUEST['address']) ? esc_html($_REQUEST['address']) : ''; $address2 = !empty($_REQUEST['address2']) ? esc_html($_REQUEST['address2']) : ''; $city = !empty($_REQUEST['city']) ? esc_html($_REQUEST['city']) : ''; $state = !empty($_REQUEST['state']) ? esc_html($_REQUEST['state']) : ''; $zip = !empty($_REQUEST['zip']) ? esc_html($_REQUEST['zip']) : ''; $country = !empty($_REQUEST['country']) ? esc_html($_REQUEST['country']) : ''; $phone = !empty($_REQUEST['phone']) ? esc_html($_REQUEST['phone']) : ''; $externalURL = !empty($_REQUEST['externalURL']) ? esc_html($_REQUEST['externalURL']) : ''; //$event_location = $address . ' ' . $city . ', ' . $state . ' ' . $zip; $event_location = ($address != '' ? $address . ' ' : '') . ($city != '' ? '<br />' . $city : '') . ($state != '' ? ', ' . $state : '') . ($zip != '' ? '<br />' . $zip : '') . ($country != '' ? '<br />' . $country : ''); //Get the first instance of the start and end times $start_time = $_REQUEST['start_time'][0]; $end_time = $_REQUEST['end_time'][0]; // Add registration times $registration_startT = event_date_display($_REQUEST['registration_startT'], 'H:i'); $registration_endT = event_date_display($_REQUEST['registration_endT'], 'H:i'); //Add timezone $timezone_string = empty($_REQUEST['timezone_string']) ? '' : $_REQUEST['timezone_string']; //Early discounts $early_disc = $_REQUEST['early_disc']; $early_disc_date = $_REQUEST['early_disc_date']; $early_disc_percentage = $_REQUEST['early_disc_percentage']; $conf_mail = $_REQUEST['conf_mail']; $use_coupon_code = $_REQUEST['use_coupon_code']; $alt_email = $_REQUEST['alt_email']; $send_mail = $_REQUEST['send_mail']; $email_id = empty($_REQUEST['email_name']) ? '' : $_REQUEST['email_name']; $event_category = serialize(empty($_REQUEST['event_category']) ? '' : $_REQUEST['event_category']); $event_discount = serialize(empty($_REQUEST['event_discount']) ? '' : $_REQUEST['event_discount']); $registration_start = array_key_exists('registration_start', $recurrence_arr) ? $recurrence_arr['registration_start'] : $_REQUEST['registration_start']; $registration_end = array_key_exists('registration_end', $recurrence_arr) ? $recurrence_arr['registration_end'] : $_REQUEST['registration_end']; $start_date = array_key_exists('recurrence_start_date', $recurrence_arr) ? $recurrence_arr['recurrence_start_date'] : ($_REQUEST['start_date'] == '' ? $_REQUEST['recurrence_start_date'] : $_REQUEST['start_date']); $end_date = array_key_exists('recurrence_event_end_date', $recurrence_arr) ? $recurrence_arr['recurrence_event_end_date'] : ($_REQUEST['end_date'] == '' ? $_REQUEST['recurrence_start_date'] : $_REQUEST['end_date']); $visible_on = array_key_exists('visible_on', $recurrence_arr) ? $recurrence_arr['visible_on'] : empty($_REQUEST['visible_on']) ? '' : $_REQUEST['visible_on']; //Venue Information $venue_title = isset($_REQUEST['venue_title']) ? $_REQUEST['venue_title'] : ''; $venue_url = isset($_REQUEST['venue_url']) ? $_REQUEST['venue_url'] : ''; $venue_phone = isset($_REQUEST['venue_phone']) ? $_REQUEST['venue_phone'] : ''; $venue_image = isset($_REQUEST['venue_image']) ? $_REQUEST['venue_image'] : ''; //Virtual location $virtual_url = isset($_REQUEST['virtual_url']) ? $_REQUEST['virtual_url'] : ''; $virtual_phone = isset($_REQUEST['virtual_phone']) ? $_REQUEST['virtual_phone'] : ''; if (isset($reg_limit) && $reg_limit == '') { $reg_limit = 999999; } $question_groups = serialize($_REQUEST['question_groups']); $add_attendee_question_groups = serialize(empty($_REQUEST['add_attendee_question_groups']) ? '' : $_REQUEST['add_attendee_question_groups']); $event_mata['default_payment_status'] = $_REQUEST['default_payment_status']; $event_mata['venue_id'] = empty($_REQUEST['venue_id']) ? '' : $_REQUEST['venue_id'][0]; $event_mata['additional_attendee_reg_info'] = $_REQUEST['additional_attendee_reg_info']; $event_mata['add_attendee_question_groups'] = empty($_REQUEST['add_attendee_question_groups']) ? '' : $_REQUEST['add_attendee_question_groups']; $event_mata['date_submitted'] = $_REQUEST['date_submitted']; /* * Added for seating chart addon */ if (isset($_REQUEST['seating_chart_id'])) { $cls_seating_chart = new seating_chart(); $seating_chart_result = $cls_seating_chart->associate_event_seating_chart($_REQUEST['seating_chart_id'], $event_id); $tmp_seating_chart_id = $_REQUEST['seating_chart_id']; if ($tmp_seating_chart_id > 0) { if ($seating_chart_result === false) { $tmp_seating_chart_row = $wpdb->get_row("select seating_chart_id from " . EVENTS_SEATING_CHART_EVENT_TABLE . " where event_id = {$event_id}"); if ($tmp_seating_chart_row !== NULL) { $tmp_seating_chart_id = $tmp_seating_chart_row->seating_chart_id; } else { $tmp_seating_chart_id = 0; } } if ($_REQUEST['allow_multiple'] == 'Y' && isset($_REQUEST['seating_chart_id']) && $tmp_seating_chart_id > 0) { $event_mata['additional_attendee_reg_info'] = 3; } } } /* * End */ if ($_REQUEST['emeta'] != '') { foreach ($_REQUEST['emeta'] as $k => $v) { $event_mata[$v] = $_REQUEST['emetad'][$k]; } } $event_mata = serialize($event_mata); ############ Added by wp-developers ###################### $require_pre_approval = 0; if (isset($_REQUEST['require_pre_approval'])) { $require_pre_approval = $_REQUEST['require_pre_approval']; } ################# END ################# //When adding colums to the following arrays, be sure both arrays have equal values. $sql = array('event_name' => $event_name, 'event_desc' => $event_desc, 'display_desc' => $display_desc, 'display_reg_form' => $display_reg_form, 'address' => $address, 'address2' => $address2, 'city' => $city, 'state' => $state, 'zip' => $zip, 'country' => $country, 'phone' => $phone, 'virtual_url' => $virtual_url, 'virtual_phone' => $virtual_phone, 'venue_title' => $venue_title, 'venue_url' => $venue_url, 'venue_phone' => $venue_phone, 'venue_image' => $venue_image, 'registration_start' => $registration_start, 'registration_end' => $registration_end, 'start_date' => $start_date, 'end_date' => $end_date, 'allow_multiple' => $allow_multiple, 'send_mail' => $send_mail, 'is_active' => $is_active, 'event_status' => $event_status, 'conf_mail' => $conf_mail, 'use_coupon_code' => $use_coupon_code, 'member_only' => $member_only, 'externalURL' => $externalURL, 'early_disc' => $early_disc, 'early_disc_date' => $early_disc_date, 'early_disc_percentage' => $early_disc_percentage, 'alt_email' => $alt_email, 'question_groups' => $question_groups, 'allow_overflow' => $allow_overflow, 'overflow_event_id' => $overflow_event_id, 'additional_limit' => $additional_limit, 'reg_limit' => $reg_limit, 'email_id' => $email_id, 'registration_startT' => $registration_startT, 'registration_endT' => $registration_endT, 'event_meta' => $event_mata, 'require_pre_approval' => $require_pre_approval, 'timezone_string' => $timezone_string); $sql_data = array('%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%d', '%d', '%d', '%d', '%s', '%s', '%s', '%s', '%s'); $update_id = array('id' => $event_id); /* echo 'Debug: <br />'; print_r($sql); echo '<br />'; print 'Number of vars: ' . count ($sql); echo '<br />'; print 'Number of cols: ' . count($sql_data); */ if (function_exists('event_espresso_add_event_to_db_groupon')) { $sql = event_espresso_add_event_to_db_groupon($sql, $_REQUEST['use_groupon_code']); ///print count ($sql); $sql_data = array_merge((array) $sql_data, (array) '%s'); //print count($sql_data); $wpdb->update(EVENTS_DETAIL_TABLE, $sql, $update_id, $sql_data, array('%d')); /* echo 'Debug: <br />'; print 'Number of vars: ' . count ($sql); echo '<br />'; print 'Number of cols: ' . count($sql_data); */ } else { $wpdb->update(EVENTS_DETAIL_TABLE, $sql, $update_id, $sql_data, array('%d')); /* echo 'Debug: <br />'; print 'Number of vars: ' . count ($sql); echo '<br />'; print 'Number of cols: ' . count($sql_data); */ } //print $wpdb->print_error(); $del_cats = "DELETE FROM " . EVENTS_CATEGORY_REL_TABLE . " WHERE event_id = '" . $event_id . "'"; $wpdb->query($del_cats); if (!empty($_REQUEST['event_category'])) { foreach ($_REQUEST['event_category'] as $k => $v) { if ($v != '') { $sql_cat = "INSERT INTO " . EVENTS_CATEGORY_REL_TABLE . " (event_id, cat_id) VALUES ('" . $event_id . "', '" . $v . "')"; //echo "$sql_cat <br>"; $wpdb->query($sql_cat); } } } $del_ppl = "DELETE FROM " . EVENTS_PERSONNEL_REL_TABLE . " WHERE event_id = '" . $event_id . "'"; $wpdb->query($del_ppl); if (!empty($_REQUEST['event_person'])) { foreach ($_REQUEST['event_person'] as $k => $v) { if ($v != '') { $sql_ppl = "INSERT INTO " . EVENTS_PERSONNEL_REL_TABLE . " (event_id, person_id) VALUES ('" . $event_id . "', '" . $v . "')"; //echo "$sql_ppl <br>"; $wpdb->query($sql_ppl); } } } $del_venues = "DELETE FROM " . EVENTS_VENUE_REL_TABLE . " WHERE event_id = '" . $event_id . "'"; $wpdb->query($del_venues); if (!empty($_REQUEST['venue_id'])) { foreach ($_REQUEST['venue_id'] as $k => $v) { if ($v != '' && $v != 0) { $sql_venues = "INSERT INTO " . EVENTS_VENUE_REL_TABLE . " (event_id, venue_id) VALUES ('" . $event_id . "', '" . $v . "')"; //echo "$sql_venues <br>"; $wpdb->query($sql_venues); } } } $del_discounts = "DELETE FROM " . EVENTS_DISCOUNT_REL_TABLE . " WHERE event_id = '" . $event_id . "'"; $wpdb->query($del_discounts); if (!empty($_REQUEST['event_discount'])) { foreach ($_REQUEST['event_discount'] as $k => $v) { if ($v != '') { $sql_discount = "INSERT INTO " . EVENTS_DISCOUNT_REL_TABLE . " (event_id, discount_id) VALUES ('" . $event_id . "', '" . $v . "')"; //echo "$sql_discount <br>"; $wpdb->query($sql_discount); } } } $del_times = "DELETE FROM " . EVENTS_START_END_TABLE . " WHERE event_id = '" . $event_id . "'"; $wpdb->query($del_times); if ($_REQUEST['start_time'] != '') { foreach ($_REQUEST['start_time'] as $k => $v) { if ($v != '') { $time_qty = empty($_REQUEST['time_qty'][$k]) ? '0' : "'" . $_REQUEST['time_qty'][$k] . "'"; $sql_times = "INSERT INTO " . EVENTS_START_END_TABLE . " (event_id, start_time, end_time, reg_limit) VALUES ('" . $event_id . "', '" . event_date_display($v, 'H:i') . "', '" . event_date_display($_REQUEST['end_time'][$k], 'H:i') . "', " . $time_qty . ")"; //echo "$sql_times <br>"; $wpdb->query($sql_times); } } } $del_prices = "DELETE FROM " . EVENTS_PRICES_TABLE . " WHERE event_id = '" . $event_id . "'"; $wpdb->query($del_prices); if (!empty($_REQUEST['event_cost'])) { foreach ($_REQUEST['event_cost'] as $k => $v) { if ($v != '') { $price_type = $_REQUEST['price_type'][$k] != '' ? $_REQUEST['price_type'][$k] : __('General Admission', 'event_espresso'); $member_price_type = !empty($_REQUEST['member_price_type'][$k]) ? $_REQUEST['member_price_type'][$k] : __('Members Admission', 'event_espresso'); $member_price = !empty($_REQUEST['member_price'][$k]) ? $_REQUEST['member_price'][$k] : $v; $sql_prices = "INSERT INTO " . EVENTS_PRICES_TABLE . " (event_id, event_cost, surcharge, surcharge_type, price_type, member_price, member_price_type) VALUES ('" . $event_id . "', '" . $v . "', '" . $_REQUEST['surcharge'][$k] . "', '" . $_REQUEST['surcharge_type'][$k] . "', '" . $price_type . "', '" . $member_price . "', '" . $member_price_type . "')"; //echo "$sql_prices <br>"; $wpdb->query($sql_prices); } } } else { $sql_price = "INSERT INTO " . EVENTS_PRICES_TABLE . " (event_id, event_cost, surcharge, price_type, member_price, member_price_type) VALUES ('" . $event_id . "', '0.00', '0.00', '" . __('Free', 'event_espresso') . "', '0.00', '" . __('Free', 'event_espresso') . "')"; if (!$wpdb->query($sql_price)) { $error = true; } } ############# MailChimp Integration ############### if (get_option('event_mailchimp_active') == 'true' && $espresso_premium == true) { MailChimpController::update_event_list_rel($event_id); } if (function_exists('espresso_fb_createevent') == 'true' && $espresso_premium == true) { espresso_fb_updateevent($event_id); } /// Create Event Post Code Here switch ($_REQUEST['create_post']) { case $_REQUEST['create_post'] == 'N': $sql = " SELECT * FROM " . EVENTS_DETAIL_TABLE; $sql .= " WHERE id = '" . $event_id . "' "; $wpdb->get_results($sql); $post_id = $wpdb->last_result[0]->post_id; if ($wpdb->num_rows > 0 && !empty($_REQUEST['delete_post']) && $_REQUEST['delete_post'] == 'Y') { $sql = array('post_id' => '', 'post_type' => ''); $sql_data = array('%d', '%s'); $update_id = array('id' => $event_id); $wpdb->update(EVENTS_DETAIL_TABLE, $sql, $update_id, $sql_data, array('%d')); wp_delete_post($post_id, 'true'); } break; case $_REQUEST['create_post'] == 'Y': $post_type = $_REQUEST['espresso_post_type']; if ($post_type == 'post') { if (file_exists(EVENT_ESPRESSO_TEMPLATE_DIR . "event_post.php") || file_exists(EVENT_ESPRESSO_PLUGINFULLPATH . "templates/event_post.php")) { // Load message from template into message post variable ob_start(); if (file_exists(EVENT_ESPRESSO_TEMPLATE_DIR . "event_post.php")) { require_once EVENT_ESPRESSO_TEMPLATE_DIR . "event_post.php"; } else { require_once EVENT_ESPRESSO_PLUGINFULLPATH . "templates/event_post.php"; } $post_content = ob_get_contents(); ob_end_clean(); } else { _e('There was error finding a post template. Please verify your post templates are available.', 'event_espresso'); } } elseif ($post_type == 'espresso_event') { ob_start(); echo $event_desc; $post_content = ob_get_contents(); ob_end_clean(); } $my_post = array(); $sql = " SELECT * FROM " . EVENTS_DETAIL_TABLE; $sql .= " WHERE id = '" . $event_id . "' "; $wpdb->get_results($sql); $post_id = $wpdb->last_result[0]->post_id; $post_type = $_REQUEST['espresso_post_type']; if ($post_id > 0) { $my_post['ID'] = $post_id; } $my_post['post_title'] = esc_html($_REQUEST['event']); $my_post['post_content'] = $post_content; $my_post['post_status'] = 'publish'; $my_post['post_author'] = $_REQUEST['user']; $my_post['post_category'] = $_REQUEST['post_category']; //print_r ($my_post['post_category']); $my_post['tags_input'] = $_REQUEST['post_tags']; $my_post['post_type'] = $post_type; //print_r($my_post); // Insert the post into the database if ($post_id > 0) { $post_id = wp_update_post($my_post); update_post_meta($post_id, 'event_id', $event_id); update_post_meta($post_id, 'event_identifier', $event_identifier); update_post_meta($post_id, 'event_start_date', $start_date); update_post_meta($post_id, 'event_end_date', $end_date); update_post_meta($post_id, 'event_location', $event_location); update_post_meta($post_id, 'virtual_url', $virtual_url); update_post_meta($post_id, 'virtual_phone', $virtual_phone); // update_post_meta($post_id, 'event_address', $address); update_post_meta($post_id, 'event_address2', $address2); update_post_meta($post_id, 'event_city', $city); update_post_meta($post_id, 'event_state', $state); update_post_meta($post_id, 'event_country', $country); update_post_meta($post_id, 'event_phone', $phone); update_post_meta($post_id, 'venue_title', $venue_title); update_post_meta($post_id, 'venue_url', $venue_url); update_post_meta($post_id, 'venue_phone', $venue_phone); update_post_meta($post_id, 'venue_image', $venue_image); update_post_meta($post_id, 'event_externalURL', $externalURL); update_post_meta($post_id, 'event_reg_limit', $reg_limit); update_post_meta($post_id, 'event_start_time', time_to_24hr($start_time)); update_post_meta($post_id, 'event_end_time', time_to_24hr($end_time)); update_post_meta($post_id, 'event_registration_start', $registration_start); update_post_meta($post_id, 'event_registration_end', $registration_end); update_post_meta($post_id, 'event_registration_startT', $registration_startT); update_post_meta($post_id, 'event_registration_endT', $registration_endT); //update_post_meta( $post_id, 'timezone_string', $timezone_string ); } else { $post_id = wp_insert_post($my_post); add_post_meta($post_id, 'event_id', $event_id); add_post_meta($post_id, 'event_identifier', $event_identifier); add_post_meta($post_id, 'event_start_date', $start_date); add_post_meta($post_id, 'event_end_date', $end_date); add_post_meta($post_id, 'event_location', $event_location); add_post_meta($post_id, 'virtual_url', $virtual_url); add_post_meta($post_id, 'virtual_phone', $virtual_phone); // add_post_meta($post_id, 'event_address', $address); add_post_meta($post_id, 'event_address2', $address2); add_post_meta($post_id, 'event_city', $city); add_post_meta($post_id, 'event_state', $state); add_post_meta($post_id, 'event_country', $country); add_post_meta($post_id, 'event_phone', $phone); add_post_meta($post_id, 'venue_title', $venue_title); add_post_meta($post_id, 'venue_url', $venue_url); add_post_meta($post_id, 'venue_phone', $venue_phone); add_post_meta($post_id, 'venue_image', $venue_image); add_post_meta($post_id, 'event_externalURL', $externalURL); add_post_meta($post_id, 'event_reg_limit', $reg_limit); add_post_meta($post_id, 'event_start_time', time_to_24hr($start_time)); add_post_meta($post_id, 'event_end_time', time_to_24hr($end_time)); add_post_meta($post_id, 'event_registration_start', $registration_start); add_post_meta($post_id, 'event_registration_end', $registration_end); add_post_meta($post_id, 'event_registration_startT', $registration_startT); add_post_meta($post_id, 'event_registration_endT', $registration_endT); //add_post_meta( $post_id, 'timezone_string', $timezone_string ); } // Store the POST ID so it can be displayed on the edit page $sql = array('post_id' => $post_id, 'post_type' => $post_type); $sql_data = array('%d', '%s'); $update_id = array('id' => $event_id); $wpdb->update(EVENTS_DETAIL_TABLE, $sql, $update_id, $sql_data, array('%d')); break; } ?> <div id="message" class="updated fade"><p><strong><?php _e('Event details updated for', 'event_espresso'); ?> <a href="<?php echo espresso_reg_url($event_id); ?> " target="_blank"><?php echo stripslashes_deep($_REQUEST['event']); ?> for <?php echo date("m/d/Y", strtotime($start_date)); ?> </a>.</strong></p></div> <?php /* * Added for seating chart addon */ if (isset($seating_chart_result) && $seating_chart_result === false) { ?> <p>Failed to associate new seating chart with this event. (Seats from current seating chart might have been used by some attendees)</p> <?php } /* * End */ ?> <?php } /* * With the recursion of this function, additional recurring events will be updated */ if (isset($recurrence_dates) && count($recurrence_dates) > 0 && $_POST['recurrence_apply_changes_to'] > 1) { //$recurrence_dates = array_shift($recurrence_dates); //Remove the first item from the array since it will be added after this recursion foreach ($recurrence_dates as $r_d) { if ($r_d['event_id'] != '' && count($r_d) > 2) { update_event(array('event_id' => $r_d['event_id'], 'event_identifier' => $r_d['event_identifier'], 'recurrence_id' => $r_d['recurrence_id'], 'recurrence_start_date' => $r_d['start_date'], 'recurrence_event_end_date' => $r_d['event_end_date'], 'registration_start' => $r_d['registration_start'], 'registration_end' => $r_d['registration_end'], 'visible_on' => $r_d['visible_on'])); } } } /* * End recursion, as part of recurring events. */ }
function update_event($recurrence_arr = array()) { //print_r($_REQUEST); global $wpdb, $org_options, $current_user, $espresso_premium; //Security check using nonce if (empty($_POST['nonce_verify_update_event']) || !wp_verify_nonce($_POST['nonce_verify_update_event'], 'espresso_verify_update_event_nonce')) { if ($recurrence_arr['bypass_nonce'] == FALSE) { print '<h3 class="error">' . __('Sorry, there was a security error and your event was not updated.', 'event_espresso') . '</h3>'; return; } } $wpdb->show_errors(); /* * Begin Recurrence handling * * Will clean up in V 1.2.0 * */ if (defined('EVENT_ESPRESSO_RECURRENCE_TABLE')) { require_once EVENT_ESPRESSO_RECURRENCE_FULL_PATH . "functions/re_functions.php"; if ($_POST['recurrence_id'] > 0) { /* * If the array is empty, then find the recurring dates */ if (count($recurrence_arr) == 0) { // Prepare the parameters array for use with various RE functions $re_params = array('start_date' => !empty($_POST['recurrence_start_date']) ? sanitize_text_field($_POST['recurrence_start_date']) : '', 'event_end_date' => !empty($_POST['recurrence_event_end_date']) ? sanitize_text_field($_POST['recurrence_event_end_date']) : '', 'end_date' => !empty($_POST['recurrence_end_date']) ? sanitize_text_field($_POST['recurrence_end_date']) : '', 'registration_start' => !empty($_POST['recurrence_regis_start_date']) ? sanitize_text_field($_POST['recurrence_regis_start_date']) : '', 'registration_end' => !empty($_POST['recurrence_regis_end_date']) ? sanitize_text_field($_POST['recurrence_regis_end_date']) : '', 'frequency' => !empty($_POST['recurrence_frequency']) ? sanitize_text_field($_POST['recurrence_frequency']) : '', 'interval' => !empty($_POST['recurrence_interval']) ? sanitize_text_field($_POST['recurrence_interval']) : '', 'recurrence_type' => !empty($_POST['recurrence_type']) ? sanitize_text_field($_POST['recurrence_type']) : '', 'weekdays' => !empty($_POST['recurrence_weekday']) ? $_POST['recurrence_weekday'] : '', 'repeat_by' => !empty($_POST['recurrence_repeat_by']) ? $_POST['recurrence_repeat_by'] : '', 'recurrence_manual_dates' => !empty($_POST['recurrence_manual_dates']) ? $_POST['recurrence_manual_dates'] : '', 'recurrence_manual_end_dates' => !empty($_POST['recurrence_manual_end_dates']) ? $_POST['recurrence_manual_end_dates'] : '', 'recurrence_id' => !empty($_POST['recurrence_id']) ? $_POST['recurrence_id'] : '', 'recurrence_regis_date_increment' => !empty($_POST['recurrence_regis_date_increment']) ? $_POST['recurrence_regis_date_increment'] : ''); //$re_params['adding_to_db'] = 'Y'; //Has the form been modified $recurrence_form_modified = recurrence_form_modified($re_params); //echo ($recurrence_form_modified) ? "Yes" : 'No'; if ($_POST['recurrence_apply_changes_to'] == 2) { //Update all events in the series based on recurrence id $recurrence_dates = $_POST['recurrence_type'] == 'm' ? find_recurrence_manual_dates($re_params) : find_recurrence_dates($re_params); $UPDATE_SQL = "SELECT id,start_date,event_identifier FROM " . EVENTS_DETAIL_TABLE . " WHERE recurrence_id = %d AND NOT event_status = 'D'"; } else { //Update this and upcoming events based on recurrence id and start_date >=start_date $re_params['start_date'] = sanitize_text_field($_POST['start_date']); $recurrence_dates = find_recurrence_dates($re_params); $UPDATE_SQL = "SELECT id,start_date,event_identifier FROM " . EVENTS_DETAIL_TABLE . " WHERE start_date >='" . sanitize_text_field($_POST['start_date']) . "' AND recurrence_id = %d and NOT event_status = 'D' "; } //Recurrence Form modified and changes need to apply to all if ($recurrence_form_modified && $_POST['recurrence_apply_changes_to'] > 1) { //Update the recurrence table record with the new RE selections update_recurrence_master_record(); /* * Delete the records that don't belong in the formula */ if (count($recurrence_dates) > 0) { $delete_in = ''; foreach ($recurrence_dates as $k => $v) { $delete_in .= "'" . $k . "',"; } $delete_in = substr($delete_in, 0, -1); } if ($_POST['recurrence_apply_changes_to'] == 2) { //Update all events in the series based on recurrence id //$DEL_SQL = 'UPDATE ' . EVENTS_DETAIL_TABLE . " SET event_status = 'D' WHERE start_date NOT IN (" . $delete_in . ") AND recurrence_id = " . $_POST['recurrence_id']; $DEL_SQL = 'DELETE EDT, EAT FROM ' . EVENTS_DETAIL_TABLE . " EDT\n LEFT JOIN " . EVENTS_ATTENDEE_TABLE . " EAT\n ON EDT.id = EAT.event_id\n WHERE EAT.id IS NULL\n AND EDT.start_date NOT IN (" . $delete_in . ")\n AND recurrence_id = " . sanitize_text_field($_POST['recurrence_id']); $UPDATE_SQL = "SELECT id,start_date,event_identifier FROM " . EVENTS_DETAIL_TABLE . " WHERE recurrence_id = %d and NOT event_status = 'D' ORDER BY start_date"; } else { $DEL_SQL = 'DELETE EDT, EAT FROM ' . EVENTS_DETAIL_TABLE . " EDT\n LEFT JOIN " . EVENTS_ATTENDEE_TABLE . " EAT\n ON EDT.id = EAT.event_id\n WHERE EAT.id IS NULL\n AND EDT.start_date >='" . esc_sql(sanitize_text_field($_POST['start_date'])) . "'\n AND EDT.start_date NOT IN (" . $delete_in . ")\n AND recurrence_id = " . $_POST['recurrence_id']; $UPDATE_SQL = "SELECT id,start_date,event_identifier FROM " . EVENTS_DETAIL_TABLE . " WHERE start_date >='" . sanitize_text_field($_POST['start_date']) . "' AND recurrence_id = %d AND NOT event_status = 'D' ORDER BY start_date"; } if ($delete_in != '') { $wpdb->query($wpdb->prepare($DEL_SQL, NULL)); } /* * Add the new records based on the new formula * The $recurrence_dates array will contain the new dates */ if (!function_exists('add_event_to_db')) { require_once 'insert_event.php'; } foreach ($recurrence_dates as $k => $v) { $result = $wpdb->get_row($wpdb->prepare("SELECT ID FROM " . EVENTS_DETAIL_TABLE . " WHERE recurrence_id = %d and start_date = %s and NOT event_status = 'D'", array($_POST['recurrence_id'], $k))); if ($wpdb->num_rows == 0) { add_event_to_db(array('recurrence_id' => sanitize_text_field($_POST['recurrence_id']), 'recurrence_start_date' => $v['start_date'], 'recurrence_event_end_date' => $v['event_end_date'], 'recurrence_end_date' => $v['start_date'], 'registration_start' => $v['registration_start'], 'registration_end' => $v['registration_end'], 'bypass_nonce' => TRUE)); } else { } } /* * Find all the event ids in the series and feed into the $recurrence_dates array * This array will be used at the end of this document to invoke the recursion of update_event function so all the events in the series * can be updated with the information. */ } $result = $wpdb->get_results($wpdb->prepare($UPDATE_SQL, array(sanitize_text_field($_POST['recurrence_id'])))); foreach ($result as $row) { if ($row->start_date != '') { $recurrence_dates[$row->start_date]['event_id'] = $row->id; $recurrence_dates[$row->start_date]['event_identifier'] = $row->event_identifier; } } } } } // echo_f('rd',$recurrence_dates); if (defined('EVENT_ESPRESSO_RECURRENCE_MODULE_ACTIVE') && !empty($_POST['recurrence']) && $_POST['recurrence'] == 'Y' && count($recurrence_arr) == 0 && $_POST['recurrence_apply_changes_to'] > 1) { //skip the first update } else { //Filters the event description based on user level $user_access = apply_filters('filter_hook_espresso_event_unfiltered_description', current_user_can('administrator')); $_REQUEST['event_desc'] = is_admin() || $user_access ? $_REQUEST['event_desc'] : apply_filters('filter_hook_espresso_event_wp_kses_post_description', wp_kses_post($_REQUEST['event_desc'])); $event_meta = array(); //will be used to hold event meta data $event_id = array_key_exists('event_id', $recurrence_arr) ? $recurrence_arr['event_id'] : (int) $_REQUEST['event_id']; $event_name = sanitize_text_field($_REQUEST['event']); $event_desc = !empty($_REQUEST['event_desc']) ? $_REQUEST['event_desc'] : ''; $display_desc = sanitize_text_field($_REQUEST['display_desc']); $display_reg_form = sanitize_text_field($_REQUEST['display_reg_form']); $externalURL = !empty($_REQUEST['externalURL']) ? esc_html($_REQUEST['externalURL']) : ''; $reg_limit = (int) $_REQUEST['reg_limit']; $allow_multiple = $_REQUEST['allow_multiple']; $overflow_event_id = empty($_REQUEST['overflow_event_id']) ? '0' : (int) $_REQUEST['overflow_event_id']; $allow_overflow = empty($_REQUEST['allow_overflow']) ? 'N' : sanitize_text_field($_REQUEST['allow_overflow']); $additional_limit = !empty($_REQUEST['additional_limit']) && $_REQUEST['additional_limit'] > 0 ? (int) $_REQUEST['additional_limit'] : '5'; $member_only = empty($_REQUEST['member_only']) ? 'N' : sanitize_text_field($_REQUEST['member_only']); $is_active = !empty($_REQUEST['is_active']) ? sanitize_text_field($_REQUEST['is_active']) : 'Y'; $event_status = !empty($_REQUEST['event_status']) ? sanitize_text_field($_REQUEST['event_status']) : 'A'; //Get the first instance of the start and end times $start_time = sanitize_text_field($_REQUEST['start_time'][0]); $end_time = sanitize_text_field($_REQUEST['end_time'][0]); // Add registration times $registration_startT = event_date_display(sanitize_text_field($_REQUEST['registration_startT']), 'H:i'); $registration_endT = event_date_display(sanitize_text_field($_REQUEST['registration_endT']), 'H:i'); //Add timezone $timezone_string = empty($_REQUEST['timezone_string']) ? '' : sanitize_text_field($_REQUEST['timezone_string']); //Early discounts $early_disc = !empty($_REQUEST['early_disc']) ? sanitize_text_field($_REQUEST['early_disc']) : ''; $early_disc_date = !empty($_REQUEST['early_disc_date']) ? sanitize_text_field($_REQUEST['early_disc_date']) : ''; $early_disc_percentage = !empty($_REQUEST['early_disc_percentage']) ? sanitize_text_field($_REQUEST['early_disc_percentage']) : ''; $conf_mail = esc_html($_REQUEST['conf_mail']); $use_coupon_code = !empty($_REQUEST['use_coupon_code']) ? sanitize_text_field($_REQUEST['use_coupon_code']) : ''; $alt_email = isset($_REQUEST['alt_email']) && !empty($_REQUEST['alt_email']) ? sanitize_text_field($_REQUEST['alt_email']) : ''; $send_mail = sanitize_text_field($_REQUEST['send_mail']); $email_id = isset($_REQUEST['email_name']) ? (int) $_REQUEST['email_name'] : '0'; $ticket_id = isset($_REQUEST['ticket_id']) ? (int) $_REQUEST['ticket_id'] : '0'; $event_category = empty($_REQUEST['event_category']) ? '' : serialize(sanitize_text_field($_REQUEST['event_category'])); $event_discount = empty($_REQUEST['event_discount']) ? '' : serialize(sanitize_text_field($_REQUEST['event_discount'])); $registration_start = array_key_exists('registration_start', $recurrence_arr) ? $recurrence_arr['registration_start'] : sanitize_text_field($_REQUEST['registration_start']); $registration_end = array_key_exists('registration_end', $recurrence_arr) ? $recurrence_arr['registration_end'] : sanitize_text_field($_REQUEST['registration_end']); $start_date = array_key_exists('recurrence_start_date', $recurrence_arr) ? $recurrence_arr['recurrence_start_date'] : (empty($_REQUEST['start_date']) ? $_REQUEST['recurrence_start_date'] : sanitize_text_field($_REQUEST['start_date'])); $end_date = array_key_exists('recurrence_event_end_date', $recurrence_arr) ? $recurrence_arr['recurrence_event_end_date'] : (empty($_REQUEST['end_date']) ? sanitize_text_field($_REQUEST['recurrence_start_date']) : sanitize_text_field($_REQUEST['end_date'])); $question_groups = serialize($_REQUEST['question_groups']); $add_attendee_question_groups = empty($_REQUEST['add_attendee_question_groups']) ? '' : $_REQUEST['add_attendee_question_groups']; //Venue Information $venue_title = isset($_REQUEST['venue_title']) ? sanitize_text_field($_REQUEST['venue_title']) : ''; $venue_url = isset($_REQUEST['venue_url']) ? sanitize_text_field($_REQUEST['venue_url']) : ''; $venue_phone = isset($_REQUEST['venue_phone']) ? sanitize_text_field($_REQUEST['venue_phone']) : ''; $venue_image = isset($_REQUEST['venue_image']) ? sanitize_text_field($_REQUEST['venue_image']) : ''; //Virtual location $virtual_url = isset($_REQUEST['virtual_url']) ? sanitize_text_field($_REQUEST['virtual_url']) : ''; $virtual_phone = isset($_REQUEST['virtual_phone']) ? sanitize_text_field($_REQUEST['virtual_phone']) : ''; //Address/venue information $address = !empty($_REQUEST['address']) ? sanitize_text_field($_REQUEST['address']) : ''; $address2 = !empty($_REQUEST['address2']) ? sanitize_text_field($_REQUEST['address2']) : ''; $city = !empty($_REQUEST['city']) ? sanitize_text_field($_REQUEST['city']) : ''; $state = !empty($_REQUEST['state']) ? sanitize_text_field($_REQUEST['state']) : ''; $zip = !empty($_REQUEST['zip']) ? sanitize_text_field($_REQUEST['zip']) : ''; $country = !empty($_REQUEST['country']) ? sanitize_text_field($_REQUEST['country']) : ''; $phone = !empty($_REQUEST['phone']) ? sanitize_text_field($_REQUEST['phone']) : ''; $event_location = ''; if (!empty($address)) { $event_location .= $address . ' '; } if (!empty($address2)) { $event_location .= '<br />' . $address2; } if (!empty($city)) { $event_location .= '<br />' . $city; } if (!empty($state)) { $event_location .= ', ' . $state; } if (!empty($zip)) { $event_location .= ', ' . $state; } if (!empty($country)) { $event_location .= '<br />' . $country; } if (isset($reg_limit) && empty($reg_limit)) { $reg_limit = 999999; } $event_meta['default_payment_status'] = !empty($_REQUEST['default_payment_status']) ? sanitize_text_field($_REQUEST['default_payment_status']) : ''; $event_meta['venue_id'] = empty($_REQUEST['venue_id']) ? '' : (int) $_REQUEST['venue_id'][0]; $event_meta['additional_attendee_reg_info'] = !empty($_REQUEST['additional_attendee_reg_info']) ? sanitize_text_field($_REQUEST['additional_attendee_reg_info']) : ''; $event_meta['add_attendee_question_groups'] = $add_attendee_question_groups; $event_meta['date_submitted'] = sanitize_text_field($_REQUEST['date_submitted']); //Added for seating chart addon if (isset($_REQUEST['seating_chart_id'])) { $cls_seating_chart = new seating_chart(); $seating_chart_result = $cls_seating_chart->associate_event_seating_chart((int) $_REQUEST['seating_chart_id'], $event_id); $tmp_seating_chart_id = (int) $_REQUEST['seating_chart_id']; if ($tmp_seating_chart_id > 0) { if ($seating_chart_result === false) { $tmp_seating_chart_row = $wpdb->get_row($wpdb->prepare("select seating_chart_id from " . EVENTS_SEATING_CHART_EVENT_TABLE . " where event_id = {$event_id}", NULL)); if ($tmp_seating_chart_row !== NULL) { $tmp_seating_chart_id = $tmp_seating_chart_row->seating_chart_id; } else { $tmp_seating_chart_id = 0; } } if ($_REQUEST['allow_multiple'] == 'Y' && isset($_REQUEST['seating_chart_id']) && $tmp_seating_chart_id > 0) { $event_meta['additional_attendee_reg_info'] = 3; } } } //Process thumbnail image $event_thumbnail_url = ''; if (isset($_REQUEST['upload_image']) && !empty($_REQUEST['upload_image'])) { $event_meta['event_thumbnail_url'] = sanitize_text_field($_REQUEST['upload_image']); $event_thumbnail_url = sanitize_text_field($event_meta['event_thumbnail_url']); } if (!empty($_REQUEST['emeta'])) { foreach ($_REQUEST['emeta'] as $k => $v) { $event_meta[$v] = sanitize_text_field($_REQUEST['emetad'][$k]); } } //Filter to update the event meta as needed $event_meta = apply_filters('filter_hook_espresso_update_event_update_meta', $event_meta, $event_id); //print_r($_REQUEST['emeta'] ); $event_meta = serialize($event_meta); ############ Added by wp-developers ###################### $require_pre_approval = 0; if (isset($_REQUEST['require_pre_approval'])) { $require_pre_approval = sanitize_text_field($_REQUEST['require_pre_approval']); } ################# END ################# //When adding colums to the following arrays, be sure both arrays have equal values. $sql = array('event_name' => $event_name, 'event_desc' => $event_desc, 'display_desc' => $display_desc, 'display_reg_form' => $display_reg_form, 'address' => $address, 'address2' => $address2, 'city' => $city, 'state' => $state, 'zip' => $zip, 'country' => $country, 'phone' => $phone, 'virtual_url' => $virtual_url, 'virtual_phone' => $virtual_phone, 'venue_title' => $venue_title, 'venue_url' => $venue_url, 'venue_phone' => $venue_phone, 'venue_image' => $venue_image, 'registration_start' => $registration_start, 'registration_end' => $registration_end, 'start_date' => $start_date, 'end_date' => $end_date, 'allow_multiple' => $allow_multiple, 'send_mail' => $send_mail, 'is_active' => $is_active, 'event_status' => $event_status, 'conf_mail' => $conf_mail, 'use_coupon_code' => $use_coupon_code, 'member_only' => $member_only, 'externalURL' => $externalURL, 'early_disc' => $early_disc, 'early_disc_date' => $early_disc_date, 'early_disc_percentage' => $early_disc_percentage, 'alt_email' => $alt_email, 'question_groups' => $question_groups, 'allow_overflow' => $allow_overflow, 'overflow_event_id' => $overflow_event_id, 'additional_limit' => $additional_limit, 'reg_limit' => $reg_limit, 'email_id' => $email_id, 'registration_startT' => $registration_startT, 'registration_endT' => $registration_endT, 'event_meta' => $event_meta, 'require_pre_approval' => $require_pre_approval, 'timezone_string' => $timezone_string, 'ticket_id' => $ticket_id); $sql_data = array('%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%d', '%d', '%d', '%d', '%s', '%s', '%s', '%s', '%s', '%d'); $update_id = array('id' => $event_id); /* echo 'Debug: <br />'; print_r($sql); echo '<br />'; print 'Number of vars: ' . count ($sql); echo '<br />'; print 'Number of cols: ' . count($sql_data); */ if (function_exists('event_espresso_add_event_to_db_groupon')) { $sql = event_espresso_add_event_to_db_groupon($sql, $_REQUEST['use_groupon_code']); ///print count ($sql); $sql_data = array_merge((array) $sql_data, (array) '%s'); //print count($sql_data); $wpdb->update(EVENTS_DETAIL_TABLE, $sql, $update_id, $sql_data, array('%d')); /* echo 'Debug: <br />'; print 'Number of vars: ' . count ($sql); echo '<br />'; print 'Number of cols: ' . count($sql_data); */ } else { $wpdb->update(EVENTS_DETAIL_TABLE, $sql, $update_id, $sql_data, array('%d')); /* echo 'Debug: <br />'; print 'Number of vars: ' . count ($sql); echo '<br />'; print 'Number of cols: ' . count($sql_data); */ } //print $wpdb->print_error(); //BEGIN CATEGORY MODIFICATION //We first delete the previous entry then we get the category id's of the event and put them in events_detail_table.category_id as a well-formatted string (id,n id) $del_cats = "DELETE FROM " . EVENTS_CATEGORY_REL_TABLE . " WHERE event_id = '" . $event_id . "'"; $wpdb->query($wpdb->prepare($del_cats, NULL)); $update_event_detail_category_id = "UPDATE " . EVENTS_DETAIL_TABLE . " SET category_id = NULL WHERE id='" . $event_id . "'"; $wpdb->query($wpdb->prepare($update_event_detail_category_id, NULL)); $string_cat = ''; if (!empty($_REQUEST['event_category'])) { foreach ($_REQUEST['event_category'] as $k => $v) { if (!empty($v)) { $sql_cat = "INSERT INTO " . EVENTS_CATEGORY_REL_TABLE . " (event_id, cat_id) VALUES ('" . $event_id . "', '" . (int) $v . "')"; $wpdb->query($wpdb->prepare($sql_cat, array())); $string_cat .= sanitize_text_field($v) . ","; } } if (!empty($string_cat) && $string_cat != ",") { $cleaned_string_cat = substr($string_cat, 0, -1); $tmp = explode(",", $cleaned_string_cat); sort($tmp); $cleaned_string_cat = implode(",", $tmp); trim($cleaned_string_cat); $sql_update_event_detail_category_id = "UPDATE " . EVENTS_DETAIL_TABLE . " SET category_id = '" . $cleaned_string_cat . "' WHERE id='" . $event_id . "'"; $wpdb->query($wpdb->prepare($sql_update_event_detail_category_id, NULL)); } } //END CATEGORY MODIFICATION //Staff $update_all_staff = FALSE; if (isset($_POST['rem_apply_to_all_staff']) && $_POST['recurrence_apply_changes_to'] == 2) { $update_all_staff = TRUE; } if ($_POST['event_id'] == $event_id || $update_all_staff == TRUE) { $del_ppl = "DELETE FROM " . EVENTS_PERSONNEL_REL_TABLE . " WHERE event_id = '" . $event_id . "'"; $wpdb->query($wpdb->prepare($del_ppl, NULL)); if (!empty($_REQUEST['event_person'])) { foreach ($_REQUEST['event_person'] as $k => $v) { if (!empty($v)) { $sql_ppl = "INSERT INTO " . EVENTS_PERSONNEL_REL_TABLE . " (event_id, person_id) VALUES ('" . $event_id . "', '" . (int) $v . "')"; $wpdb->query($wpdb->prepare($sql_ppl, array())); } } } } //Venues $del_venues = "DELETE FROM " . EVENTS_VENUE_REL_TABLE . " WHERE event_id = '" . $event_id . "'"; $wpdb->query($wpdb->prepare($del_venues, NULL)); if (!empty($_REQUEST['venue_id'])) { foreach ($_REQUEST['venue_id'] as $k => $v) { if (!empty($v) && $v != 0) { $sql_venues = "INSERT INTO " . EVENTS_VENUE_REL_TABLE . " (event_id, venue_id) VALUES ('" . $event_id . "', '" . (int) $v . "')"; $wpdb->query($wpdb->prepare($sql_venues, array())); } } } //Discounts $del_discounts = "DELETE FROM " . EVENTS_DISCOUNT_REL_TABLE . " WHERE event_id = '" . $event_id . "'"; $wpdb->query($wpdb->prepare($del_discounts, NULL)); if (!empty($_REQUEST['event_discount']) && $_REQUEST['use_coupon_code'] == 'Y') { //only re-add the coupon codes if they've specified to use all global coupon codes //and 'specific' coupon codes foreach ($_REQUEST['event_discount'] as $k => $v) { if (!empty($v)) { $sql_discount = "INSERT INTO " . EVENTS_DISCOUNT_REL_TABLE . " (event_id, discount_id) VALUES ('" . $event_id . "', '" . (int) $v . "')"; $wpdb->query($wpdb->prepare($sql_discount, array())); } } } $del_times = "DELETE FROM " . EVENTS_START_END_TABLE . " WHERE event_id = '" . $event_id . "'"; $wpdb->query($wpdb->prepare($del_times, NULL)); if (!empty($_REQUEST['start_time'])) { foreach ($_REQUEST['start_time'] as $k => $v) { if (!empty($v)) { $time_qty = empty($_REQUEST['time_qty'][$k]) ? '0' : "'" . (int) $_REQUEST['time_qty'][$k] . "'"; $sql_times = "INSERT INTO " . EVENTS_START_END_TABLE . " (event_id, start_time, end_time, reg_limit) VALUES ('" . $event_id . "', '" . event_date_display(sanitize_text_field($v), 'H:i') . "', '" . event_date_display(sanitize_text_field($_REQUEST['end_time'][$k]), 'H:i') . "', " . $time_qty . ")"; $wpdb->query($wpdb->prepare($sql_times, array())); } } } $del_prices = "DELETE FROM " . EVENTS_PRICES_TABLE . " WHERE event_id = '" . $event_id . "'"; $wpdb->query($wpdb->prepare($del_prices, NULL)); if (!empty($_REQUEST['event_cost'])) { foreach ($_REQUEST['event_cost'] as $k => $v) { if (!empty($v)) { $v = (double) preg_replace('/[^0-9\\.]/ui', '', $v); //Removes non-integer characters $price_type = $_REQUEST['price_type'][$k] != '' ? sanitize_text_field(stripslashes_deep($_REQUEST['price_type'][$k])) : __('General Admission', 'event_espresso'); $member_price_type = !empty($_REQUEST['member_price_type'][$k]) ? sanitize_text_field(stripslashes_deep($_REQUEST['member_price_type'][$k])) : __('Members Admission', 'event_espresso'); $member_price = !empty($_REQUEST['member_price'][$k]) ? (double) $_REQUEST['member_price'][$k] : $v; $sql_price = array('event_id' => $event_id, 'event_cost' => $v, 'surcharge' => sanitize_text_field($_REQUEST['surcharge'][$k]), 'surcharge_type' => sanitize_text_field($_REQUEST['surcharge_type'][$k]), 'price_type' => $price_type, 'member_price' => $member_price, 'member_price_type' => $member_price_type); $sql_price_data = array('%d', '%s', '%s', '%s', '%s', '%s', '%s'); if (!$wpdb->insert(EVENTS_PRICES_TABLE, $sql_price, $sql_price_data)) { $error = true; } } } } else { $sql_price = "INSERT INTO " . EVENTS_PRICES_TABLE . " (event_id, event_cost, surcharge, price_type, member_price, member_price_type) VALUES ('" . $event_id . "', '0.00', '0.00', '" . __('Free', 'event_espresso') . "', '0.00', '" . __('Free', 'event_espresso') . "')"; if (!$wpdb->query($wpdb->prepare($sql_price, array()))) { $error = true; } } ############# MailChimp Integration ############### if (defined('EVENTS_MAILCHIMP_ATTENDEE_REL_TABLE') && $espresso_premium == true) { MailChimpController::update_event_list_rel($event_id); } // Create Event Post Code Here if (isset($_REQUEST['create_post'])) { switch ($_REQUEST['create_post']) { case 'N': $sql = " SELECT * FROM " . EVENTS_DETAIL_TABLE; $sql .= " WHERE id = '" . $event_id . "' "; $wpdb->get_results($wpdb->prepare($sql, NULL)); $post_id = $wpdb->last_result[0]->post_id; if ($wpdb->num_rows > 0 && !empty($_REQUEST['delete_post']) && $_REQUEST['delete_post'] == 'Y') { $sql = array('post_id' => '', 'post_type' => ''); $sql_data = array('%d', '%s'); $update_id = array('id' => $event_id); $wpdb->update(EVENTS_DETAIL_TABLE, $sql, $update_id, $sql_data, array('%d')); wp_delete_post($post_id, 'true'); } break; case 'Y': $post_type = $_REQUEST['espresso_post_type']; if ($post_type == 'post') { if (file_exists(EVENT_ESPRESSO_TEMPLATE_DIR . "event_post.php") || file_exists(EVENT_ESPRESSO_PLUGINFULLPATH . "templates/event_post.php")) { // Load message from template into message post variable ob_start(); if (file_exists(EVENT_ESPRESSO_TEMPLATE_DIR . "event_post.php")) { require_once EVENT_ESPRESSO_TEMPLATE_DIR . "event_post.php"; } else { require_once EVENT_ESPRESSO_PLUGINFULLPATH . "templates/event_post.php"; } $post_content = ob_get_contents(); ob_end_clean(); } else { _e('There was error finding a post template. Please verify your post templates are available.', 'event_espresso'); } } elseif ($post_type == 'espresso_event') { ob_start(); echo $event_desc; $post_content = ob_get_contents(); ob_end_clean(); // if there's a cart link shortcode in the post, replace the shortcode with one that includes the event_id if (preg_match("/ESPRESSO_CART_LINK/", $post_content)) { $post_content = preg_replace('/ESPRESSO_CART_LINK/', 'ESPRESSO_CART_LINK event_id=' . $event_id, $post_content); } } $my_post = array(); $sql = " SELECT * FROM " . EVENTS_DETAIL_TABLE; $sql .= " WHERE id = '" . $event_id . "' "; $wpdb->get_results($wpdb->prepare($sql, NULL)); $post_id = $wpdb->last_result[0]->post_id; $post_type = $_REQUEST['espresso_post_type']; if ($post_id > 0) { $my_post['ID'] = $post_id; } $my_post['post_title'] = sanitize_text_field($_REQUEST['event']); $my_post['post_content'] = $post_content; $my_post['post_status'] = 'publish'; $my_post['post_author'] = !empty($_REQUEST['user']) ? (int) $_REQUEST['user'] : ''; $my_post['post_category'] = !empty($_REQUEST['post_category']) ? $_REQUEST['post_category'] : ''; $my_post['tags_input'] = !empty($_REQUEST['post_tags']) ? $_REQUEST['post_tags'] : ''; $my_post['post_type'] = !empty($post_type) ? $post_type : 'post'; //print_r($my_post); // Insert the post into the database if ($post_id > 0) { $post_id = wp_update_post($my_post); update_post_meta($post_id, 'event_id', $event_id); update_post_meta($post_id, 'event_meta', $event_meta); update_post_meta($post_id, 'event_identifier', $event_identifier); update_post_meta($post_id, 'event_start_date', $start_date); update_post_meta($post_id, 'event_end_date', $end_date); update_post_meta($post_id, 'event_location', $event_location); update_post_meta($post_id, 'event_thumbnail_url', $event_thumbnail_url); update_post_meta($post_id, 'virtual_url', $virtual_url); update_post_meta($post_id, 'virtual_phone', $virtual_phone); // update_post_meta($post_id, 'event_address', $address); update_post_meta($post_id, 'event_address2', $address2); update_post_meta($post_id, 'event_city', $city); update_post_meta($post_id, 'event_state', $state); update_post_meta($post_id, 'event_country', $country); update_post_meta($post_id, 'event_phone', $phone); update_post_meta($post_id, 'venue_title', $venue_title); update_post_meta($post_id, 'venue_url', $venue_url); update_post_meta($post_id, 'venue_phone', $venue_phone); update_post_meta($post_id, 'venue_image', $venue_image); update_post_meta($post_id, 'event_externalURL', $externalURL); update_post_meta($post_id, 'event_reg_limit', $reg_limit); update_post_meta($post_id, 'event_start_time', time_to_24hr($start_time)); update_post_meta($post_id, 'event_end_time', time_to_24hr($end_time)); update_post_meta($post_id, 'event_registration_start', $registration_start); update_post_meta($post_id, 'event_registration_end', $registration_end); update_post_meta($post_id, 'event_registration_startT', $registration_startT); update_post_meta($post_id, 'event_registration_endT', $registration_endT); } else { $post_id = wp_insert_post($my_post); add_post_meta($post_id, 'event_id', $event_id); add_post_meta($post_id, 'event_meta', $event_meta); add_post_meta($post_id, 'event_identifier', $event_identifier); add_post_meta($post_id, 'event_start_date', $start_date); add_post_meta($post_id, 'event_end_date', $end_date); add_post_meta($post_id, 'event_location', $event_location); add_post_meta($post_id, 'event_thumbnail_url', $event_thumbnail_url); add_post_meta($post_id, 'virtual_url', $virtual_url); add_post_meta($post_id, 'virtual_phone', $virtual_phone); // add_post_meta($post_id, 'event_address', $address); add_post_meta($post_id, 'event_address2', $address2); add_post_meta($post_id, 'event_city', $city); add_post_meta($post_id, 'event_state', $state); add_post_meta($post_id, 'event_country', $country); add_post_meta($post_id, 'event_phone', $phone); add_post_meta($post_id, 'venue_title', $venue_title); add_post_meta($post_id, 'venue_url', $venue_url); add_post_meta($post_id, 'venue_phone', $venue_phone); add_post_meta($post_id, 'venue_image', $venue_image); add_post_meta($post_id, 'event_externalURL', $externalURL); add_post_meta($post_id, 'event_reg_limit', $reg_limit); add_post_meta($post_id, 'event_start_time', time_to_24hr($start_time)); add_post_meta($post_id, 'event_end_time', time_to_24hr($end_time)); add_post_meta($post_id, 'event_registration_start', $registration_start); add_post_meta($post_id, 'event_registration_end', $registration_end); add_post_meta($post_id, 'event_registration_startT', $registration_startT); add_post_meta($post_id, 'event_registration_endT', $registration_endT); } // Store the POST ID so it can be displayed on the edit page $sql = array('post_id' => $post_id, 'post_type' => $post_type); $sql_data = array('%d', '%s'); $update_id = array('id' => $event_id); $wpdb->update(EVENTS_DETAIL_TABLE, $sql, $update_id, $sql_data, array('%d')); break; } } ?> <div id="message" class="updated fade"><p><strong><?php _e('Event details updated for', 'event_espresso'); ?> <a href="<?php echo espresso_reg_url($event_id); ?> " target="_blank"> <?php echo htmlentities(stripslashes(sanitize_text_field($_REQUEST['event'])), ENT_QUOTES, 'UTF-8'); ?> for <?php echo date("m/d/Y", strtotime($start_date)); ?> </a>.</strong></p></div> <?php /* * Added for seating chart addon */ if (isset($seating_chart_result) && $seating_chart_result === false) { echo '<p>Failed to associate new seating chart with this event. (Seats from current seating chart might have been used by some attendees)</p>'; } } /* * With the recursion of this function, additional recurring events will be updated */ if (isset($recurrence_dates) && count($recurrence_dates) > 0 && $_POST['recurrence_apply_changes_to'] > 1) { //$recurrence_dates = array_shift($recurrence_dates); //Remove the first item from the array since it will be added after this recursion foreach ($recurrence_dates as $r_d) { if ($r_d['event_id'] != '' && count($r_d) > 2) { update_event(array('event_id' => $r_d['event_id'], 'event_identifier' => $r_d['event_identifier'], 'recurrence_id' => $r_d['recurrence_id'], 'recurrence_start_date' => $r_d['start_date'], 'recurrence_event_end_date' => $r_d['event_end_date'], 'registration_start' => $r_d['registration_start'], 'registration_end' => $r_d['registration_end'], 'visible_on' => $r_d['visible_on'], 'bypass_nonce' => TRUE)); } } } /* * End recursion, as part of recurring events. */ do_action('action_hook_espresso_update_event_success', $_REQUEST); }