function mc_list_groups() { global $wpdb; $mcdb = $wpdb; $sortby = isset($_GET['sort']) ? (int) $_GET['sort'] : get_option('mc_default_sort'); if (isset($_GET['order'])) { $sortdir = isset($_GET['order']) && $_GET['order'] == 'ASC' ? 'ASC' : 'default'; } else { $sortdir = 'default'; } if (empty($sortby)) { $sortbyvalue = 'event_begin'; } else { switch ($sortby) { case 1: $sortbyvalue = 'event_ID'; break; case 2: $sortbyvalue = 'event_title'; break; case 3: $sortbyvalue = 'event_desc'; break; case 4: $sortbyvalue = 'event_begin'; break; case 5: $sortbyvalue = 'event_author'; break; case 6: $sortbyvalue = 'event_category'; break; case 7: $sortbyvalue = 'event_label'; break; case 8: $sortbyvalue = 'group_id'; break; default: $sortbyvalue = 'event_begin'; } } $sortbydirection = $sortdir == 'default' ? 'DESC' : $sortdir; $sorting = $sortbydirection == 'DESC' ? "&order=ASC" : ''; $current = empty($_GET['paged']) ? 1 : intval($_GET['paged']); $user = get_current_user_id(); $screen = get_current_screen(); $option = $screen->get_option('per_page', 'option'); $items_per_page = get_user_meta($user, $option, true); if (empty($items_per_page) || $items_per_page < 1) { $items_per_page = $screen->get_option('per_page', 'default'); } $limit = isset($_GET['limit']) ? $_GET['limit'] : 'all'; switch ($limit) { case 'all': $limit = ''; break; case 'grouped': $limit = 'WHERE event_group_id <> 0'; break; case 'ungrouped': $limit = 'WHERE event_group_id = 0'; break; default: $limit = ''; } $events = $mcdb->get_results("SELECT SQL_CALC_FOUND_ROWS * FROM " . my_calendar_table() . " {$limit} ORDER BY {$sortbyvalue} {$sortbydirection} LIMIT " . ($current - 1) * $items_per_page . ", " . $items_per_page); $found_rows = $wpdb->get_col("SELECT FOUND_ROWS();"); $items = $found_rows[0]; ?> <div class='inside'><?php if (get_option('mc_event_approve') == 'true') { ?> <ul class="links"> <li><a <?php echo isset($_GET['limit']) && $_GET['limit'] == 'groupeed' ? ' class="active-link"' : ''; ?> href="<?php echo admin_url('admin.php?page=my-calendar-groups&limit=grouped#my-calendar-admin-table'); ?> "><?php _e('Grouped Events', 'my-calendar'); ?> </a></li> <li><a <?php echo isset($_GET['limit']) && $_GET['limit'] == 'ungrouped' ? ' class="active-link"' : ''; ?> href="<?php echo admin_url('admin.php?page=my-calendar-groups&limit=ungrouped#my-calendar-admin-table'); ?> "><?php _e('Ungrouped Events', 'my-calendar'); ?> </a></li> <li><a <?php echo isset($_GET['limit']) && $_GET['limit'] == 'all' || !isset($_GET['limit']) ? ' class="active-link"' : ''; ?> href="<?php echo admin_url('admin.php?page=my-calendar-groups#my-calendar-admin-table'); ?> "><?php _e('All', 'my-calendar'); ?> </a></li> </ul> <?php } ?> <p><?php _e('Check a set of events to group them for mass editing.', 'my-calendar'); ?> </p><?php $num_pages = ceil($items / $items_per_page); if ($num_pages > 1) { $page_links = paginate_links(array('base' => add_query_arg('paged', '%#%'), 'format' => '', 'prev_text' => __('« Previous<span class="screen-reader-text"> Events</span>', 'my-calendar'), 'next_text' => __('Next<span class="screen-reader-text"> Events</span> »', 'my-calendar'), 'total' => $num_pages, 'current' => $current, 'mid_size' => 1)); printf("<div class='tablenav'><div class='tablenav-pages'>%s</div></div>", $page_links); } if (!empty($events)) { ?> <form action="<?php echo admin_url("admin.php?page=my-calendar-groups"); ?> " method="post"> <div> <input type="hidden" name="_wpnonce" value="<?php echo wp_create_nonce('my-calendar-nonce'); ?> " /> <input type="hidden" name="event_action" value="group" /> </div> <p style="position:relative;display:inline-block;"> <input type="submit" class="button-primary group" value="<?php _e('Group checked events for mass editing', 'my-calendar'); ?> " /> </p> </div> <table class="widefat wp-list-table" id="my-calendar-admin-table"> <thead> <tr> <th scope="col" style="width: 50px;"><a href="<?php echo admin_url("admin.php?page=my-calendar-groups&sort=1{$sorting}"); ?> "><?php _e('ID', 'my-calendar'); ?> </a></th> <th scope="col"><a href="<?php echo admin_url("admin.php?page=my-calendar-groups&sort=8{$sorting}"); ?> "><?php _e('Group', 'my-calendar'); ?> </a></th> <th scope="col"><a href="<?php echo admin_url("admin.php?page=my-calendar-groups&sort=2{$sorting}"); ?> "><?php _e('Title', 'my-calendar'); ?> </a></th> <th scope="col"><a href="<?php echo admin_url("admin.php?page=my-calendar-groups&sort=7{$sorting}"); ?> "><?php _e('Where', 'my-calendar'); ?> </a></th> <th scope="col"><a href="<?php echo admin_url("admin.php?page=my-calendar-groups&sort=4{$sorting}"); ?> "><?php _e('Starts', 'my-calendar'); ?> </a></th> <th scope="col"><?php _e('Recurs', 'my-calendar'); ?> </th> <th scope="col"><a href="<?php echo admin_url("admin.php?page=my-calendar-groups&sort=5{$sorting}"); ?> "><?php _e('Author', 'my-calendar'); ?> </a></th> <th scope="col"><a href="<?php echo admin_url("admin.php?page=my-calendar-groups&sort=6{$sorting}"); ?> "><?php _e('Category', 'my-calendar'); ?> </a></th> </tr> </thead> <?php $class = ''; $sql = "SELECT * FROM " . my_calendar_categories_table(); $categories = $mcdb->get_results($sql); foreach ($events as $event) { $class = $class == 'alternate' ? '' : 'alternate'; $spam = $event->event_flagged == 1 ? ' spam' : ''; $spam_label = $event->event_flagged == 1 ? '<strong>Possible spam:</strong> ' : ''; $author = $event->event_author != 0 ? get_userdata($event->event_author) : 'Public Submitter'; if ($event->event_link != '') { $title = "<a href='" . esc_attr($event->event_link) . "'>{$event->event_title}</a>"; } else { $title = $event->event_title; } ?> <tr class="<?php echo $class; echo $spam; ?> " id="event<?php echo $event->event_id; ?> "> <th scope="row"><input type="checkbox" value="<?php echo $event->event_id; ?> " name="group[]" id="mc<?php echo $event->event_id; ?> " <?php echo mc_event_is_grouped($event->event_group_id) ? ' disabled="disabled"' : ''; ?> /> <label for="mc<?php echo $event->event_id; ?> "><?php echo $event->event_id; ?> </label></th> <th scope="row"><?php echo $event->event_group_id == 0 ? '-' : $event->event_group_id; ?> </th> <td title="<?php echo esc_attr(substr(strip_tags(stripslashes($event->event_desc)), 0, 240)); ?> "> <strong><?php if (mc_can_edit_event($event->event_author)) { ?> <a href="<?php echo admin_url("admin.php?page=my-calendar&mode=edit&event_id={$event->event_id}"); ?> " class='edit'> <?php } echo $spam_label; echo stripslashes($title); ?> <?php if (mc_can_edit_event($event->event_author)) { echo "</a>"; } ?> </strong> <div class='row-actions' style="visibility:visible;"> <?php if (mc_can_edit_event($event->event_author)) { ?> <a href="<?php echo admin_url("admin.php?page=my-calendar&mode=edit&event_id={$event->event_id}"); ?> " class='edit'><?php _e('Edit Event', 'my-calendar'); ?> </a> | <?php if (mc_event_is_grouped($event->event_group_id)) { ?> <a href="<?php echo admin_url("admin.php?page=my-calendar-groups&mode=edit&event_id={$event->event_id}&group_id={$event->event_group_id}"); ?> " class='edit group'><?php _e('Edit Group', 'my-calendar'); ?> </a> <?php } else { ?> <em><?php _e('Ungrouped', 'my-calendar'); ?> </em> <?php } } else { _e("Not editable.", 'my-calendar'); } ?> </div> </td> <td><?php echo stripslashes($event->event_label); ?> </td> <?php if ($event->event_time != "00:00:00") { $eventTime = date_i18n(get_option('mc_time_format'), strtotime($event->event_time)); } else { $eventTime = get_option('mc_notime_text'); } ?> <td><?php echo "{$event->event_begin}<br />{$eventTime}"; ?> </td> <td> <?php $recurs = str_split($event->event_recur, 1); $recur = $recurs[0]; $every = isset($recurs[1]) ? $recurs[1] : 1; // Interpret the DB values into something human readable if ($recur == 'S') { _e('Never', 'my-calendar'); } else { if ($recur == 'D') { _e('Daily', 'my-calendar'); } else { if ($recur == 'E') { _e('Weekdays', 'my-calendar'); } else { if ($recur == 'W') { _e('Weekly', 'my-calendar'); } else { if ($recur == 'B') { _e('Bi-Weekly', 'my-calendar'); } else { if ($recur == 'M') { _e('Monthly (by date)', 'my-calendar'); } else { if ($recur == 'U') { _e('Monthly (by day)', 'my-calendar'); } else { if ($recur == 'Y') { _e('Yearly', 'my-calendar'); } } } } } } } } ?> –<?php if ($recur == 'S') { _e('N/A', 'my-calendar'); } else { if (mc_event_repeats_forever($recur, $event->event_repeats)) { _e('Forever', 'my-calendar'); } else { if ($event->event_repeats > 0) { printf(__('%d Times', 'my-calendar'), $event->event_repeats); } } } ?> </td> <td><?php echo is_object($author) ? $author->display_name : $author; ?> </td> <?php $this_category = $event->event_category; foreach ($categories as $key => $value) { if ($value->category_id == $this_category) { $this_cat = $categories[$key]; } } ?> <td><div class="category-color" style="background-color:<?php echo strpos($this_cat->category_color, '#') !== 0 ? '#' : ''; echo $this_cat->category_color; ?> ;"> </div> <?php echo stripslashes($this_cat->category_name); ?> </td> <?php unset($this_cat); ?> </tr><?php } ?> </table> <div class="inside"> <p> <input type="submit" class="button-secondary group" value="<?php _e('Group checked events for mass editing', 'my-calendar'); ?> " /> </p> </div> </form><?php } else { ?> <div class="inside"><p><?php _e("There are no events in the database!", 'my-calendar'); ?> </p></div><?php } }
function mc_check_data($action, $post, $i) { $post = apply_filters('mc_pre_checkdata', $post, $action, $i); global $wpdb, $current_user, $users_entries; $mcdb = $wpdb; $submit = array(); $errors = ''; $every = $recur = $events_access = $begin = $end = $short = $time = $endtime = $event_label = $event_street = $event_street2 = $event_city = $event_state = $event_postcode = $event_region = $event_country = $event_url = $event_image = $event_phone = $event_phone2 = $event_access = $event_tickets = $event_registration = $event_author = $category = $expires = $event_zoom = $event_open = $event_group = $approved = $host = $event_fifth_week = $event_holiday = $event_group_id = $event_span = $event_hide_end = $event_longitude = $event_latitude = ''; if (get_magic_quotes_gpc()) { $post = array_map('stripslashes_deep', $post); } if (!wp_verify_nonce($post['event_nonce_name'], 'event_nonce')) { return array(); } if ($action == 'add' || $action == 'edit' || $action == 'copy') { $title = !empty($post['event_title']) ? trim($post['event_title']) : ''; $desc = !empty($post['content']) ? trim($post['content']) : ''; $short = !empty($post['event_short']) ? trim($post['event_short']) : ''; $recur = !empty($post['event_recur']) ? trim($post['event_recur']) : ''; $every = !empty($post['event_every']) ? (int) $post['event_every'] : 1; // if this is an all weekdays event, and it's been scheduled to start on a weekend, the math gets nasty. // ...AND there's no reason to allow it, since weekday events will NEVER happen on the weekend. $begin = trim($post['event_begin'][$i]); $end = !empty($post['event_end']) ? trim($post['event_end'][$i]) : $post['event_begin'][$i]; if ($recur == 'E' && (date('w', strtotime($begin)) == 0 || date('w', strtotime($begin)) == 6)) { if (date('w', strtotime($begin)) == 0) { $newbegin = my_calendar_add_date($begin, 1); if (!empty($post['event_end'][$i])) { $newend = my_calendar_add_date($end, 1); } else { $newend = $newbegin; } } else { if (date('w', strtotime($begin)) == 6) { $newbegin = my_calendar_add_date($begin, 2); if (!empty($post['event_end'][$i])) { $newend = my_calendar_add_date($end, 2); } else { $newend = $newbegin; } } } $begin = $newbegin; $end = $newend; } else { $begin = !empty($post['event_begin'][$i]) ? trim($post['event_begin'][$i]) : ''; $end = !empty($post['event_end'][$i]) ? trim($post['event_end'][$i]) : $begin; } $begin = date('Y-m-d', strtotime($begin)); // regardless of entry format, convert. $time = !empty($post['event_time'][$i]) ? trim($post['event_time'][$i]) : ''; if ($time != '') { $endtime = !empty($post['event_endtime'][$i]) ? trim($post['event_endtime'][$i]) : date('H:i:s', strtotime($time . ' +1 hour')); } else { $endtime = !empty($post['event_endtime'][$i]) ? trim($post['event_endtime'][$i]) : ''; } $time = $time == '' || $time == '00:00:00' ? '00:00:00' : $time; // set at midnight if not provided $endtime = $endtime == '' && $time == '00:00:00' ? '23:59:59' : $endtime; // set at end of night if np // prevent setting enddate to incorrect value on copy. if (strtotime($end) < strtotime($begin) && $action == 'copy') { $end = date('Y-m-d', strtotime($begin) + (strtotime($post['prev_event_end']) - strtotime($post['prev_event_begin']))); } if (isset($post['event_allday']) && (int) $post['event_allday'] !== 0) { $time = '00:00:00'; $endtime = '23:59:59'; } // verify formats $time = date('H:i:s', strtotime($time)); $endtime = date('H:i:s', strtotime($endtime)); $end = date('Y-m-d', strtotime($end)); // regardless of entry format, convert. $repeats = isset($post['event_repeats']) ? trim($post['event_repeats']) : 0; $host = !empty($post['event_host']) ? $post['event_host'] : $current_user->ID; $category = isset($post['event_category']) && is_numeric($post['event_category']) ? $post['event_category'] : 1; $event_author = isset($post['event_author']) && is_numeric($post['event_author']) ? $post['event_author'] : 0; $event_link = !empty($post['event_link']) ? trim($post['event_link']) : ''; $expires = !empty($post['event_link_expires']) ? $post['event_link_expires'] : '0'; $approved = !empty($post['event_approved']) ? $post['event_approved'] : '0'; $location_preset = !empty($post['location_preset']) ? $post['location_preset'] : ''; $event_open = isset($post['event_open']) && $post['event_open'] !== 0 ? $post['event_open'] : '2'; $event_tickets = isset($post['event_tickets']) ? trim($post['event_tickets']) : ''; $event_registration = isset($post['event_registration']) ? trim($post['event_registration']) : ''; $event_group = !empty($post['event_group']) ? 1 : 0; $event_image = isset($post['event_image']) ? esc_url_raw($post['event_image']) : ''; $event_fifth_week = !empty($post['event_fifth_week']) ? 1 : 0; $event_holiday = !empty($post['event_holiday']) ? 1 : 0; // get group id: if multiple events submitted, auto group OR if event being submitted is already part of a group; otherwise zero. $group_id_submitted = (int) $post['event_group_id']; $event_group_id = is_array($post['event_begin']) && count($post['event_begin']) > 1 || mc_event_is_grouped($group_id_submitted) ? $group_id_submitted : 0; $event_span = !empty($post['event_span']) && $event_group_id != 0 ? 1 : 0; $event_hide_end = !empty($post['event_hide_end']) ? (int) $post['event_hide_end'] : 0; $event_hide_end = $time == '' || $time == '23:59:59' ? 1 : $event_hide_end; // hide end time automatically on all day events // set location if ($location_preset != 'none' && is_numeric($location_preset)) { $sql = "SELECT * FROM " . my_calendar_locations_table() . " WHERE location_id = {$location_preset}"; $location = $mcdb->get_row($sql); $event_label = $location->location_label; $event_street = $location->location_street; $event_street2 = $location->location_street2; $event_city = $location->location_city; $event_state = $location->location_state; $event_postcode = $location->location_postcode; $event_region = $location->location_region; $event_country = $location->location_country; $event_url = $location->location_url; $event_longitude = $location->location_longitude; $event_latitude = $location->location_latitude; $event_zoom = $location->location_zoom; $event_phone = $location->location_phone; $event_phone2 = $location->location_phone2; $event_access = $location->location_access; } else { $event_label = !empty($post['event_label']) ? $post['event_label'] : ''; $event_street = !empty($post['event_street']) ? $post['event_street'] : ''; $event_street2 = !empty($post['event_street2']) ? $post['event_street2'] : ''; $event_city = !empty($post['event_city']) ? $post['event_city'] : ''; $event_state = !empty($post['event_state']) ? $post['event_state'] : ''; $event_postcode = !empty($post['event_postcode']) ? $post['event_postcode'] : ''; $event_region = !empty($post['event_region']) ? $post['event_region'] : ''; $event_country = !empty($post['event_country']) ? $post['event_country'] : ''; $event_url = !empty($post['event_url']) ? $post['event_url'] : ''; $event_longitude = !empty($post['event_longitude']) ? $post['event_longitude'] : ''; $event_latitude = !empty($post['event_latitude']) ? $post['event_latitude'] : ''; $event_zoom = !empty($post['event_zoom']) ? $post['event_zoom'] : ''; $event_phone = !empty($post['event_phone']) ? $post['event_phone'] : ''; $event_phone2 = !empty($post['event_phone2']) ? $post['event_phone2'] : ''; $event_access = !empty($post['event_access']) ? $post['event_access'] : ''; $event_access = !empty($post['event_access_hidden']) ? unserialize($post['event_access_hidden']) : $event_access; if (isset($post['mc_copy_location']) && $post['mc_copy_location'] == 'on' && $i == 0) { // only the first event, if adding multiples. $add_loc = array('location_label' => $event_label, 'location_street' => $event_street, 'location_street2' => $event_street2, 'location_city' => $event_city, 'location_state' => $event_state, 'location_postcode' => $event_postcode, 'location_region' => $event_region, 'location_country' => $event_country, 'location_url' => $event_url, 'location_longitude' => $event_longitude, 'location_latitude' => $event_latitude, 'location_zoom' => $event_zoom, 'location_phone' => $event_phone, 'location_phone2' => $event_phone2, 'location_access' => is_array($event_access) ? serialize($event_access) : ''); $add_loc = array_map('mc_kses_post', $add_loc); $loc_formats = array('%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%f', '%f', '%d', '%s', '%s', '%s'); $mcdb->insert(my_calendar_locations_table(), $add_loc, $loc_formats); } } // Perform validation on the submitted dates - checks for valid years and months if (mc_checkdate($begin) && mc_checkdate($end)) { // Make sure dates are equal or end date is later than start date if (strtotime("{$end} {$endtime}") < strtotime("{$begin} {$time}")) { $errors .= "<div class='error'><p><strong>" . __('Error', 'my-calendar') . ":</strong> " . __('Your event end date must be either after or the same as your event begin date', 'my-calendar') . "</p></div>"; } } else { $errors .= "<div class='error'><p><strong>" . __('Error', 'my-calendar') . ":</strong> " . __('Your date formatting is correct but one or more of your dates is invalid. Check for number of days in month and leap year related errors.', 'my-calendar') . "</p></div>"; } // We check for a valid time, or an empty one $time = $time == '' ? '23:59:59' : date('H:i:00', strtotime($time)); $time_format_one = '/^([0-1][0-9]):([0-5][0-9]):([0-5][0-9])$/'; $time_format_two = '/^([2][0-3]):([0-5][0-9]):([0-5][0-9])$/'; if (preg_match($time_format_one, $time) || preg_match($time_format_two, $time) || $time == '') { } else { $errors .= "<div class='error'><p><strong>" . __('Error', 'my-calendar') . ":</strong> " . __('The time field must either be blank or be entered in the format hh:mm am/pm', 'my-calendar') . "</p></div>"; } // We check for a valid end time, or an empty one if (preg_match($time_format_one, $endtime) || preg_match($time_format_two, $endtime) || $endtime == '') { } else { $errors .= "<div class='error'><p><strong>" . __('Error', 'my-calendar') . ":</strong> " . __('The end time field must either be blank or be entered in the format hh:mm am/pm', 'my-calendar') . "</p></div>"; } // We check to make sure the URL is acceptable (blank or starting with http://) if (!($event_link == '' || preg_match('/^(http)(s?)(:)\\/\\//', $event_link))) { $event_link = "http://" . $event_link; } } // A title is required, and can't be more than 255 characters. $title_length = strlen($title); if (!($title_length >= 1 && $title_length <= 255)) { $title = __('Untitled Event', 'my-calendar'); } // Run checks on recurrence profile if ($repeats == 0 && $recur == 'S' || $repeats >= 0 && ($recur == 'W' || $recur == 'B' || $recur == 'M' || $recur == 'U' || $recur == 'Y' || $recur == 'D' || $recur == 'E')) { $recur = $recur . $every; } else { // if it's not valid, assign a default value. $repeats = 0; $recur = 'S1'; } if (function_exists('mcs_submissions') && isset($post['mcs_check_conflicts'])) { $conflicts = mcs_check_conflicts($begin, $time, $end, $endtime, $event_label); if ($conflicts) { $errors .= "<div class='error'><p><strong>" . __('Error', 'my-calendar') . ":</strong> " . __('That event conflicts with a previously scheduled event.', 'my-calendar') . "</p></div>"; } } $spam = mc_spam($event_link, $desc, $post); // the likelihood that something will be both flagged as spam and have a zero start time // and yet be legitimate is crazy minimal. Just kill it. if ($spam == 1 && $begin == '1970-01-01') { die; } if ($errors == '') { $current_user = wp_get_current_user(); $event_author = $event_author == $current_user->ID || current_user_can('mc_manage_events') ? $event_author : $current_user->ID; $event_category = !$category ? 1 : $category; $ok = true; $submit = array('event_begin' => $begin, 'event_end' => $end, 'event_title' => $title, 'event_desc' => force_balance_tags($desc), 'event_short' => force_balance_tags($short), 'event_time' => $time, 'event_endtime' => $endtime, 'event_link' => $event_link, 'event_label' => $event_label, 'event_street' => $event_street, 'event_street2' => $event_street2, 'event_city' => $event_city, 'event_state' => $event_state, 'event_postcode' => $event_postcode, 'event_region' => $event_region, 'event_country' => $event_country, 'event_url' => $event_url, 'event_recur' => $recur, 'event_image' => $event_image, 'event_phone' => $event_phone, 'event_phone2' => $event_phone2, 'event_access' => is_array($event_access) ? serialize($event_access) : '', 'event_tickets' => $event_tickets, 'event_registration' => $event_registration, 'event_repeats' => $repeats, 'event_author' => $event_author, 'event_category' => $event_category, 'event_link_expires' => $expires, 'event_zoom' => $event_zoom, 'event_open' => $event_open, 'event_group' => $event_group, 'event_approved' => $approved, 'event_host' => $host, 'event_flagged' => $spam, 'event_fifth_week' => $event_fifth_week, 'event_holiday' => $event_holiday, 'event_group_id' => $event_group_id, 'event_span' => $event_span, 'event_hide_end' => $event_hide_end, 'event_longitude' => $event_longitude, 'event_latitude' => $event_latitude); $submit = array_map('mc_kses_post', $submit); } else { $ok = false; $event_access = is_array($event_access) ? serialize($event_access) : ''; // The form is going to be rejected due to field validation issues, so we preserve the users entries here // all submitted data should be in this object, regardless of data destination. $users_entries = !is_object($users_entries) ? new stdClass() : $users_entries; $users_entries->event_id = isset($_GET['event_id']) && is_numeric($_GET['event_id']) ? $_GET['event_id'] : false; $users_entries->event_title = $title; $users_entries->event_desc = $desc; $users_entries->event_begin = $begin; $users_entries->event_end = $end; $users_entries->event_time = $time; $users_entries->event_endtime = $endtime; $users_entries->event_recur = $recur; $users_entries->event_repeats = $repeats; $users_entries->event_host = $host; $users_entries->event_category = $category; $users_entries->event_link = $event_link; $users_entries->event_link_expires = $expires; $users_entries->event_label = $event_label; $users_entries->event_street = $event_street; $users_entries->event_street2 = $event_street2; $users_entries->event_city = $event_city; $users_entries->event_state = $event_state; $users_entries->event_postcode = $event_postcode; $users_entries->event_country = $event_country; $users_entries->event_region = $event_region; $users_entries->event_url = $event_url; $users_entries->event_longitude = $event_longitude; $users_entries->event_latitude = $event_latitude; $users_entries->event_zoom = $event_zoom; $users_entries->event_phone = $event_phone; $users_entries->event_phone2 = $event_phone2; $users_entries->event_author = $event_author; $users_entries->event_open = $event_open; $users_entries->event_short = $short; $users_entries->event_group = $event_group; $users_entries->event_approved = $approved; $users_entries->event_image = $event_image; $users_entries->event_fifth_week = $event_fifth_week; $users_entries->event_holiday = $event_holiday; $users_entries->event_flagged = 0; $users_entries->event_group_id = $event_group_id; $users_entries->event_span = $event_span; $users_entries->event_hide_end = $event_hide_end; $users_entries->event_access = $event_access; $users_entries->events_access = serialize($events_access); $users_entries->event_tickets = $event_tickets; $users_entries->event_registration = $event_registration; } $data = array($ok, $users_entries, $submit, $errors); return $data; }