File: /datos/www/expodubai/wp-content/plugins/modern-events-calendar-lite/app/features/ix.php
<?php
/** no direct access **/
defined('MECEXEC') or die();
/**
* Webnus MEC Import / Export class. Requires PHP >= 5.3 otherwise it don't activate
* @author Webnus <[email protected]>
*/
class MEC_feature_ix extends MEC_base
{
public $factory;
public $main;
public $db;
public $action;
public $ix;
public $response;
/**
* Facebook App Access Token
* @var string
*/
private $fb_access_token = '';
/**
* Constructor method
* @author Webnus <[email protected]>
*/
public function __construct()
{
// Import MEC Factory
$this->factory = $this->getFactory();
// Import MEC Main
$this->main = $this->getMain();
// Import MEC DB
$this->db = $this->getDB();
}
/**
* Initialize IX feature
* @author Webnus <[email protected]>
*/
public function init()
{
// Disable Import / Export Feature if autoload feature is not exists
if(!function_exists('spl_autoload_register')) return;
$this->factory->action('admin_menu', array($this, 'menus'), 20);
// Import APIs
$this->factory->action('init', array($this, 'include_google_api'));
$this->factory->action('init', array($this, 'include_facebook_api'));
$this->factory->action('init', array($this, 'include_meetup_api'));
// MEC IX Action
$mec_ix_action = isset($_GET['mec-ix-action']) ? sanitize_text_field($_GET['mec-ix-action']) : '';
// Export All Events
if($mec_ix_action == 'export-events') $this->factory->action('init', array($this, 'export_all_events_do'), 9999);
elseif($mec_ix_action == 'export-bookings') $this->factory->action('init', array($this, 'export_all_bookings_do'), 9999);
elseif($mec_ix_action == 'google-calendar-export-get-token') $this->factory->action('init', array($this, 'g_calendar_export_get_token'), 9999);
// AJAX Actions
$this->factory->action('wp_ajax_mec_ix_add_to_g_calendar', array($this, 'g_calendar_export_do'));
$this->factory->action('wp_ajax_mec_ix_g_calendar_authenticate', array($this, 'g_calendar_export_authenticate'));
// Import XML File
$this->factory->action('mec_import_file', array($this, 'import_do'));
}
/**
* Import Google API libraries
* @author Webnus <[email protected]>
*/
public function include_google_api()
{
if(class_exists('Google_Service_Calendar')) return;
MEC::import('app.api.Google.autoload', false);
}
/**
* Import Facebook API libraries
* @author Webnus <[email protected]>
*/
public function include_facebook_api()
{
}
/**
* Import Meetup API libraries
* @author Webnus <[email protected]>
*/
public function include_meetup_api()
{
if(class_exists('Meetup')) return;
MEC::import('app.api.Meetup.meetup', false);
}
/**
* Add the IX menu
* @author Webnus <[email protected]>
*/
public function menus()
{
add_submenu_page('mec-intro', __('MEC - Import / Export', 'modern-events-calendar-lite'), __('Import / Export', 'modern-events-calendar-lite'), 'mec_import_export', 'MEC-ix', array($this, 'ix'));
}
/**
* Show content of Import Import / Export Menu
* @author Webnus <[email protected]>
* @return void
*/
public function ix()
{
$tab = isset($_GET['tab']) ? sanitize_text_field($_GET['tab']) : '';
if($tab == 'MEC-export') $this->ix_export();
elseif($tab == 'MEC-sync') $this->ix_sync();
elseif($tab == 'MEC-g-calendar-export') $this->ix_g_calendar_export();
elseif($tab == 'MEC-f-calendar-import') $this->ix_f_calendar_import();
elseif($tab == 'MEC-meetup-import') $this->ix_meetup_import();
elseif($tab == 'MEC-import') $this->ix_import();
elseif($tab == 'MEC-thirdparty') $this->ix_thirdparty();
else $this->ix_g_calendar_import();
}
/**
* Show content of export tab
* @author Webnus <[email protected]>
* @return void
*/
public function ix_export()
{
$path = MEC::import('app.features.ix.export', true, true);
ob_start();
include $path;
echo $output = ob_get_clean();
}
/**
* Show content of export tab
* @author Webnus <[email protected]>
* @return void
*/
public function ix_sync()
{
// Current Action
$this->action = isset($_POST['mec-ix-action']) ? sanitize_text_field($_POST['mec-ix-action']) : '';
$this->ix = isset($_POST['ix']) ? $_POST['ix'] : array();
if($this->action == 'save-sync-options')
{
// Save options
$this->main->save_ix_options(array(
'sync_g_import'=>isset($this->ix['sync_g_import']) ? $this->ix['sync_g_import'] : 0,
'sync_g_import_auto'=>isset($this->ix['sync_g_import_auto']) ? $this->ix['sync_g_import_auto'] : 0,
'sync_g_export'=>isset($this->ix['sync_g_export']) ? $this->ix['sync_g_export'] : 0,
'sync_g_export_auto'=>isset($this->ix['sync_g_export_auto']) ? $this->ix['sync_g_export_auto'] : 0,
'sync_g_export_attendees'=>isset($this->ix['sync_g_export_attendees']) ? $this->ix['sync_g_export_attendees'] : 0,
'sync_f_import'=>isset($this->ix['sync_f_import']) ? $this->ix['sync_f_import'] : 0,
'sync_meetup_import'=>isset($this->ix['sync_meetup_import']) ? $this->ix['sync_meetup_import'] : 0,
'sync_meetup_import_auto'=>isset($this->ix['sync_meetup_import_auto']) ? $this->ix['sync_meetup_import_auto'] : 0,
));
}
$path = MEC::import('app.features.ix.sync', true, true);
ob_start();
include $path;
echo $output = ob_get_clean();
}
/**
* Show content of import tab
* @author Webnus <[email protected]>
* @return void
*/
public function ix_import()
{
// Current Action
$this->action = isset($_POST['mec-ix-action']) ? sanitize_text_field($_POST['mec-ix-action']) : '';
$this->ix = isset($_POST['ix']) ? $_POST['ix'] : array();
$this->response = array();
$nonce = (isset($_POST['_wpnonce']) ? $_POST['_wpnonce'] : '');
if(wp_verify_nonce($nonce, 'mec_import_start_upload'))
{
if(in_array($this->action, array('import-start-xml', 'import-start-ics'))) $this->response = $this->import_start();
elseif($this->action == 'import-start-bookings') $this->response = $this->import_start_bookings();
elseif(!empty($this->action)) $this->response = apply_filters('mec_import_item_action', $this->action);
}
$path = MEC::import('app.features.ix.import', true, true);
ob_start();
include $path;
echo $output = ob_get_clean();
}
public function import_start_bookings()
{
$feed_file = $_FILES['feed'];
// File is not uploaded
if(!isset($feed_file['name']) or (isset($feed_file['name']) and trim($feed_file['name']) == '')) return array('success' => 0, 'message' => __('Please upload a CSV file.', 'modern-events-calendar-lite'));
// File name validation
$name_ex = explode('.', $feed_file['name']);
$name_end = end($name_ex);
if($name_end != 'csv') return array('success' => 0, 'message' => __('Please upload a CSV file.', 'modern-events-calendar-lite'));
// Upload the File
$upload_dir = wp_upload_dir();
$target_path = $upload_dir['basedir'].'/'.basename($feed_file['name']);
$uploaded = move_uploaded_file($feed_file['tmp_name'], $target_path);
// Error on Upload
if(!$uploaded) return array('success' => 0, 'message' => __("An error occurred during the file upload! Please check permissions!", 'modern-events-calendar-lite'));
if($type = mime_content_type($target_path) and $type == 'text/x-php')
{
unlink($target_path);
return array('success' => 0, 'message' => __("Please upload a CSV file.", 'modern-events-calendar-lite'));
}
$bookings = array();
if(($h = fopen($target_path, 'r')) !== false)
{
// MEC Libraries
$gateway = new MEC_gateway();
$book = $this->getBook();
$r = 0;
while(($data = fgetcsv($h, 1000, ",")) !== false)
{
$r++;
$booking_id = $data[0];
if($r === 1 and !is_numeric($booking_id)) continue;
$event_title = $data[1];
$event_id = post_exists($event_title, '', '', $this->main->get_main_post_type());
// Event not Found
if(!$event_id) continue;
$tickets = get_post_meta($event_id, 'mec_tickets', true);
if(!is_array($tickets)) $tickets = array();
$ticket_id = NULL;
$ticket_name = $data[5];
foreach($tickets as $tid => $ticket)
{
if(strtolower($ticket['name']) == strtolower($ticket_name))
{
$ticket_id = $tid;
break;
}
}
// Ticket ID not found!
if(is_null($ticket_id)) continue;
$transaction_id = $data[6];
// Transaction Exists
$transaction_exists = $book->get_transaction($transaction_id);
if(is_array($transaction_exists) and count($transaction_exists)) continue;
$start_datetime = $data[2];
$end_datetime = $data[3];
$name = $data[9];
$email = $data[10];
$confirmed_label = $data[12];
if($confirmed_label == __('Confirmed', 'modern-events-calendar-lite')) $confirmed = 1;
elseif($confirmed_label == __('Rejected', 'modern-events-calendar-lite')) $confirmed = -1;
else $confirmed = 0;
$verified_label = $data[13];
if($verified_label == __('Verified', 'modern-events-calendar-lite')) $verified = 1;
elseif($verified_label == __('Canceled', 'modern-events-calendar-lite')) $verified = -1;
else $verified = 0;
$ticket_variations = explode(',', $data[11]);
$variations = $this->main->ticket_variations($event_id, $ticket_id);
$v = array();
foreach($variations as $vid => $variation)
{
foreach($ticket_variations as $ticket_variation)
{
$variation_ex = explode(':', $ticket_variation);
if(!isset($variation_ex[1])) continue;
$variation_name = $variation_ex[0];
$variation_count = trim($variation_ex[1], '() ');
if(strtolower($variation['title']) == strtolower($variation_name))
{
$v[$vid] = $variation_count;
}
}
}
if(!isset($bookings[$transaction_id])) $bookings[$transaction_id] = array('tickets' => array());
$bookings[$transaction_id]['tickets'][] = array(
'email' => $email,
'name' => $name,
'variations' => $v,
'id' => $ticket_id,
'count' => 1
);
if(!isset($bookings[$transaction_id]['date'])) $bookings[$transaction_id]['date'] = strtotime($start_datetime).':'.strtotime($end_datetime);
if(!isset($bookings[$transaction_id]['event_id'])) $bookings[$transaction_id]['event_id'] = $event_id;
if(!isset($bookings[$transaction_id]['confirmed'])) $bookings[$transaction_id]['confirmed'] = $confirmed;
if(!isset($bookings[$transaction_id]['verified'])) $bookings[$transaction_id]['verified'] = $verified;
}
fclose($h);
// MEC User
$u = $this->getUser();
foreach($bookings as $transaction_id => $transaction)
{
$event_id = $transaction['event_id'];
$tickets = $transaction['tickets'];
$event_tickets = get_post_meta($event_id, 'mec_tickets', true);
if(!is_array($event_tickets)) $event_tickets = array();
$raw_tickets = array();
$raw_variations = array();
foreach($tickets as $ticket)
{
if(!isset($raw_tickets[$ticket['id']])) $raw_tickets[$ticket['id']] = 1;
else $raw_tickets[$ticket['id']] += 1;
if(isset($ticket['variations']) and is_array($ticket['variations']) and count($ticket['variations']))
{
foreach($ticket['variations'] as $variation_id => $variation_count)
{
if(!trim($variation_count)) continue;
if(!isset($raw_variations[$variation_id])) $raw_variations[$variation_id] = $variation_count;
else $raw_variations[$variation_id] += $variation_count;
}
}
}
// Calculate price of bookings
$price_details = $book->get_price_details($raw_tickets, $event_id, $event_tickets, $raw_variations);
$transaction['price_details'] = $price_details;
$transaction['total'] = $price_details['total'];
$transaction['discount'] = 0;
$transaction['price'] = $price_details['total'];
$transaction['coupon'] = NULL;
update_option($transaction_id, $transaction, false);
$attendees = isset($transaction['tickets']) ? $transaction['tickets'] : array();
$attention_date = isset($transaction['date']) ? $transaction['date'] : '';
$attention_times = explode(':', $attention_date);
$date = date('Y-m-d H:i:s', trim($attention_times[0]));
$main_attendee = isset($attendees[0]) ? $attendees[0] : array();
$name = isset($main_attendee['name']) ? $main_attendee['name'] : '';
$ticket_ids = '';
$attendees_info = array();
foreach($attendees as $i => $attendee)
{
if(!is_numeric($i)) continue;
$ticket_ids .= $attendee['id'] . ',';
if(!array_key_exists($attendee['email'], $attendees_info)) $attendees_info[$attendee['email']] = array('count' => $attendee['count']);
else $attendees_info[$attendee['email']]['count'] = ($attendees_info[$attendee['email']]['count'] + $attendee['count']);
}
$ticket_ids = ',' . trim($ticket_ids, ', ') . ',';
$user_id = $gateway->register_user($main_attendee);
$book_subject = $name.' - '.$u->get($user_id)->user_email;
$book_id = $book->add(
array(
'post_author' => $user_id,
'post_type' => $this->main->get_book_post_type(),
'post_title' => $book_subject,
'post_date' => $date,
'attendees_info' => $attendees_info,
'mec_attendees' => $attendees
),
$transaction_id,
$ticket_ids
);
// Assign User
$u->assign($book_id, $user_id);
update_post_meta($book_id, 'mec_gateway', 'MEC_gateway');
update_post_meta($book_id, 'mec_gateway_label', $gateway->title());
update_post_meta($book_id, 'mec_confirmed', $transaction['confirmed']);
update_post_meta($book_id, 'mec_verified', $transaction['verified']);
}
}
// Delete File
unlink($target_path);
return array('success' => (count($bookings) ? 1 : 0), 'message' => (count($bookings) ? __('The bookings are imported successfully!', 'modern-events-calendar-lite') : __('No bookings found to import!', 'modern-events-calendar-lite')));
}
public function import_start()
{
$feed_file = $_FILES['feed'];
// File is not uploaded
if(!isset($feed_file['name']) or (isset($feed_file['name']) and trim($feed_file['name']) == '')) return array('success' => 0, 'message' => __('Please upload the feed file.', 'modern-events-calendar-lite'));
// File name validation
$ex = explode('.', $feed_file['name']);
$name_end = end($ex);
if(!in_array($name_end, array('xml', 'ics'))) return array('success' => 0, 'message' => __('Please upload an XML or an ICS file.', 'modern-events-calendar-lite'));
// File Type is not valid
if(!isset($feed_file['type']) or (isset($feed_file['type']) and !in_array(strtolower($feed_file['type']), array('text/xml', 'text/calendar')))) return array('success' => 0, 'message' => __('The file type should be XML or ICS.', 'modern-events-calendar-lite'));
// Upload the File
$upload_dir = wp_upload_dir();
$target_path = $upload_dir['basedir'].'/'.basename($feed_file['name']);
$uploaded = move_uploaded_file($feed_file['tmp_name'], $target_path);
// Error on Upload
if(!$uploaded) return array('success' => 0, 'message' => __("An error occurred during the file upload! Please check permissions!", 'modern-events-calendar-lite'));
if($type = mime_content_type($target_path) and $type == 'text/x-php')
{
unlink($target_path);
return array('success' => 0, 'message' => __("Please upload an XML or an ICS file.", 'modern-events-calendar-lite'));
}
// Import
do_action('mec_import_file', $target_path);
// Delete File
unlink($target_path);
return array('success' => 1, 'message' => __('The events are imported successfully!', 'modern-events-calendar-lite'));
}
public function import_do($feed)
{
// Increase the resources
@ini_set('memory_limit', '1024M');
@ini_set('max_execution_time', 300);
do_action('mec_custom_max_execution');
$file = $this->getFile();
$extension = $file->getExt($feed);
/**
* @var MEC_db
*/
$db = $this->getDB();
/**
* @var MEC_main
*/
$main = $this->getMain();
// WP Upload Path
$wp_upload_dir = wp_upload_dir();
$posts = array();
if(strtolower($extension) == 'xml')
{
$xml_string = str_replace(':i:', 'iii', $file->read($feed));
$xml_string = str_replace(':fi:', 'fif', $xml_string);
$XML = simplexml_load_string($xml_string);
if($XML === false) return false;
foreach($XML->children() as $event)
{
$feed_event_id = (int) $event->ID;
// Event Data
$meta = $event->meta;
$mec = $event->mec;
// Event location
$location = ($event->locations ? $event->locations->item[0] : NULL);
$location_id = ($location and isset($location->name)) ? $main->save_location(array
(
'name'=>trim((string) $location->name),
'address'=>(string) $location->address,
'latitude'=>(string) $location->latitude,
'longitude'=>(string) $location->longitude,
'thumbnail'=>(string) $location->thumbnail
)) : 1;
// Event Organizer
$organizer = ($event->organizers ? $event->organizers->item[0] : NULL);
$organizer_id = ($organizer and isset($organizer->name)) ? $main->save_organizer(array
(
'name'=>trim((string) $organizer->name),
'email'=>(string) $organizer->email,
'tel'=>(string) $organizer->tel,
'url'=>(string) $organizer->url,
'thumbnail'=>(string) $organizer->thumbnail
)) : 1;
// Event Categories
$category_ids = array();
if(isset($event->categories))
{
foreach($event->categories->children() as $category)
{
$category_id = $main->save_category(array
(
'name'=>trim((string) $category->name),
));
if($category_id) $category_ids[] = $category_id;
}
}
// Event Tags
$tag_ids = array();
if(isset($event->tags))
{
foreach($event->tags->children() as $tag)
{
$tag_id = $main->save_tag(array
(
'name'=>trim((string) $tag->name),
));
if($tag_id) $tag_ids[] = $tag_id;
}
}
// Event Labels
$label_ids = array();
if(isset($event->labels))
{
foreach($event->labels->children() as $label)
{
$label_id = $main->save_label(array
(
'name'=>trim((string) $label->name),
'color'=>(string) $label->color,
));
if($label_id) $label_ids[] = $label_id;
}
}
// Event Speakers
$speaker_ids = array();
if(isset($event->speakers))
{
foreach($event->speakers->children() as $speaker)
{
$speaker_id = $main->save_speaker(array
(
'name'=>trim((string) $speaker->name),
'job_title'=>(string) (isset($speaker->job_title) ? $speaker->job_title : ''),
'tel'=>(string) (isset($speaker->tel) ? $speaker->tel : ''),
'email'=>(string) (isset($speaker->email) ? $speaker->email : ''),
'facebook'=>(string) (isset($speaker->facebook) ? $speaker->facebook : ''),
'twitter'=>(string) (isset($speaker->twitter) ? $speaker->twitter : ''),
'instagram'=>(string) (isset($speaker->instagram) ? $speaker->instagram : ''),
'linkedin'=>(string) (isset($speaker->linkedin) ? $speaker->linkedin : ''),
'website'=>(string) (isset($speaker->website) ? $speaker->website : ''),
'thumbnail'=>(string) (isset($speaker->thumbnail) ? $speaker->thumbnail : ''),
));
if($speaker_id) $speaker_ids[] = $speaker_id;
}
}
// Start
$start_date = (string) $meta->mec_date->start->date;
$start_hour = (int) $meta->mec_date->start->hour;
$start_minutes = (int) $meta->mec_date->start->minutes;
$start_ampm = (string) $meta->mec_date->start->ampm;
// End
$end_date = (string) $meta->mec_date->end->date;
$end_hour = (int) $meta->mec_date->end->hour;
$end_minutes = (int) $meta->mec_date->end->minutes;
$end_ampm = (string) $meta->mec_date->end->ampm;
// Time Options
$allday = (string) $meta->mec_date->allday;
$time_comment = (string) $meta->mec_date->comment;
$hide_time = (string) $meta->mec_date->hide_time;
$hide_end_time = (string) $meta->mec_date->hide_end_time;
// Repeat Options
$repeat_status = (int) $meta->mec_repeat_status;
$repeat_type = (string) $meta->mec_repeat_type;
$repeat_interval = (int) $meta->mec_repeat_interval;
$finish = (string) $mec->end;
$year = (string) $mec->year;
$month = (string) $mec->month;
$day = (string) $mec->day;
$week = (string) $mec->week;
$weekday = (string) $mec->weekday;
$weekdays = (string) $mec->weekdays;
$days = (string) $mec->days;
$not_in_days = (string) $mec->not_in_days;
$additional_organizer_ids = array();
if(isset($meta->mec_additional_organizer_ids))
{
foreach($meta->mec_additional_organizer_ids->children() as $o)
{
$additional_organizer_ids[] = (int) $o;
}
}
$hourly_schedules = array();
if(isset($meta->mec_hourly_schedules))
{
foreach($meta->mec_hourly_schedules->children() as $s)
{
$hourly_schedules[] = array
(
'from' => (string) $s->from,
'to' => (string) $s->to,
'title' => (string) $s->title,
'description' => (string) $s->description,
);
}
}
$tickets = array();
if(isset($meta->mec_tickets))
{
foreach($meta->mec_tickets->children() as $t)
{
$tickets[] = array
(
'name' => (string) $t->name,
'description' => (string) $t->description,
'price' => (string) $t->price,
'price_label' => (string) $t->price_label,
'limit' => (int) $t->limit,
'unlimited' => (int) $t->unlimited,
);
}
}
$fees = array();
if(isset($meta->mec_fees))
{
foreach($meta->mec_fees->children() as $f)
{
if($f->getName() !== 'item') continue;
$fees[] = array
(
'title' => (string) $f->title,
'amount' => (string) $f->amount,
'type' => (string) $f->type,
);
}
}
$reg_fields = array();
if(isset($meta->mec_reg_fields))
{
foreach($meta->mec_reg_fields->children() as $r)
{
if($r->getName() !== 'item') continue;
$options = array();
foreach($r->options->children() as $o) $options[] = (string) $o->label;
$reg_fields[] = array
(
'mandatory' => (int) $r->mandatory,
'type' => (string) $r->type,
'label' => (string) $r->label,
'options' => $options,
);
}
}
$advanced_days = array();
if(isset($meta->mec_advanced_days))
{
foreach($meta->mec_advanced_days->children() as $t)
{
$advanced_days[] = (string) $t;
}
}
$args = array
(
'title'=> (string) $event->title,
'content'=> (string) $event->content,
'status'=> (string) ($event->post ? $event->post->post_status : 'publish'),
'location_id'=>$location_id,
'organizer_id'=>$organizer_id,
'date'=>array
(
'start'=>array(
'date'=>$start_date,
'hour'=>$start_hour,
'minutes'=>$start_minutes,
'ampm'=>$start_ampm,
),
'end'=>array(
'date'=>$end_date,
'hour'=>$end_hour,
'minutes'=>$end_minutes,
'ampm'=>$end_ampm,
),
'repeat'=>array(),
'allday'=>$allday,
'comment'=>$time_comment,
'hide_time'=>$hide_time,
'hide_end_time'=>$hide_end_time,
),
'start'=>$start_date,
'start_time_hour'=>$start_hour,
'start_time_minutes'=>$start_minutes,
'start_time_ampm'=>$start_ampm,
'end'=>$end_date,
'end_time_hour'=>$end_hour,
'end_time_minutes'=>$end_minutes,
'end_time_ampm'=>$end_ampm,
'repeat_status'=>$repeat_status,
'repeat_type'=>$repeat_type,
'interval'=>$repeat_interval,
'finish'=>$finish,
'year'=>$year,
'month'=>$month,
'day'=>$day,
'week'=>$week,
'weekday'=>$weekday,
'weekdays'=>$weekdays,
'days'=>$days,
'not_in_days'=>$not_in_days,
'meta'=>array
(
'mec_source'=>'mec-calendar',
'mec_feed_event_id'=>$feed_event_id,
'mec_dont_show_map'=> (int) $meta->mec_dont_show_map,
'mec_color'=> (string) $meta->mec_color,
'mec_read_more'=> (string) $meta->mec_read_more,
'mec_more_info'=> (string) $meta->mec_more_info,
'mec_more_info_title'=> (string) $meta->mec_more_info_title,
'mec_more_info_target'=> (string) $meta->mec_more_info_target,
'mec_cost'=> (string) $meta->mec_cost,
'mec_additional_organizer_ids' =>$additional_organizer_ids,
'mec_repeat'=>array
(
'status' => (int) $meta->mec_repeat->status,
'type' => (string) $meta->mec_repeat->type,
'interval' => (int) $meta->mec_repeat->interval,
'end' => (string) $meta->mec_repeat->end,
'end_at_date' => (string) $meta->mec_repeat->end_at_date,
'end_at_occurrences' => (string) $meta->mec_repeat->end_at_occurrences,
),
'mec_allday'=>$allday,
'mec_hide_time'=>$hide_time,
'mec_hide_end_time'=>$hide_end_time,
'mec_comment'=>$time_comment,
'mec_repeat_end'=> (string) $meta->mec_repeat_end,
'mec_repeat_end_at_occurrences'=> (string) $meta->mec_repeat_end_at_occurrences,
'mec_repeat_end_at_date'=> (string) $meta->mec_repeat_end_at_date,
'mec_in_days'=> (string) $meta->mec_in_days,
'mec_not_in_days'=> (string) $meta->mec_not_in_days,
'mec_hourly_schedules'=>$hourly_schedules,
'mec_booking'=>array
(
'bookings_limit_unlimited' => (int) $meta->mec_booking->bookings_limit_unlimited,
'bookings_limit' => (int) $meta->mec_booking->bookings_limit,
),
'mec_tickets'=>$tickets,
'mec_fees_global_inheritance'=> (int) $meta->mec_fees_global_inheritance,
'mec_fees'=>$fees,
'mec_reg_fields_global_inheritance'=> (int) $meta->mec_reg_fields_global_inheritance,
'mec_reg_fields'=>$reg_fields,
'mec_advanced_days'=>$advanced_days,
)
);
$post_id = $db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$feed_event_id' AND `meta_key`='mec_feed_event_id'", 'loadResult');
// Insert the event into MEC
$post_id = $main->save_event($args, $post_id);
// Add it to the imported posts
$posts[] = $post_id;
// Set location to the post
if($location_id) wp_set_object_terms($post_id, (int) $location_id, 'mec_location');
// Set organizer to the post
if($organizer_id) wp_set_object_terms($post_id, (int) $organizer_id, 'mec_organizer');
// Set categories to the post
if(count($category_ids)) foreach($category_ids as $category_id) wp_set_object_terms($post_id, (int) $category_id, 'mec_category', true);
// Set tags to the post
if(count($tag_ids)) foreach($tag_ids as $tag_id) wp_set_object_terms($post_id, (int) $tag_id, apply_filters('mec_taxonomy_tag', ''), true);
// Set labels to the post
if(count($label_ids)) foreach($label_ids as $label_id) wp_set_object_terms($post_id, (int) $label_id, 'mec_label', true);
// Set speakers to the post
if(count($speaker_ids)) foreach($speaker_ids as $speaker_id) wp_set_object_terms($post_id, (int) $speaker_id, 'mec_speaker', true);
// Featured Image
$featured_image = isset($event->featured_image) ? (string) $event->featured_image->full : '';
if(!has_post_thumbnail($post_id) and trim($featured_image))
{
$file_name = basename($featured_image);
$path = rtrim($wp_upload_dir['path'], DS.' ').DS.$file_name;
$url = rtrim($wp_upload_dir['url'], '/ ').'/'.$file_name;
// Download Image
$buffer = $main->get_web_page($featured_image);
$file->write($path, $buffer);
$main->set_featured_image($url, $post_id);
}
}
}
elseif(strtolower($extension) == 'ics')
{
$parsed = $main->parse_ics($feed);
// Timezone
$timezone = $main->get_timezone();
$events = $parsed->events();
foreach($events as $event)
{
$feed_event_id = $event->uid;
// Event location
$location = $event->location;
$location_id = trim($location) ? $main->save_location(array
(
'name'=>trim((string) $location),
)) : 1;
// Event Organizer
$organizer = isset($event->organizer_array) ? $event->organizer_array : array();
$organizer_id = (isset($organizer[0]) and isset($organizer[0]['CN'])) ? $main->save_organizer(array
(
'name'=>trim((string) $organizer[0]['CN']),
'email'=>(string) str_replace('MAILTO:', '', $organizer[1]),
)) : 1;
// Event Categories
$category_ids = array();
if(isset($event->categories) and trim($event->categories))
{
$cats = explode(',', $event->categories);
foreach($cats as $category)
{
$category_id = $main->save_category(array
(
'name'=>trim((string) $category),
));
if($category_id) $category_ids[] = $category_id;
}
}
$date_start = new DateTime($event->dtstart);
$date_start->setTimezone(new DateTimeZone($timezone));
$start_date = $date_start->format('Y-m-d');
$start_hour = $date_start->format('g');
$start_minutes = $date_start->format('i');
$start_ampm = $date_start->format('A');
$date_end = NULL;
$end_timestamp = isset($event->dtend) ? strtotime($event->dtend) : 0;
if($end_timestamp)
{
$date_end = new DateTime($event->dtend);
$date_end->setTimezone(new DateTimeZone($timezone));
}
$end_date = $end_timestamp ? $date_end->format('Y-m-d') : $start_date;
$end_hour = $end_timestamp ? $date_end->format('g') : 8;
$end_minutes = $end_timestamp ? $date_end->format('i') : '00';
$end_ampm = $end_timestamp ? $date_end->format('A') : 'PM';
// Time Options
$allday = 0;
$time_comment = '';
$hide_time = 0;
$hide_end_time = 0;
// Repeat Options
$repeat_status = 0;
$repeat_type = '';
$repeat_interval = NULL;
$finish = $end_date;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = NULL;
$not_in_days = NULL;
// Recurring Event
$rrule = (isset($event->rrule) and trim($event->rrule)) ? $event->rrule : '';
if(trim($rrule) != '')
{
$ex1 = explode(';', $rrule);
$rule = array();
foreach($ex1 as $r)
{
$ex2 = explode('=', $r);
$rule[strtolower($ex2[0])] = strtolower($ex2[1]);
}
$repeat_status = 1;
if($rule['freq'] == 'daily')
{
$repeat_type = 'daily';
$repeat_interval = isset($rule['interval']) ? $rule['interval'] : 1;
}
elseif($rule['freq'] == 'weekly')
{
$repeat_type = 'weekly';
$repeat_interval = isset($rule['interval']) ? $rule['interval']*7 : 7;
}
elseif($rule['freq'] == 'monthly')
{
$repeat_type = 'monthly';
$year = '*';
$month = '*';
$s = $start_date;
$e = $end_date;
$_days = array();
while(strtotime($s) <= strtotime($e))
{
$_days[] = date('d', strtotime($s));
$s = date('Y-m-d', strtotime('+1 Day', strtotime($s)));
}
$day = ','.implode(',', array_unique($_days)).',';
$week = '*';
$weekday = '*';
}
elseif($rule['freq'] == 'yearly')
{
$repeat_type = 'yearly';
$year = '*';
$s = $start_date;
$e = $end_date;
$_months = array();
$_days = array();
while(strtotime($s) <= strtotime($e))
{
$_months[] = date('m', strtotime($s));
$_days[] = date('d', strtotime($s));
$s = date('Y-m-d', strtotime('+1 Day', strtotime($s)));
}
$month = ','.implode(',', array_unique($_months)).',';
$day = ','.implode(',', array_unique($_days)).',';
$week = '*';
$weekday = '*';
}
else $repeat_type = '';
// Custom Week Days
if($repeat_type == 'weekly' and isset($rule['byday']) and count(explode(',', $rule['byday'])) > 1)
{
$g_week_days = explode(',', $rule['byday']);
$week_day_mapping = array('mo'=>1, 'tu'=>2, 'we'=>3, 'th'=>4, 'fr'=>5, 'sa'=>6, 'su'=>7);
$weekdays = '';
foreach($g_week_days as $g_week_day) $weekdays .= $week_day_mapping[$g_week_day].',';
$weekdays = ','.trim($weekdays, ', ').',';
$interval = NULL;
$repeat_type = 'certain_weekdays';
}
$finish = isset($rule['until']) ? date('Y-m-d', strtotime($rule['until'])) : NULL;
}
$additional_organizer_ids = array();
$hourly_schedules = array();
$tickets = array();
$fees = array();
$reg_fields = array();
$args = array
(
'title'=> (string) $event->summary,
'content'=> (string) $event->description,
'location_id'=>$location_id,
'organizer_id'=>$organizer_id,
'date'=>array
(
'start'=>array(
'date'=>$start_date,
'hour'=>$start_hour,
'minutes'=>$start_minutes,
'ampm'=>$start_ampm,
),
'end'=>array(
'date'=>$end_date,
'hour'=>$end_hour,
'minutes'=>$end_minutes,
'ampm'=>$end_ampm,
),
'repeat'=>array(),
'allday'=>$allday,
'comment'=>$time_comment,
'hide_time'=>$hide_time,
'hide_end_time'=>$hide_end_time,
),
'start'=>$start_date,
'start_time_hour'=>$start_hour,
'start_time_minutes'=>$start_minutes,
'start_time_ampm'=>$start_ampm,
'end'=>$end_date,
'end_time_hour'=>$end_hour,
'end_time_minutes'=>$end_minutes,
'end_time_ampm'=>$end_ampm,
'repeat_status'=>$repeat_status,
'repeat_type'=>$repeat_type,
'interval'=>$repeat_interval,
'finish'=>$finish,
'year'=>$year,
'month'=>$month,
'day'=>$day,
'week'=>$week,
'weekday'=>$weekday,
'weekdays'=>$weekdays,
'days'=>$days,
'not_in_days'=>$not_in_days,
'meta'=>array
(
'mec_source'=>'ics-calendar',
'mec_feed_event_id'=>$feed_event_id,
'mec_dont_show_map'=> 0,
'mec_additional_organizer_ids' =>$additional_organizer_ids,
'mec_repeat'=>array
(
'status' => $repeat_status,
'type' => $repeat_type,
'interval' => $repeat_interval,
'end' => 'never',
'end_at_date' => NULL,
'end_at_occurrences' => NULL,
),
'mec_allday'=>$allday,
'mec_hide_time'=>$hide_time,
'mec_hide_end_time'=>$hide_end_time,
'mec_comment'=>$time_comment,
'mec_repeat_end'=> 'never',
'mec_repeat_end_at_occurrences'=> NULL,
'mec_repeat_end_at_date'=> NULL,
'mec_in_days'=> $days,
'mec_not_in_days'=> $not_in_days,
'mec_hourly_schedules'=>$hourly_schedules,
'mec_tickets'=>$tickets,
'mec_fees_global_inheritance'=> 1,
'mec_fees'=>$fees,
'mec_reg_fields_global_inheritance'=> 1,
'mec_reg_fields'=>$reg_fields,
)
);
$post_id = $db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$feed_event_id' AND `meta_key`='mec_feed_event_id'", 'loadResult');
// Insert the event into MEC
$post_id = $main->save_event($args, $post_id);
// Add it to the imported posts
$posts[] = $post_id;
// Set location to the post
if($location_id) wp_set_object_terms($post_id, (int) $location_id, 'mec_location');
// Set organizer to the post
if($organizer_id) wp_set_object_terms($post_id, (int) $organizer_id, 'mec_organizer');
// Set categories to the post
if(count($category_ids)) foreach($category_ids as $category_id) wp_set_object_terms($post_id, (int) $category_id, 'mec_category', true);
// Featured Image
$featured_image = isset($event->attach) ? (string) $event->attach : '';
if(!has_post_thumbnail($post_id) and trim($featured_image))
{
$file_name = basename($featured_image);
$path = rtrim($wp_upload_dir['path'], DS.' ').DS.$file_name;
$url = rtrim($wp_upload_dir['url'], '/ ').'/'.$file_name;
// Download Image
$buffer = $main->get_web_page($featured_image);
$file->write($path, $buffer);
$main->set_featured_image($url, $post_id);
}
}
}
return $posts;
}
/**
* Show content of third party tab
* @author Webnus <[email protected]>
* @return void
*/
public function ix_thirdparty()
{
// Current Action
$this->action = isset($_POST['mec-ix-action']) ? sanitize_text_field($_POST['mec-ix-action']) : '';
$this->ix = isset($_POST['ix']) ? $_POST['ix'] : array();
$this->response = array();
if($this->action == 'thirdparty-import-start') $this->response = $this->thirdparty_import_start();
elseif($this->action == 'thirdparty-import-do') $this->response = $this->thirdparty_import_do();
$path = MEC::import('app.features.ix.thirdparty', true, true);
ob_start();
include $path;
echo $output = ob_get_clean();
}
public function thirdparty_import_start()
{
$third_party = isset($this->ix['third-party']) ? $this->ix['third-party'] : NULL;
if($third_party == 'eventon' and class_exists('EventON'))
{
$events = get_posts(array(
'posts_per_page' => -1,
'post_type' => 'ajde_events',
));
}
elseif($third_party == 'the-events-calendar' and class_exists('Tribe__Events__Main'))
{
$events = tribe_get_events(array(
'posts_per_page' => -1,
'post_type' => 'tribe_events',
));
}
elseif($third_party == 'weekly-class' and class_exists('WeeklyClass'))
{
$events = get_posts(array(
'posts_per_page' => -1,
'post_type' => 'class',
));
}
elseif($third_party == 'calendarize-it' and class_exists('plugin_righthere_calendar'))
{
$events = get_posts(array(
'posts_per_page' => -1,
'post_type' => 'events',
));
}
elseif($third_party == 'event-espresso' and function_exists('bootstrap_espresso'))
{
$events = get_posts(array(
'posts_per_page' => -1,
'post_type' => 'espresso_events',
));
}
elseif($third_party == 'events-manager-recurring' and class_exists('EM_Formats'))
{
$events = get_posts(array(
'posts_per_page' => -1,
'post_type' => 'event-recurring',
));
}
elseif($third_party == 'events-manager-single' and class_exists('EM_Formats'))
{
$events = get_posts(array(
'posts_per_page' => -1,
'post_type' => 'event',
'meta_key' => '_recurrence_id',
'meta_compare' => 'NOT EXISTS'
));
}
elseif($third_party == 'wp-event-manager' and class_exists('WP_Event_Manager'))
{
$events = get_posts(array(
'posts_per_page' => -1,
'post_type' => 'event_listing',
));
}
else return array('success'=>0, 'message'=>__("Third Party plugin is not installed and activated!", 'modern-events-calendar-lite'));
return array(
'success' => 1,
'data' => array(
'count' => count($events),
'events' => $events
)
);
}
public function thirdparty_import_do()
{
$third_party = isset($this->ix['third-party']) ? $this->ix['third-party'] : '';
if($third_party == 'eventon') return $this->thirdparty_eventon_import_do();
elseif($third_party == 'the-events-calendar') return $this->thirdparty_tec_import_do();
elseif($third_party == 'weekly-class') return $this->thirdparty_weekly_class_import_do();
elseif($third_party == 'calendarize-it') return $this->thirdparty_calendarize_it_import_do();
elseif($third_party == 'event-espresso') return $this->thirdparty_es_import_do();
elseif($third_party == 'events-manager-recurring') return $this->thirdparty_emr_import_do();
elseif($third_party == 'events-manager-single') return $this->thirdparty_ems_import_do();
elseif($third_party == 'wp-event-manager') return $this->thirdparty_wpem_import_do();
return array('success'=>0, 'message'=>__('Third Party plugin is invalid!', 'modern-events-calendar-lite'));
}
public function thirdparty_eventon_import_do()
{
$IDs = isset($_POST['tp-events']) ? $_POST['tp-events'] : array();
$count = 0;
foreach($IDs as $ID)
{
$post = get_post($ID);
$metas = $this->main->get_post_meta($ID);
// Event Title and Content
$title = $post->post_title;
$description = $post->post_content;
$third_party_id = $ID;
// Event location
$locations = wp_get_post_terms($ID, 'event_location');
$location_id = 1;
// Import Event Locations into MEC locations
if(isset($this->ix['import_locations']) and $this->ix['import_locations'] and isset($locations[0]))
{
$l_metas = evo_get_term_meta('event_location', $locations[0]->term_id);
$location_id = $this->main->save_location(array
(
'name'=>trim($locations[0]->name),
'address'=>(isset($l_metas['location_address']) ? $l_metas['location_address'] : ''),
'latitude'=>(isset($l_metas['location_lat']) ? $l_metas['location_lat'] : 0),
'longitude'=>(isset($l_metas['location_lon']) ? $l_metas['location_lon'] : 0),
));
}
// Event Organizer
$organizers = wp_get_post_terms($ID, 'event_organizer');
$organizer_id = 1;
// Import Event Organizer into MEC organizers
if(isset($this->ix['import_organizers']) and $this->ix['import_organizers'] and isset($organizers[0]))
{
$o_metas = evo_get_term_meta('event_organizer', $organizers[0]->term_id);
$organizer_id = $this->main->save_organizer(array
(
'name'=>trim($organizers[0]->name),
'tel'=>(isset($o_metas['evcal_org_contact']) ? $o_metas['evcal_org_contact'] : ''),
'url'=>(isset($o_metas['evcal_org_exlink']) ? $o_metas['evcal_org_exlink'] : ''),
));
}
// Event Categories
$categories = wp_get_post_terms($ID, 'event_type');
$category_ids = array();
// Import Event Categories into MEC categories
if(isset($this->ix['import_categories']) and $this->ix['import_categories'] and count($categories))
{
foreach($categories as $category)
{
$category_id = $this->main->save_category(array
(
'name'=>trim($category->name),
));
if($category_id) $category_ids[] = $category_id;
}
}
// Event Start Date and Time
$date_start = new DateTime(date('Y-m-d G:i', $metas['evcal_srow']));
if(isset($metas['evo_event_timezone']) and trim($metas['evo_event_timezone'])) $date_start->setTimezone(new DateTimeZone($metas['evo_event_timezone']));
$start_date = $date_start->format('Y-m-d');
$start_hour = $date_start->format('g');
$start_minutes = $date_start->format('i');
$start_ampm = $date_start->format('A');
// Event End Date and Time
$date_end = new DateTime(date('Y-m-d G:i', $metas['evcal_erow']));
if(isset($metas['evo_event_timezone']) and trim($metas['evo_event_timezone'])) $date_end->setTimezone(new DateTimeZone($metas['evo_event_timezone']));
$end_date = $date_end->format('Y-m-d');
$end_hour = $date_end->format('g');
$end_minutes = $date_end->format('i');
$end_ampm = $date_end->format('A');
// Event Time Options
$hide_end_time = (isset($metas['evo_hide_endtime']) and $metas['evo_hide_endtime'] == 'yes') ? 1 : 0;
$allday = (isset($metas['evcal_allday']) and trim($metas['evcal_allday']) == 'yes') ? $metas['evcal_allday'] : 0;
// Recurring Event
if(isset($metas['evcal_repeat']) and $metas['evcal_repeat'] == 'yes')
{
$repeat_status = 1;
$interval = NULL;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = NULL;
$finish = NULL;
$occurrences = (isset($metas['repeat_intervals']) and is_array($metas['repeat_intervals'])) ? $metas['repeat_intervals'] : array();
if(count($occurrences))
{
$t = $occurrences[(count($occurrences) -1)][1];
$finish = date('Y-m-d', $t);
}
$freq = (isset($metas['evcal_rep_freq']) and trim($metas['evcal_rep_freq'])) ? $metas['evcal_rep_freq'] : 'daily';
if($freq == 'daily')
{
$repeat_type = 'daily';
$interval = isset($metas['evcal_rep_gap']) ? $metas['evcal_rep_gap'] : 1;
}
elseif($freq == 'weekly')
{
$repeat_type = 'weekly';
$interval = isset($metas['evcal_rep_gap']) ? $metas['evcal_rep_gap']*7 : 7;
}
elseif($freq == 'monthly')
{
$repeat_type = 'monthly';
$year = '*';
$month = '*';
$s = $start_date;
$e = $end_date;
$_days = array();
while(strtotime($s) <= strtotime($e))
{
$_days[] = date('d', strtotime($s));
$s = date('Y-m-d', strtotime('+1 Day', strtotime($s)));
}
$day = ','.implode(',', array_unique($_days)).',';
$week = '*';
$weekday = '*';
}
elseif($freq == 'yearly')
{
$repeat_type = 'yearly';
$year = '*';
$s = $start_date;
$e = $end_date;
$_months = array();
$_days = array();
while(strtotime($s) <= strtotime($e))
{
$_months[] = date('m', strtotime($s));
$_days[] = date('d', strtotime($s));
$s = date('Y-m-d', strtotime('+1 Day', strtotime($s)));
}
$month = ','.implode(',', array_unique($_months)).',';
$day = ','.implode(',', array_unique($_days)).',';
$week = '*';
$weekday = '*';
}
elseif($freq == 'custom')
{
$repeat_type = 'custom_days';
$occurrencies = (isset($metas['repeat_intervals']) and is_array($metas['repeat_intervals'])) ? $metas['repeat_intervals'] : array();
$days = '';
$x = 1;
foreach($occurrencies as $occurrency)
{
if($x == 1)
{
$finish = date('Y-m-d', $occurrency[0]);
$x++;
continue;
}
$days .= date('Y-m-d', $occurrency[0]).',';
$x++;
}
$days = trim($days, ', ');
}
else $repeat_type = '';
// Custom Week Days
if($repeat_type == 'weekly' and isset($metas['evo_rep_WKwk']) and is_array($metas['evo_rep_WKwk']) and count($metas['evo_rep_WKwk']) > 1)
{
$week_day_mapping = array('d1'=>1, 'd2'=>2, 'd3'=>3, 'd4'=>4, 'd5'=>5, 'd6'=>6, 'd0'=>7);
$weekdays = '';
foreach($metas['evo_rep_WKwk'] as $week_day) $weekdays .= $week_day_mapping['d'.$week_day].',';
$weekdays = ','.trim($weekdays, ', ').',';
$interval = NULL;
$repeat_type = 'certain_weekdays';
}
}
// Single Event
else
{
$repeat_status = 0;
$repeat_type = '';
$interval = NULL;
$finish = $end_date;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = NULL;
}
// Hourly Schedule
$hourly_schedules = array();
if(isset($metas['_sch_blocks']) and is_array($metas['_sch_blocks']) and count($metas['_sch_blocks']))
{
foreach($metas['_sch_blocks'] as $sch_block)
{
foreach($sch_block as $sch)
{
if(!is_array($sch)) continue;
$hourly_schedules[] = array(
'from' => $sch['evo_sch_stime'],
'to' => $sch['evo_sch_etime'],
'title' => $sch['evo_sch_title'],
'description' => $sch['evo_sch_desc'],
);
}
}
}
$args = array
(
'title'=>$title,
'content'=>$description,
'location_id'=>$location_id,
'organizer_id'=>$organizer_id,
'date'=>array
(
'start'=>array(
'date'=>$start_date,
'hour'=>$start_hour,
'minutes'=>$start_minutes,
'ampm'=>$start_ampm,
),
'end'=>array(
'date'=>$end_date,
'hour'=>$end_hour,
'minutes'=>$end_minutes,
'ampm'=>$end_ampm,
),
'repeat'=>array(
'end'=>'date',
'end_at_date'=>$finish,
'end_at_occurrences'=>10,
),
'allday'=>$allday,
'comment'=>'',
'hide_time'=>0,
'hide_end_time'=>$hide_end_time,
),
'start'=>$start_date,
'start_time_hour'=>$start_hour,
'start_time_minutes'=>$start_minutes,
'start_time_ampm'=>$start_ampm,
'end'=>$end_date,
'end_time_hour'=>$end_hour,
'end_time_minutes'=>$end_minutes,
'end_time_ampm'=>$end_ampm,
'repeat_status'=>$repeat_status,
'repeat_type'=>$repeat_type,
'interval'=>$interval,
'finish'=>$finish,
'year'=>$year,
'month'=>$month,
'day'=>$day,
'week'=>$week,
'weekday'=>$weekday,
'weekdays'=>$weekdays,
'days'=>$days,
'meta'=>array
(
'mec_source'=>'eventon',
'mec_eventon_id'=>$third_party_id,
'mec_allday'=>$allday,
'hide_end_time'=>$hide_end_time,
'mec_repeat_end'=>'date',
'mec_repeat_end_at_occurrences'=>9,
'mec_repeat_end_at_date'=>$finish,
'mec_in_days'=>$days,
'mec_hourly_schedules'=>$hourly_schedules,
)
);
$post_id = $this->db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$third_party_id' AND `meta_key`='mec_eventon_id'", 'loadResult');
// Insert the event into MEC
$post_id = $this->main->save_event($args, $post_id);
// Set location to the post
if($location_id) wp_set_object_terms($post_id, (int) $location_id, 'mec_location');
// Set organizer to the post
if($organizer_id) wp_set_object_terms($post_id, (int) $organizer_id, 'mec_organizer');
// Set categories to the post
if(count($category_ids)) foreach($category_ids as $category_id) wp_set_object_terms($post_id, (int) $category_id, 'mec_category', true);
// Set Features Image
if(isset($this->ix['import_featured_image']) and $this->ix['import_featured_image'] and $thumbnail_id = get_post_thumbnail_id($ID))
{
set_post_thumbnail($post_id, $thumbnail_id);
}
$count++;
}
return array('success'=>1, 'data'=>$count);
}
public function thirdparty_tec_import_do()
{
$IDs = isset($_POST['tp-events']) ? $_POST['tp-events'] : array();
$count = 0;
foreach($IDs as $ID)
{
$post = get_post($ID);
$metas = $this->main->get_post_meta($ID);
// Event Title and Content
$title = $post->post_title;
$description = $post->post_content;
$third_party_id = $ID;
// Event location
$location = get_post($metas['_EventVenueID']);
$location_id = 1;
// Import Event Locations into MEC locations
if(isset($this->ix['import_locations']) and $this->ix['import_locations'] and isset($location->ID))
{
$l_metas = $this->main->get_post_meta($location->ID);
$location_id = $this->main->save_location(array
(
'name'=>trim($location->post_title),
'address'=>(isset($l_metas['_VenueAddress']) ? $l_metas['_VenueAddress'] : ''),
'latitude'=>0,
'longitude'=>0,
));
}
// Event Organizer
$organizer = get_post($metas['_EventOrganizerID']);
$organizer_id = 1;
// Import Event Organizer into MEC organizers
if(isset($this->ix['import_organizers']) and $this->ix['import_organizers'] and isset($organizer->ID))
{
$o_metas = $this->main->get_post_meta($organizer->ID);
$organizer_id = $this->main->save_organizer(array
(
'name'=>trim($organizer->post_title),
'tel'=>(isset($o_metas['_OrganizerPhone']) ? $o_metas['_OrganizerPhone'] : ''),
'email'=>(isset($o_metas['_OrganizerEmail']) ? $o_metas['_OrganizerEmail'] : ''),
'url'=>(isset($o_metas['_OrganizerWebsite']) ? $o_metas['_OrganizerWebsite'] : ''),
));
}
// Event Categories
$categories = wp_get_post_terms($ID, 'tribe_events_cat');
$category_ids = array();
// Import Event Categories into MEC categories
if(isset($this->ix['import_categories']) and $this->ix['import_categories'] and count($categories))
{
foreach($categories as $category)
{
$category_id = $this->main->save_category(array
(
'name'=>trim($category->name),
));
if($category_id) $category_ids[] = $category_id;
}
}
// Event Start Date and Time
$date_start = new DateTime(date('Y-m-d G:i', strtotime($metas['_EventStartDate'])));
$start_date = $date_start->format('Y-m-d');
$start_hour = $date_start->format('g');
$start_minutes = $date_start->format('i');
$start_ampm = $date_start->format('A');
// Event End Date and Time
$date_end = new DateTime(date('Y-m-d G:i', strtotime($metas['_EventEndDate'])));
$end_date = $date_end->format('Y-m-d');
$end_hour = $date_end->format('g');
$end_minutes = $date_end->format('i');
$end_ampm = $date_end->format('A');
// Event Time Options
$hide_end_time = 0;
$allday = (isset($metas['_EventAllDay']) and trim($metas['_EventAllDay']) == 'yes') ? 1 : 0;
// Single Event
$repeat_status = 0;
$repeat_type = '';
$interval = NULL;
$finish = $end_date;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = NULL;
$args = array
(
'title'=>$title,
'content'=>$description,
'location_id'=>$location_id,
'organizer_id'=>$organizer_id,
'date'=>array
(
'start'=>array(
'date'=>$start_date,
'hour'=>$start_hour,
'minutes'=>$start_minutes,
'ampm'=>$start_ampm,
),
'end'=>array(
'date'=>$end_date,
'hour'=>$end_hour,
'minutes'=>$end_minutes,
'ampm'=>$end_ampm,
),
'repeat'=>array(
'end'=>'date',
'end_at_date'=>$finish,
'end_at_occurrences'=>10,
),
'allday'=>$allday,
'comment'=>'',
'hide_time'=>0,
'hide_end_time'=>$hide_end_time,
),
'start'=>$start_date,
'start_time_hour'=>$start_hour,
'start_time_minutes'=>$start_minutes,
'start_time_ampm'=>$start_ampm,
'end'=>$end_date,
'end_time_hour'=>$end_hour,
'end_time_minutes'=>$end_minutes,
'end_time_ampm'=>$end_ampm,
'repeat_status'=>$repeat_status,
'repeat_type'=>$repeat_type,
'interval'=>$interval,
'finish'=>$finish,
'year'=>$year,
'month'=>$month,
'day'=>$day,
'week'=>$week,
'weekday'=>$weekday,
'weekdays'=>$weekdays,
'days'=>$days,
'meta'=>array
(
'mec_source'=>'the-events-calendar',
'mec_tec_id'=>$third_party_id,
'mec_allday'=>$allday,
'hide_end_time'=>$hide_end_time,
'mec_repeat_end'=>'date',
'mec_repeat_end_at_occurrences'=>9,
'mec_repeat_end_at_date'=>$finish,
'mec_in_days'=>$days,
'mec_more_info'=>$metas['_EventURL'],
'mec_cost'=>trim($metas['_EventCurrencySymbol'].$metas['_EventCost']),
)
);
$post_id = $this->db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$third_party_id' AND `meta_key`='mec_tec_id'", 'loadResult');
// Insert the event into MEC
$post_id = $this->main->save_event($args, $post_id);
// Set location to the post
if($location_id) wp_set_object_terms($post_id, (int) $location_id, 'mec_location');
// Set organizer to the post
if($organizer_id) wp_set_object_terms($post_id, (int) $organizer_id, 'mec_organizer');
// Set categories to the post
if(count($category_ids)) foreach($category_ids as $category_id) wp_set_object_terms($post_id, (int) $category_id, 'mec_category', true);
// Set Features Image
if(isset($this->ix['import_featured_image']) and $this->ix['import_featured_image'] and $thumbnail_id = get_post_thumbnail_id($ID))
{
set_post_thumbnail($post_id, $thumbnail_id);
}
$count++;
}
return array('success'=>1, 'data'=>$count);
}
public function thirdparty_weekly_class_import_do()
{
$IDs = isset($_POST['tp-events']) ? $_POST['tp-events'] : array();
$count = 0;
foreach($IDs as $ID)
{
$post = get_post($ID);
$metas = $this->main->get_post_meta($ID);
// Event Title and Content
$title = $post->post_title;
$description = $post->post_content;
$third_party_id = $ID;
// Event location
$locations = wp_get_post_terms($ID, 'wcs-room');
$location_id = 1;
// Import Event Locations into MEC locations
if(isset($this->ix['import_locations']) and $this->ix['import_locations'] and isset($locations[0]))
{
$location_id = $this->main->save_location(array
(
'name'=>trim($locations[0]->name),
'address'=>'',
'latitude'=>'',
'longitude'=>'',
));
}
// Event Organizer
$organizers = wp_get_post_terms($ID, 'wcs-instructor');
$organizer_id = 1;
// Import Event Organizer into MEC organizers
if(isset($this->ix['import_organizers']) and $this->ix['import_organizers'] and isset($organizers[0]))
{
$organizer_id = $this->main->save_organizer(array
(
'name'=>trim($organizers[0]->name),
'tel'=>'',
'url'=>'',
));
}
// Event Categories
$categories = wp_get_post_terms($ID, 'wcs-type');
$category_ids = array();
// Import Event Categories into MEC categories
if(isset($this->ix['import_categories']) and $this->ix['import_categories'] and count($categories))
{
foreach($categories as $category)
{
$category_id = $this->main->save_category(array
(
'name'=>trim($category->name),
));
if($category_id) $category_ids[] = $category_id;
}
}
// Event Start Date and Time
$date_start = new DateTime(date('Y-m-d G:i', $metas['_wcs_timestamp']));
$start_date = $date_start->format('Y-m-d');
$start_hour = $date_start->format('g');
$start_minutes = $date_start->format('i');
$start_ampm = $date_start->format('A');
// Event End Date and Time
$date_end = new DateTime(date('Y-m-d G:i', ($metas['_wcs_timestamp']+($metas['_wcs_duration']*60))));
$end_date = $date_end->format('Y-m-d');
$end_hour = $date_end->format('g');
$end_minutes = $date_end->format('i');
$end_ampm = $date_end->format('A');
// Event Time Options
$hide_end_time = 0;
$allday = 0;
// Recurring Event
if(isset($metas['_wcs_interval']) and $metas['_wcs_interval'])
{
$repeat_status = 1;
$interval = NULL;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = NULL;
$finish = (isset($metas['_wcs_repeat_until']) and trim($metas['_wcs_repeat_until'])) ? date('Y-m-d', strtotime($metas['_wcs_repeat_until'])) : NULL;
$freq = (isset($metas['_wcs_interval']) and trim($metas['_wcs_interval'])) ? $metas['_wcs_interval'] : 2;
if($freq == 2) // Daily
{
$repeat_type = 'daily';
$interval = 1;
}
elseif($freq == 1 or $freq == 3) // Weekly or Every Two Weeks
{
$repeat_type = 'weekly';
$interval = $freq == 3 ? 14 : 7;
}
elseif($freq == 4) // Monthly
{
$repeat_type = 'monthly';
$year = '*';
$month = '*';
$s = $start_date;
$e = $end_date;
$_days = array();
while(strtotime($s) <= strtotime($e))
{
$_days[] = date('d', strtotime($s));
$s = date('Y-m-d', strtotime('+1 Day', strtotime($s)));
}
$day = ','.implode(',', array_unique($_days)).',';
$week = '*';
$weekday = '*';
}
elseif($freq == 5) // Yearly
{
$repeat_type = 'yearly';
$year = '*';
$s = $start_date;
$e = $end_date;
$_months = array();
$_days = array();
while(strtotime($s) <= strtotime($e))
{
$_months[] = date('m', strtotime($s));
$_days[] = date('d', strtotime($s));
$s = date('Y-m-d', strtotime('+1 Day', strtotime($s)));
}
$month = ','.implode(',', array_unique($_months)).',';
$day = ','.implode(',', array_unique($_days)).',';
$week = '*';
$weekday = '*';
}
else $repeat_type = '';
// Custom Week Days
if($repeat_type == 'daily' and isset($metas['_wcs_repeat_days']) and is_array($metas['_wcs_repeat_days']) and count($metas['_wcs_repeat_days']) > 1 and count($metas['_wcs_repeat_days']) < 7)
{
$week_day_mapping = array('d1'=>1, 'd2'=>2, 'd3'=>3, 'd4'=>4, 'd5'=>5, 'd6'=>6, 'd0'=>7);
$weekdays = '';
foreach($metas['_wcs_repeat_days'] as $week_day) $weekdays .= $week_day_mapping['d'.$week_day].',';
$weekdays = ','.trim($weekdays, ', ').',';
$interval = NULL;
$repeat_type = 'certain_weekdays';
}
}
// Single Event
else
{
$repeat_status = 0;
$repeat_type = '';
$interval = NULL;
$finish = $end_date;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = NULL;
}
$args = array
(
'title'=>$title,
'content'=>$description,
'location_id'=>$location_id,
'organizer_id'=>$organizer_id,
'date'=>array
(
'start'=>array(
'date'=>$start_date,
'hour'=>$start_hour,
'minutes'=>$start_minutes,
'ampm'=>$start_ampm,
),
'end'=>array(
'date'=>$end_date,
'hour'=>$end_hour,
'minutes'=>$end_minutes,
'ampm'=>$end_ampm,
),
'repeat'=>array(
'end'=>'date',
'end_at_date'=>$finish,
'end_at_occurrences'=>10,
),
'allday'=>$allday,
'comment'=>'',
'hide_time'=>0,
'hide_end_time'=>$hide_end_time,
),
'start'=>$start_date,
'start_time_hour'=>$start_hour,
'start_time_minutes'=>$start_minutes,
'start_time_ampm'=>$start_ampm,
'end'=>$end_date,
'end_time_hour'=>$end_hour,
'end_time_minutes'=>$end_minutes,
'end_time_ampm'=>$end_ampm,
'repeat_status'=>$repeat_status,
'repeat_type'=>$repeat_type,
'interval'=>$interval,
'finish'=>$finish,
'year'=>$year,
'month'=>$month,
'day'=>$day,
'week'=>$week,
'weekday'=>$weekday,
'weekdays'=>$weekdays,
'days'=>$days,
'meta'=>array
(
'mec_source'=>'weekly_class',
'mec_weekly_class_id'=>$third_party_id,
'mec_allday'=>$allday,
'hide_end_time'=>$hide_end_time,
'mec_repeat_end'=>($finish ? 'date' : 'never'),
'mec_repeat_end_at_occurrences'=>9,
'mec_repeat_end_at_date'=>$finish,
'mec_in_days'=>$days,
)
);
$post_id = $this->db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$third_party_id' AND `meta_key`='mec_weekly_class_id'", 'loadResult');
// Insert the event into MEC
$post_id = $this->main->save_event($args, $post_id);
// Set location to the post
if($location_id) wp_set_object_terms($post_id, (int) $location_id, 'mec_location');
// Set organizer to the post
if($organizer_id) wp_set_object_terms($post_id, (int) $organizer_id, 'mec_organizer');
// Set categories to the post
if(count($category_ids)) foreach($category_ids as $category_id) wp_set_object_terms($post_id, (int) $category_id, 'mec_category', true);
// Set Features Image
if(isset($this->ix['import_featured_image']) and $this->ix['import_featured_image'] and $thumbnail_id = get_post_thumbnail_id($ID))
{
set_post_thumbnail($post_id, $thumbnail_id);
}
$count++;
}
return array('success'=>1, 'data'=>$count);
}
public function thirdparty_calendarize_it_import_do()
{
$IDs = isset($_POST['tp-events']) ? $_POST['tp-events'] : array();
$count = 0;
foreach($IDs as $ID)
{
$post = get_post($ID);
$metas = $this->main->get_post_meta($ID);
// Event Title and Content
$title = $post->post_title;
$description = $post->post_content;
$third_party_id = $ID;
// Event location
$locations = wp_get_post_terms($ID, 'venue');
$location_id = 1;
// Import Event Locations into MEC locations
if(isset($this->ix['import_locations']) and $this->ix['import_locations'] and isset($locations[0]))
{
$location_id = $this->main->save_location(array
(
'name'=>trim($locations[0]->name),
'address'=>trim(get_term_meta($locations[0]->term_id, 'address', true)),
'latitude'=>trim(get_term_meta($locations[0]->term_id, 'glat', true)),
'longitude'=>trim(get_term_meta($locations[0]->term_id, 'glon', true)),
));
}
// Event Organizer
$organizers = wp_get_post_terms($ID, 'organizer');
$organizer_id = 1;
// Import Event Organizer into MEC organizers
if(isset($this->ix['import_organizers']) and $this->ix['import_organizers'] and isset($organizers[0]))
{
$organizer_id = $this->main->save_organizer(array
(
'name'=>trim($organizers[0]->name),
'tel'=>trim(get_term_meta($organizers[0]->term_id, 'phone', true)),
'email'=>trim(get_term_meta($organizers[0]->term_id, 'email', true)),
'url'=>trim(get_term_meta($organizers[0]->term_id, 'website', true)),
));
}
// Event Categories
$categories = wp_get_post_terms($ID, 'calendar');
$category_ids = array();
// Import Event Categories into MEC categories
if(isset($this->ix['import_categories']) and $this->ix['import_categories'] and count($categories))
{
foreach($categories as $category)
{
$category_id = $this->main->save_category(array
(
'name'=>trim($category->name),
));
if($category_id) $category_ids[] = $category_id;
}
}
// Event Start Date and Time
$date_start = new DateTime(date('Y-m-d G:i', strtotime($metas['fc_start_datetime'])));
$start_date = $date_start->format('Y-m-d');
$start_hour = $date_start->format('g');
$start_minutes = $date_start->format('i');
$start_ampm = $date_start->format('A');
// Event End Date and Time
$date_end = new DateTime(date('Y-m-d G:i', strtotime($metas['fc_end_datetime'])));
$end_date = $date_end->format('Y-m-d');
$end_hour = $date_end->format('g');
$end_minutes = $date_end->format('i');
$end_ampm = $date_end->format('A');
// Event Time Options
$hide_end_time = 0;
$allday = isset($metas['fc_allday']) ? $metas['fc_allday'] : 0;
// Recurring Event
if(isset($metas['fc_rrule']) and trim($metas['fc_rrule']))
{
$rules = explode(';', trim($metas['fc_rrule'], '; '));
$rule = array();
foreach($rules as $rule_row)
{
$ex = explode('=', $rule_row);
$key = strtolower($ex[0]);
$value = $key == 'until' ? $ex[1] : strtolower($ex[1]);
$rule[$key] = $value;
}
$repeat_status = 1;
$interval = NULL;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = NULL;
$finish = isset($rule['until']) ? date('Y-m-d', strtotime($rule['until'])) : NULL;
if($rule['freq'] == 'daily')
{
$repeat_type = 'daily';
$interval = isset($rule['interval']) ? $rule['interval'] : 1;
if(isset($rule['count'])) $finish = date('Y-m-d', strtotime('+'.$rule['count'].' days', strtotime($start_date)));
}
elseif($rule['freq'] == 'weekly')
{
$repeat_type = 'weekly';
$interval = isset($rule['interval']) ? $rule['interval']*7 : 7;
if(isset($rule['count'])) $finish = date('Y-m-d', strtotime('+'.$rule['count'].' weeks', strtotime($start_date)));
}
elseif($rule['freq'] == 'monthly')
{
$repeat_type = 'monthly';
$year = '*';
$month = '*';
$s = $start_date;
$e = $end_date;
$_days = array();
while(strtotime($s) <= strtotime($e))
{
$_days[] = date('d', strtotime($s));
$s = date('Y-m-d', strtotime('+1 Day', strtotime($s)));
}
$day = ','.implode(',', array_unique($_days)).',';
$week = '*';
$weekday = '*';
if(isset($rule['count'])) $finish = date('Y-m-d', strtotime('+'.$rule['count'].' months', strtotime($start_date)));
}
elseif($rule['freq'] == 'yearly')
{
$repeat_type = 'yearly';
$year = '*';
$s = $start_date;
$e = $end_date;
$_months = array();
$_days = array();
while(strtotime($s) <= strtotime($e))
{
$_months[] = date('m', strtotime($s));
$_days[] = date('d', strtotime($s));
$s = date('Y-m-d', strtotime('+1 Day', strtotime($s)));
}
$month = ','.implode(',', array_unique($_months)).',';
$day = ','.implode(',', array_unique($_days)).',';
$week = '*';
$weekday = '*';
if(isset($rule['count'])) $finish = date('Y-m-d', strtotime('+'.$rule['count'].' years', strtotime($start_date)));
}
}
// Custom Days
elseif(isset($metas['fc_rdate']) and trim($metas['fc_rdate']))
{
$fc_rdates = explode(',', $metas['fc_rdate']);
$str_days = '';
foreach($fc_rdates as $fc_rdate) $str_days .= date('Y-m-d', strtotime($fc_rdate)).',';
$repeat_status = 1;
$repeat_type = 'custom_days';
$interval = NULL;
$finish = $end_date;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = trim($str_days, ', ');
}
// Single Event
else
{
$repeat_status = 0;
$repeat_type = '';
$interval = NULL;
$finish = $end_date;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = NULL;
}
$args = array
(
'title'=>$title,
'content'=>$description,
'location_id'=>$location_id,
'organizer_id'=>$organizer_id,
'date'=>array
(
'start'=>array(
'date'=>$start_date,
'hour'=>$start_hour,
'minutes'=>$start_minutes,
'ampm'=>$start_ampm,
),
'end'=>array(
'date'=>$end_date,
'hour'=>$end_hour,
'minutes'=>$end_minutes,
'ampm'=>$end_ampm,
),
'repeat'=>array(
'end'=>'date',
'end_at_date'=>$finish,
'end_at_occurrences'=>10,
),
'allday'=>$allday,
'comment'=>'',
'hide_time'=>0,
'hide_end_time'=>$hide_end_time,
),
'start'=>$start_date,
'start_time_hour'=>$start_hour,
'start_time_minutes'=>$start_minutes,
'start_time_ampm'=>$start_ampm,
'end'=>$end_date,
'end_time_hour'=>$end_hour,
'end_time_minutes'=>$end_minutes,
'end_time_ampm'=>$end_ampm,
'repeat_status'=>$repeat_status,
'repeat_type'=>$repeat_type,
'interval'=>$interval,
'finish'=>$finish,
'year'=>$year,
'month'=>$month,
'day'=>$day,
'week'=>$week,
'weekday'=>$weekday,
'weekdays'=>$weekdays,
'days'=>$days,
'meta'=>array
(
'mec_source'=>'calendarize_it',
'mec_calendarize_it_id'=>$third_party_id,
'mec_allday'=>$allday,
'hide_end_time'=>$hide_end_time,
'mec_repeat_end'=>($finish ? 'date' : 'never'),
'mec_repeat_end_at_occurrences'=>9,
'mec_repeat_end_at_date'=>$finish,
'mec_in_days'=>$days,
)
);
$post_id = $this->db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$third_party_id' AND `meta_key`='mec_calendarize_it_id'", 'loadResult');
// Insert the event into MEC
$post_id = $this->main->save_event($args, $post_id);
// Set location to the post
if($location_id) wp_set_object_terms($post_id, (int) $location_id, 'mec_location');
// Set organizer to the post
if($organizer_id) wp_set_object_terms($post_id, (int) $organizer_id, 'mec_organizer');
// Set categories to the post
if(count($category_ids)) foreach($category_ids as $category_id) wp_set_object_terms($post_id, (int) $category_id, 'mec_category', true);
// Set Features Image
if(isset($this->ix['import_featured_image']) and $this->ix['import_featured_image'] and $thumbnail_id = get_post_thumbnail_id($ID))
{
set_post_thumbnail($post_id, $thumbnail_id);
}
$count++;
}
return array('success'=>1, 'data'=>$count);
}
public function thirdparty_es_import_do()
{
$IDs = isset($_POST['tp-events']) ? $_POST['tp-events'] : array();
$count = 0;
// Timezone
$timezone = $this->main->get_timezone();
foreach($IDs as $ID)
{
$post = get_post($ID);
// Event Title and Content
$title = $post->post_title;
$description = $post->post_content;
$third_party_id = $ID;
// Event location
$venue_id = $this->db->select("SELECT `VNU_ID` FROM `#__esp_event_venue` WHERE `EVT_ID`='".$ID."' ORDER BY `EVV_ID` ASC LIMIT 1", 'loadResult');
$location_id = 1;
// Import Event Locations into MEC locations
if(isset($this->ix['import_locations']) and $this->ix['import_locations'] and $venue_id)
{
$v_meta = $this->db->select("SELECT * FROM `#__esp_venue_meta` WHERE `VNU_ID`='".$venue_id."'", 'loadAssoc');
$location_id = $this->main->save_location(array
(
'name'=>get_the_title($venue_id),
'address'=>trim($v_meta['VNU_address'].' '.$v_meta['VNU_address2']),
'latitude'=>'',
'longitude'=>'',
));
}
// Event Categories
$categories = wp_get_post_terms($ID, 'espresso_event_categories');
$category_ids = array();
// Import Event Categories into MEC categories
if(isset($this->ix['import_categories']) and $this->ix['import_categories'] and count($categories))
{
foreach($categories as $category)
{
$category_id = $this->main->save_category(array
(
'name'=>trim($category->name),
));
if($category_id) $category_ids[] = $category_id;
}
}
$datetimes = $venue_id = $this->db->select("SELECT * FROM `#__esp_datetime` WHERE `EVT_ID`='".$ID."' ORDER BY `DTT_EVT_start` ASC", 'loadAssocList');
$dt_start = NULL;
$dt_end = NULL;
$custom_days = array();
$i = 1;
foreach($datetimes as $datetime)
{
if(!$dt_start) $dt_start = $datetime['DTT_EVT_start'];
if(!$dt_end) $dt_end = $datetime['DTT_EVT_end'];
// Add to Custom Days
if($i > 1) $custom_days[] = array(date('Y-m-d', strtotime($datetime['DTT_EVT_start'])), date('Y-m-d', strtotime($datetime['DTT_EVT_end'])));
$i++;
}
// Event Start Date and Time
$date_start = new DateTime(date('Y-m-d G:i', strtotime($dt_start)), new DateTimeZone('UTC'));
$date_start->setTimezone(new DateTimeZone($timezone));
$start_date = $date_start->format('Y-m-d');
$start_hour = $date_start->format('g');
$start_minutes = $date_start->format('i');
$start_ampm = $date_start->format('A');
// Event End Date and Time
$date_end = new DateTime(date('Y-m-d G:i', strtotime($dt_end)), new DateTimeZone('UTC'));
$date_end->setTimezone(new DateTimeZone($timezone));
$end_date = $date_end->format('Y-m-d');
$end_hour = $date_end->format('g');
$end_minutes = $date_end->format('i');
$end_ampm = $date_end->format('A');
// Event Time Options
$hide_end_time = 0;
$allday = 0;
// Custom Days
if(count($custom_days))
{
$str_days = '';
foreach($custom_days as $custom_day) $str_days .= date('Y-m-d', strtotime($custom_day[0])).':'.date('Y-m-d', strtotime($custom_day[1])).',';
$repeat_status = 1;
$repeat_type = 'custom_days';
$interval = NULL;
$finish = $end_date;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = trim($str_days, ', ');
}
// Single Event
else
{
$repeat_status = 0;
$repeat_type = '';
$interval = NULL;
$finish = $end_date;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = NULL;
}
$args = array
(
'title'=>$title,
'content'=>$description,
'location_id'=>$location_id,
'organizer_id'=>1,
'date'=>array
(
'start'=>array(
'date'=>$start_date,
'hour'=>$start_hour,
'minutes'=>$start_minutes,
'ampm'=>$start_ampm,
),
'end'=>array(
'date'=>$end_date,
'hour'=>$end_hour,
'minutes'=>$end_minutes,
'ampm'=>$end_ampm,
),
'repeat'=>array(
'end'=>'date',
'end_at_date'=>$finish,
'end_at_occurrences'=>10,
),
'allday'=>$allday,
'comment'=>'',
'hide_time'=>0,
'hide_end_time'=>$hide_end_time,
),
'start'=>$start_date,
'start_time_hour'=>$start_hour,
'start_time_minutes'=>$start_minutes,
'start_time_ampm'=>$start_ampm,
'end'=>$end_date,
'end_time_hour'=>$end_hour,
'end_time_minutes'=>$end_minutes,
'end_time_ampm'=>$end_ampm,
'repeat_status'=>$repeat_status,
'repeat_type'=>$repeat_type,
'interval'=>$interval,
'finish'=>$finish,
'year'=>$year,
'month'=>$month,
'day'=>$day,
'week'=>$week,
'weekday'=>$weekday,
'weekdays'=>$weekdays,
'days'=>$days,
'meta'=>array
(
'mec_source'=>'eventespresso',
'mec_eventespresso_id'=>$third_party_id,
'mec_allday'=>$allday,
'hide_end_time'=>$hide_end_time,
'mec_repeat_end'=>($finish ? 'date' : 'never'),
'mec_repeat_end_at_occurrences'=>9,
'mec_repeat_end_at_date'=>$finish,
'mec_in_days'=>$days,
)
);
$post_id = $this->db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$third_party_id' AND `meta_key`='mec_eventespresso_id'", 'loadResult');
// Insert the event into MEC
$post_id = $this->main->save_event($args, $post_id);
// Set location to the post
if($location_id) wp_set_object_terms($post_id, (int) $location_id, 'mec_location');
// Set categories to the post
if(count($category_ids)) foreach($category_ids as $category_id) wp_set_object_terms($post_id, (int) $category_id, 'mec_category', true);
// Set Features Image
if(isset($this->ix['import_featured_image']) and $this->ix['import_featured_image'] and $thumbnail_id = get_post_thumbnail_id($ID))
{
set_post_thumbnail($post_id, $thumbnail_id);
}
$count++;
}
return array('success'=>1, 'data'=>$count);
}
public function thirdparty_emr_import_do()
{
$IDs = isset($_POST['tp-events']) ? $_POST['tp-events'] : array();
$count = 0;
foreach($IDs as $ID)
{
$post = get_post($ID);
$metas = $this->main->get_post_meta($ID);
// Event Title and Content
$title = $post->post_title;
$description = $post->post_content;
$third_party_id = $ID;
// Event location
$location = $this->db->select("SELECT * FROM `#__em_locations` WHERE `location_id`='".(isset($metas['_location_id']) ? $metas['_location_id'] : 0)."'", 'loadAssoc');
$location_id = 1;
// Import Event Locations into MEC locations
if(isset($this->ix['import_locations']) and $this->ix['import_locations'] and isset($location['post_id']))
{
$address = $location['location_address'].' '.$location['location_region'].' '.$location['location_town'].' '.$location['location_state'].' '.$location['location_country'];
$location_id = $this->main->save_location(array
(
'name'=>trim($location['location_name']),
'address'=>trim($address),
'latitude'=>trim($location['location_latitude']),
'longitude'=>trim($location['location_longitude']),
));
}
// Event Categories
$categories = wp_get_post_terms($ID, 'event-categories');
$category_ids = array();
// Import Event Categories into MEC categories
if(isset($this->ix['import_categories']) and $this->ix['import_categories'] and count($categories))
{
foreach($categories as $category)
{
$category_id = $this->main->save_category(array
(
'name'=>trim($category->name),
));
if($category_id) $category_ids[] = $category_id;
}
}
// Event Start Date and Time
$date_start = new DateTime(date('Y-m-d G:i', strtotime($metas['_event_start_local'])));
$start_date = $date_start->format('Y-m-d');
$start_hour = $date_start->format('g');
$start_minutes = $date_start->format('i');
$start_ampm = $date_start->format('A');
// Event End Date and Time
$date_end = new DateTime(date('Y-m-d', strtotime('+'.(isset($metas['_recurrence_days']) ? $metas['_recurrence_days'] : 0).' days', strtotime($metas['_event_start_local']))).' '.$metas['_event_end_time']);
$end_date = $date_end->format('Y-m-d');
$end_hour = $date_end->format('g');
$end_minutes = $date_end->format('i');
$end_ampm = $date_end->format('A');
// Event Time Options
$hide_end_time = 0;
$allday = isset($metas['_event_all_day']) ? $metas['_event_all_day'] : 0;
$repeat_status = 1;
$interval = NULL;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = NULL;
$finish = date('Y-m-d', strtotime($metas['_event_end_local']));
$repeat_type = '';
$advanced_days = NULL;
if($metas['_recurrence_freq'] == 'daily')
{
$repeat_type = 'daily';
$interval = isset($metas['_recurrence_interval']) ? $metas['_recurrence_interval'] : 1;
}
elseif($metas['_recurrence_freq'] == 'weekly')
{
$repeat_type = 'certain_weekdays';
$interval = 1;
$weekdays = ',' . str_replace('0', '7', $metas['_recurrence_byday']) . ',';
}
elseif($metas['_recurrence_freq'] == 'monthly')
{
$repeat_type = 'advanced';
$week_no = $metas['_recurrence_byweekno'];
if($week_no == '-1' or $week_no == '5') $week_no = 'l';
$week_day = $metas['_recurrence_byday'];
if($week_day == '0') $week_day = 'Sun';
elseif($week_day == '1') $week_day = 'Mon';
elseif($week_day == '2') $week_day = 'Tue';
elseif($week_day == '3') $week_day = 'Wed';
elseif($week_day == '4') $week_day = 'Thu';
elseif($week_day == '5') $week_day = 'Fri';
else $week_day = 'Sat';
$advanced_days = array($week_day.'.'.$week_no);
}
elseif($metas['_recurrence_freq'] == 'yearly')
{
$repeat_type = 'yearly';
$year = '*';
$s = $start_date;
$e = $end_date;
$_months = array();
$_days = array();
while(strtotime($s) <= strtotime($e))
{
$_months[] = date('m', strtotime($s));
$_days[] = date('d', strtotime($s));
$s = date('Y-m-d', strtotime('+1 Day', strtotime($s)));
}
$month = ','.implode(',', array_unique($_months)).',';
$day = ','.implode(',', array_unique($_days)).',';
$week = '*';
$weekday = '*';
}
$args = array
(
'title'=>$title,
'content'=>$description,
'location_id'=>$location_id,
'organizer_id'=>1,
'date'=>array
(
'start'=>array(
'date'=>$start_date,
'hour'=>$start_hour,
'minutes'=>$start_minutes,
'ampm'=>$start_ampm,
),
'end'=>array(
'date'=>$end_date,
'hour'=>$end_hour,
'minutes'=>$end_minutes,
'ampm'=>$end_ampm,
),
'repeat'=>array(
'end'=>'date',
'end_at_date'=>$finish,
'end_at_occurrences'=>10,
),
'allday'=>$allday,
'comment'=>'',
'hide_time'=>0,
'hide_end_time'=>$hide_end_time,
),
'start'=>$start_date,
'start_time_hour'=>$start_hour,
'start_time_minutes'=>$start_minutes,
'start_time_ampm'=>$start_ampm,
'end'=>$end_date,
'end_time_hour'=>$end_hour,
'end_time_minutes'=>$end_minutes,
'end_time_ampm'=>$end_ampm,
'repeat_status'=>$repeat_status,
'repeat_type'=>$repeat_type,
'interval'=>$interval,
'finish'=>$finish,
'year'=>$year,
'month'=>$month,
'day'=>$day,
'week'=>$week,
'weekday'=>$weekday,
'weekdays'=>$weekdays,
'days'=>$days,
'meta'=>array
(
'mec_source'=>'event_manager_recurring',
'mec_emr_id'=>$third_party_id,
'mec_allday'=>$allday,
'hide_end_time'=>$hide_end_time,
'mec_repeat_end'=>($finish ? 'date' : 'never'),
'mec_repeat_end_at_occurrences'=>9,
'mec_repeat_end_at_date'=>$finish,
'mec_in_days'=>$days,
'mec_advanced_days'=>$advanced_days,
)
);
$post_id = $this->db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$third_party_id' AND `meta_key`='mec_emr_id'", 'loadResult');
// Insert the event into MEC
$post_id = $this->main->save_event($args, $post_id);
// Set location to the post
if($location_id) wp_set_object_terms($post_id, (int) $location_id, 'mec_location');
// Set categories to the post
if(count($category_ids)) foreach($category_ids as $category_id) wp_set_object_terms($post_id, (int) $category_id, 'mec_category', true);
// Set Features Image
if(isset($this->ix['import_featured_image']) and $this->ix['import_featured_image'] and $thumbnail_id = get_post_thumbnail_id($ID))
{
set_post_thumbnail($post_id, $thumbnail_id);
}
$count++;
}
return array('success'=>1, 'data'=>$count);
}
public function thirdparty_ems_import_do()
{
$IDs = isset($_POST['tp-events']) ? $_POST['tp-events'] : array();
$count = 0;
foreach($IDs as $ID)
{
$post = get_post($ID);
$metas = $this->main->get_post_meta($ID);
// Event Title and Content
$title = $post->post_title;
$description = $post->post_content;
$third_party_id = $ID;
// Event location
$location = $this->db->select("SELECT * FROM `#__em_locations` WHERE `location_id`='".(isset($metas['_location_id']) ? $metas['_location_id'] : 0)."'", 'loadAssoc');
$location_id = 1;
// Import Event Locations into MEC locations
if(isset($this->ix['import_locations']) and $this->ix['import_locations'] and isset($location['post_id']))
{
$address = $location['location_address'].' '.$location['location_region'].' '.$location['location_town'].' '.$location['location_state'].' '.$location['location_country'];
$location_id = $this->main->save_location(array
(
'name'=>trim($location['location_name']),
'address'=>trim($address),
'latitude'=>trim($location['location_latitude']),
'longitude'=>trim($location['location_longitude']),
));
}
// Event Categories
$categories = wp_get_post_terms($ID, 'event-categories');
$category_ids = array();
// Import Event Categories into MEC categories
if(isset($this->ix['import_categories']) and $this->ix['import_categories'] and count($categories))
{
foreach($categories as $category)
{
$category_id = $this->main->save_category(array
(
'name'=>trim($category->name),
));
if($category_id) $category_ids[] = $category_id;
}
}
// Event Start Date and Time
$date_start = new DateTime(date('Y-m-d G:i', strtotime($metas['_event_start_local'])));
$start_date = $date_start->format('Y-m-d');
$start_hour = $date_start->format('g');
$start_minutes = $date_start->format('i');
$start_ampm = $date_start->format('A');
// Event End Date and Time
$date_end = new DateTime(date('Y-m-d G:i', strtotime($metas['_event_end_local'])));
$end_date = $date_end->format('Y-m-d');
$end_hour = $date_end->format('g');
$end_minutes = $date_end->format('i');
$end_ampm = $date_end->format('A');
// Event Time Options
$hide_end_time = 0;
$allday = isset($metas['_event_all_day']) ? $metas['_event_all_day'] : 0;
// Single Event
$repeat_status = 0;
$repeat_type = '';
$interval = NULL;
$finish = $end_date;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = NULL;
$args = array
(
'title'=>$title,
'content'=>$description,
'location_id'=>$location_id,
'organizer_id'=>1,
'date'=>array
(
'start'=>array(
'date'=>$start_date,
'hour'=>$start_hour,
'minutes'=>$start_minutes,
'ampm'=>$start_ampm,
),
'end'=>array(
'date'=>$end_date,
'hour'=>$end_hour,
'minutes'=>$end_minutes,
'ampm'=>$end_ampm,
),
'repeat'=>array(
'end'=>'date',
'end_at_date'=>$finish,
'end_at_occurrences'=>10,
),
'allday'=>$allday,
'comment'=>'',
'hide_time'=>0,
'hide_end_time'=>$hide_end_time,
),
'start'=>$start_date,
'start_time_hour'=>$start_hour,
'start_time_minutes'=>$start_minutes,
'start_time_ampm'=>$start_ampm,
'end'=>$end_date,
'end_time_hour'=>$end_hour,
'end_time_minutes'=>$end_minutes,
'end_time_ampm'=>$end_ampm,
'repeat_status'=>$repeat_status,
'repeat_type'=>$repeat_type,
'interval'=>$interval,
'finish'=>$finish,
'year'=>$year,
'month'=>$month,
'day'=>$day,
'week'=>$week,
'weekday'=>$weekday,
'weekdays'=>$weekdays,
'days'=>$days,
'meta'=>array
(
'mec_source'=>'event_manager_single',
'mec_ems_id'=>$third_party_id,
'mec_allday'=>$allday,
'hide_end_time'=>$hide_end_time,
'mec_repeat_end'=>($finish ? 'date' : 'never'),
'mec_repeat_end_at_occurrences'=>9,
'mec_repeat_end_at_date'=>$finish,
'mec_in_days'=>$days,
)
);
$post_id = $this->db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$third_party_id' AND `meta_key`='mec_ems_id'", 'loadResult');
// Insert the event into MEC
$post_id = $this->main->save_event($args, $post_id);
// Set location to the post
if($location_id) wp_set_object_terms($post_id, (int) $location_id, 'mec_location');
// Set categories to the post
if(count($category_ids)) foreach($category_ids as $category_id) wp_set_object_terms($post_id, (int) $category_id, 'mec_category', true);
// Set Features Image
if(isset($this->ix['import_featured_image']) and $this->ix['import_featured_image'] and $thumbnail_id = get_post_thumbnail_id($ID))
{
set_post_thumbnail($post_id, $thumbnail_id);
}
$count++;
}
return array('success'=>1, 'data'=>$count);
}
public function thirdparty_wpem_import_do()
{
$IDs = isset($_POST['tp-events']) ? $_POST['tp-events'] : array();
$count = 0;
foreach($IDs as $ID)
{
$post = get_post($ID);
$metas = $this->main->get_post_meta($ID);
// Event Title and Content
$title = $post->post_title;
$description = $post->post_content;
$third_party_id = $ID;
// Event location
$location = get_post($metas['_event_venue_ids']);
$location_id = 1;
// Import Event Locations into MEC locations
if(isset($this->ix['import_locations']) and $this->ix['import_locations'] and isset($location->ID))
{
$l_metas = $this->main->get_post_meta($location->ID);
$thumbnail = has_post_thumbnail($location->ID) ? $this->main->get_post_thumbnail_url($location->ID, 'full') : '';
$location_id = $this->main->save_location(array
(
'name'=>trim($location->post_title),
'address'=>(isset($l_metas['_venue_description']) ? $l_metas['_venue_description'] : ''),
'latitude'=>0,
'longitude'=>0,
'thumbnail'=>$thumbnail
));
}
// Event Organizer
$organizers = $metas['_event_organizer_ids'];
$organizer = (isset($organizers[0]) ? get_post($organizers[0]) : new stdClass());
if(isset($organizers[0])) unset($organizers[0]);
$wpem_additional_organizers_ids = $organizers;
$organizer_id = 1;
$additional_organizers_ids = array();
// Import Event Organizer into MEC organizers
if(isset($this->ix['import_organizers']) and $this->ix['import_organizers'] and isset($organizer->ID))
{
$o_metas = $this->main->get_post_meta($organizer->ID);
$organizer_id = $this->main->save_organizer(array
(
'name'=>trim($organizer->post_title),
'tel'=>'',
'email'=>(isset($o_metas['_organizer_email']) ? $o_metas['_organizer_email'] : ''),
'url'=>(isset($o_metas['_organizer_website']) ? $o_metas['_organizer_website'] : ''),
));
if(is_array($wpem_additional_organizers_ids) and count($wpem_additional_organizers_ids))
{
foreach($wpem_additional_organizers_ids as $wpem_additional_organizers_id)
{
$o_organizer = get_post($wpem_additional_organizers_id);
$o_metas = $this->main->get_post_meta($wpem_additional_organizers_id);
$additional_organizers_ids[] = $this->main->save_organizer(array
(
'name'=>trim($o_organizer->post_title),
'tel'=>'',
'email'=>(isset($o_metas['_organizer_email']) ? $o_metas['_organizer_email'] : ''),
'url'=>(isset($o_metas['_organizer_website']) ? $o_metas['_organizer_website'] : ''),
));
}
}
}
// Event Categories
$categories = wp_get_post_terms($ID, 'event_listing_category');
$category_ids = array();
// Import Event Categories into MEC categories
if(isset($this->ix['import_categories']) and $this->ix['import_categories'] and count($categories))
{
foreach($categories as $category)
{
$category_id = $this->main->save_category(array
(
'name'=>trim($category->name),
));
if($category_id) $category_ids[] = $category_id;
}
}
// Event Start Date and Time
$date_start = new DateTime(date('Y-m-d G:i', strtotime($metas['_event_start_date'])));
$start_date = $date_start->format('Y-m-d');
$start_hour = $date_start->format('g');
$start_minutes = $date_start->format('i');
$start_ampm = $date_start->format('A');
// Event End Date and Time
$date_end = new DateTime(date('Y-m-d G:i', strtotime($metas['_event_end_date'])));
$end_date = $date_end->format('Y-m-d');
$end_hour = $date_end->format('g');
$end_minutes = $date_end->format('i');
$end_ampm = $date_end->format('A');
// Event Time Options
$hide_end_time = 0;
$allday = 0;
// Single Event
$repeat_status = 0;
$repeat_type = '';
$interval = NULL;
$finish = $end_date;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$days = NULL;
$args = array
(
'title'=>$title,
'content'=>$description,
'location_id'=>$location_id,
'organizer_id'=>$organizer_id,
'date'=>array
(
'start'=>array(
'date'=>$start_date,
'hour'=>$start_hour,
'minutes'=>$start_minutes,
'ampm'=>$start_ampm,
),
'end'=>array(
'date'=>$end_date,
'hour'=>$end_hour,
'minutes'=>$end_minutes,
'ampm'=>$end_ampm,
),
'repeat'=>array(
'end'=>'date',
'end_at_date'=>$finish,
'end_at_occurrences'=>10,
),
'allday'=>$allday,
'comment'=>'',
'hide_time'=>0,
'hide_end_time'=>$hide_end_time,
),
'start'=>$start_date,
'start_time_hour'=>$start_hour,
'start_time_minutes'=>$start_minutes,
'start_time_ampm'=>$start_ampm,
'end'=>$end_date,
'end_time_hour'=>$end_hour,
'end_time_minutes'=>$end_minutes,
'end_time_ampm'=>$end_ampm,
'repeat_status'=>$repeat_status,
'repeat_type'=>$repeat_type,
'interval'=>$interval,
'finish'=>$finish,
'year'=>$year,
'month'=>$month,
'day'=>$day,
'week'=>$week,
'weekday'=>$weekday,
'weekdays'=>$weekdays,
'days'=>$days,
'meta'=>array
(
'mec_source'=>'the-events-calendar',
'mec_tec_id'=>$third_party_id,
'mec_allday'=>$allday,
'hide_end_time'=>$hide_end_time,
'mec_repeat_end'=>'date',
'mec_repeat_end_at_occurrences'=>9,
'mec_repeat_end_at_date'=>$finish,
'mec_in_days'=>$days,
'mec_more_info'=>'',
'mec_cost'=>'',
)
);
$post_id = $this->db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$third_party_id' AND `meta_key`='mec_tec_id'", 'loadResult');
// Insert the event into MEC
$post_id = $this->main->save_event($args, $post_id);
// Set location to the post
if($location_id) wp_set_object_terms($post_id, (int) $location_id, 'mec_location');
// Set organizer to the post
if($organizer_id) wp_set_object_terms($post_id, (int) $organizer_id, 'mec_organizer');
// Set additional organizers
if(is_array($additional_organizers_ids) and count($additional_organizers_ids))
{
foreach($additional_organizers_ids as $additional_organizers_id) wp_set_object_terms($post_id, (int) $additional_organizers_id, 'mec_organizer', true);
update_post_meta($post_id, 'mec_additional_organizer_ids', $additional_organizers_ids);
}
// Set categories to the post
if(count($category_ids)) foreach($category_ids as $category_id) wp_set_object_terms($post_id, (int) $category_id, 'mec_category', true);
// Set Features Image
if(isset($this->ix['import_featured_image']) and $this->ix['import_featured_image'] and $thumbnail_id = get_post_thumbnail_id($ID))
{
set_post_thumbnail($post_id, $thumbnail_id);
}
$count++;
}
return array('success'=>1, 'data'=>$count);
}
/**
* Show content of export tab
* @author Webnus <[email protected]>
* @return void
*/
public function ix_g_calendar_export()
{
// Current Action
$this->action = isset($_POST['mec-ix-action']) ? sanitize_text_field($_POST['mec-ix-action']) : (isset($_GET['mec-ix-action']) ? sanitize_text_field($_GET['mec-ix-action']) : '');
$path = MEC::import('app.features.ix.export_g_calendar', true, true);
ob_start();
include $path;
echo $output = ob_get_clean();
}
/**
* Show content of import tab
* @author Webnus <[email protected]>
* @return void
*/
public function ix_g_calendar_import()
{
// Current Action
$this->action = isset($_POST['mec-ix-action']) ? sanitize_text_field($_POST['mec-ix-action']) : '';
$this->ix = isset($_POST['ix']) ? $_POST['ix'] : array();
$this->response = array();
if($this->action == 'google-calendar-import-start') $this->response = $this->g_calendar_import_start();
elseif($this->action == 'google-calendar-import-do') $this->response = $this->g_calendar_import_do();
$path = MEC::import('app.features.ix.import_g_calendar', true, true);
ob_start();
include $path;
echo $output = ob_get_clean();
}
public function g_calendar_import_start()
{
$api_key = isset($this->ix['google_import_api_key']) ? $this->ix['google_import_api_key'] : NULL;
$calendar_id = isset($this->ix['google_import_calendar_id']) ? $this->ix['google_import_calendar_id'] : NULL;
$start_date = isset($this->ix['google_import_start_date']) ? $this->ix['google_import_start_date'] : 'Today';
$end_date = (isset($this->ix['google_import_end_date']) and trim($this->ix['google_import_end_date'])) ? $this->ix['google_import_end_date'] : 'Tomorrow';
if(!trim($api_key) or !trim($calendar_id)) return array('success'=>0, 'error'=>__('API key and Calendar ID are required!', 'modern-events-calendar-lite'));
// Save options
$this->main->save_ix_options(array('google_import_api_key'=>$api_key, 'google_import_calendar_id'=>$calendar_id, 'google_import_start_date'=>$start_date, 'google_import_end_date'=>$end_date));
// GMT Offset
$gmt_offset = $this->main->get_gmt_offset();
$client = new Google_Client();
$client->setApplicationName('Modern Events Calendar');
$client->setAccessType('online');
$client->setScopes(array('https://www.googleapis.com/auth/calendar.readonly'));
$client->setDeveloperKey($api_key);
$service = new Google_Service_Calendar($client);
$data = array();
try
{
$args = array();
$args['timeMin'] = date('Y-m-d\TH:i:s', strtotime($start_date)).$gmt_offset;
$args['timeMax'] = date('Y-m-d\TH:i:s', strtotime($end_date)).$gmt_offset;
$args['maxResults'] = 50000;
$response = $service->events->listEvents($calendar_id, $args);
$data['id'] = $calendar_id;
$data['title'] = $response->getSummary();
$data['timezone'] = $response->getTimeZone();
$data['events'] = array();
foreach($response->getItems() as $event)
{
$title = $event->getSummary();
if(trim($title) == '') continue;
// Import Only Main Events
if($event->getRecurringEventId()) continue;
$data['events'][] = array('id'=>$event->id, 'title'=>$title, 'start'=>$event->getStart(), 'end'=>$event->getEnd());
}
$data['count'] = count($data['events']);
}
catch(Exception $e)
{
$error = $e->getMessage();
return array('success'=>0, 'error'=>$error);
}
return array('success'=>1, 'data'=>$data);
}
public function g_calendar_import_do()
{
$g_events = isset($_POST['g-events']) ? $_POST['g-events'] : array();
if(!count($g_events)) return array('success'=>0, 'error'=>__('Please select events to import!', 'modern-events-calendar-lite'));
$api_key = isset($this->ix['google_import_api_key']) ? $this->ix['google_import_api_key'] : NULL;
$calendar_id = isset($this->ix['google_import_calendar_id']) ? $this->ix['google_import_calendar_id'] : NULL;
if(!trim($api_key) or !trim($calendar_id)) return array('success'=>0, 'error'=>__('API key and Calendar ID are required!', 'modern-events-calendar-lite'));
// Timezone
$timezone = $this->main->get_timezone();
$client = new Google_Client();
$client->setApplicationName('Modern Events Calendar');
$client->setAccessType('online');
$client->setScopes(array('https://www.googleapis.com/auth/calendar.readonly'));
$client->setDeveloperKey($api_key);
$service = new Google_Service_Calendar($client);
$post_ids = array();
foreach($g_events as $g_event)
{
try
{
$event = $service->events->get($calendar_id, $g_event, array('timeZone' => $timezone));
}
catch(Exception $e)
{
continue;
}
// Event Title and Content
$title = $event->getSummary();
$description = $event->getDescription();
$gcal_ical_uid = $event->getICalUID();
$gcal_id = $event->getId();
// Event location
$location = $event->getLocation();
$location_id = 1;
// Import Event Locations into MEC locations
if(isset($this->ix['import_locations']) and $this->ix['import_locations'] and trim($location))
{
$location_ex = explode(',', $location);
$location_id = $this->main->save_location(array
(
'name'=>trim($location_ex[0]),
'address'=>$location
));
}
// Event Organizer
$organizer = $event->getOrganizer();
$organizer_id = 1;
// Import Event Organizer into MEC organizers
if(isset($this->ix['import_organizers']) and $this->ix['import_organizers'])
{
$organizer_id = $this->main->save_organizer(array
(
'name'=>$organizer->getDisplayName(),
'email'=>$organizer->getEmail()
));
}
// Event Start Date and Time
$start = $event->getStart();
$g_start_date = $start->getDate();
$g_start_datetime = $start->getDateTime();
$date_start = new DateTime((trim($g_start_datetime) ? $g_start_datetime : $g_start_date));
$start_date = $date_start->format('Y-m-d');
$start_hour = 8;
$start_minutes = '00';
$start_ampm = 'AM';
if(trim($g_start_datetime))
{
$start_hour = $date_start->format('g');
$start_minutes = $date_start->format('i');
$start_ampm = $date_start->format('A');
}
// Event End Date and Time
$end = $event->getEnd();
$g_end_date = $end->getDate();
$g_end_datetime = $end->getDateTime();
$date_end = new DateTime((trim($g_end_datetime) ? $g_end_datetime : $g_end_date));
$end_date = $date_end->format('Y-m-d');
$end_hour = 6;
$end_minutes = '00';
$end_ampm = 'PM';
if(trim($g_end_datetime))
{
$end_hour = $date_end->format('g');
$end_minutes = $date_end->format('i');
$end_ampm = $date_end->format('A');
}
// Event Time Options
$allday = 0;
// Both Start and Date times are empty so it's all day event
if(!trim($g_end_datetime) and !trim($g_start_datetime))
{
$allday = 1;
$start_hour = 0;
$start_minutes = 0;
$start_ampm = 'AM';
$end_hour = 11;
$end_minutes = 55;
$end_ampm = 'PM';
}
// Recurring Event
if($event->getRecurrence())
{
$repeat_status = 1;
$r_rules = $event->getRecurrence();
$i = 0;
do
{
$g_recurrence_rule = $r_rules[$i];
$main_rule_ex = explode(':', $g_recurrence_rule);
$rules = explode(';', $main_rule_ex[1]);
$i++;
}
while($main_rule_ex[0] != 'RRULE' and isset($r_rules[$i]));
$rule = array();
foreach($rules as $rule_row)
{
$ex = explode('=', $rule_row);
$key = strtolower($ex[0]);
$value = ($key == 'until' ? $ex[1] : strtolower($ex[1]));
$rule[$key] = $value;
}
$interval = NULL;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$weekdays = NULL;
$advanced_days = NULL;
if($rule['freq'] == 'daily')
{
$repeat_type = 'daily';
$interval = isset($rule['interval']) ? $rule['interval'] : 1;
}
elseif($rule['freq'] == 'weekly')
{
$repeat_type = 'weekly';
$interval = isset($rule['interval']) ? $rule['interval']*7 : 7;
}
elseif($rule['freq'] == 'monthly' and isset($rule['byday']) and trim($rule['byday']))
{
$repeat_type = 'advanced';
$adv_week = (isset($rule['bysetpos']) and trim($rule['bysetpos']) != '') ? $rule['bysetpos'] : (int) substr($rule['byday'], 0, -2);
if($adv_week < 0) $adv_week = 'l';
$adv_day = str_replace($adv_week, '', $rule['byday']);
$mec_adv_day = 'Sat';
if($adv_day == 'su') $mec_adv_day = 'Sun';
elseif($adv_day == 'mo') $mec_adv_day = 'Mon';
elseif($adv_day == 'tu') $mec_adv_day = 'Tue';
elseif($adv_day == 'we') $mec_adv_day = 'Wed';
elseif($adv_day == 'th') $mec_adv_day = 'Thu';
elseif($adv_day == 'fr') $mec_adv_day = 'Fri';
$advanced_days = array($mec_adv_day.'.'.$adv_week);
}
elseif($rule['freq'] == 'monthly')
{
$repeat_type = 'monthly';
$interval = isset($rule['interval']) ? $rule['interval'] : 1;
$year = '*';
$month = '*';
$s = $start_date;
$e = $end_date;
$_days = array();
while(strtotime($s) <= strtotime($e))
{
$_days[] = date('d', strtotime($s));
$s = date('Y-m-d', strtotime('+1 Day', strtotime($s)));
}
$day = ','.implode(',', array_unique($_days)).',';
$week = '*';
$weekday = '*';
}
elseif($rule['freq'] == 'yearly')
{
$repeat_type = 'yearly';
$year = '*';
$s = $start_date;
$e = $end_date;
$_months = array();
$_days = array();
while(strtotime($s) <= strtotime($e))
{
$_months[] = date('m', strtotime($s));
$_days[] = date('d', strtotime($s));
$s = date('Y-m-d', strtotime('+1 Day', strtotime($s)));
}
$month = ','.implode(',', array_unique($_months)).',';
$day = ','.implode(',', array_unique($_days)).',';
$week = '*';
$weekday = '*';
}
else $repeat_type = '';
// Custom Week Days
if($repeat_type == 'weekly' and isset($rule['byday']) and count(explode(',', $rule['byday'])) > 1)
{
$g_week_days = explode(',', $rule['byday']);
$week_day_mapping = array('mo'=>1, 'tu'=>2, 'we'=>3, 'th'=>4, 'fr'=>5, 'sa'=>6, 'su'=>7);
$weekdays = '';
foreach($g_week_days as $g_week_day) $weekdays .= $week_day_mapping[$g_week_day].',';
$weekdays = ','.trim($weekdays, ', ').',';
$interval = NULL;
$repeat_type = 'certain_weekdays';
}
$finish = isset($rule['until']) ? date('Y-m-d', strtotime($rule['until'])) : NULL;
// It's all day event so we should reduce one day from the end date! Google provides 2020-12-12 while the event ends at 2020-12-11
if($allday)
{
$diff = $this->main->date_diff($start_date, $end_date);
if(($diff ? $diff->days : 0) >= 1)
{
$date_end->sub(new DateInterval('P1D'));
$end_date = $date_end->format('Y-m-d');
}
}
}
// Single Event
else
{
// It's a one day single event but google sends 2020-12-12 as end date if start date is 2020-12-11
if(trim($g_end_datetime) == '' and date('Y-m-d', strtotime('-1 day', strtotime($end_date))) == $start_date)
{
$end_date = $start_date;
}
// It's all day event so we should reduce one day from the end date! Google provides 2020-12-12 while the event ends at 2020-12-11
elseif($allday)
{
$diff = $this->main->date_diff($start_date, $end_date);
if(($diff ? $diff->days : 0) > 1)
{
$date_end->sub(new DateInterval('P1D'));
$end_date = $date_end->format('Y-m-d');
}
}
$repeat_status = 0;
$g_recurrence_rule = '';
$repeat_type = '';
$interval = NULL;
$finish = $end_date;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
$advanced_days = NULL;
}
$args = array
(
'title'=>$title,
'content'=>$description,
'location_id'=>$location_id,
'organizer_id'=>$organizer_id,
'date'=>array
(
'start'=>array(
'date'=>$start_date,
'hour'=>$start_hour,
'minutes'=>$start_minutes,
'ampm'=>$start_ampm,
),
'end'=>array(
'date'=>$end_date,
'hour'=>$end_hour,
'minutes'=>$end_minutes,
'ampm'=>$end_ampm,
),
'repeat'=>array(),
'allday'=>$allday,
'comment'=>'',
'hide_time'=>0,
'hide_end_time'=>0,
),
'start'=>$start_date,
'start_time_hour'=>$start_hour,
'start_time_minutes'=>$start_minutes,
'start_time_ampm'=>$start_ampm,
'end'=>$end_date,
'end_time_hour'=>$end_hour,
'end_time_minutes'=>$end_minutes,
'end_time_ampm'=>$end_ampm,
'repeat_status'=>$repeat_status,
'repeat_type'=>$repeat_type,
'interval'=>$interval,
'finish'=>$finish,
'year'=>$year,
'month'=>$month,
'day'=>$day,
'week'=>$week,
'weekday'=>$weekday,
'weekdays'=>$weekdays,
'meta'=>array
(
'mec_source'=>'google-calendar',
'mec_gcal_ical_uid'=>$gcal_ical_uid,
'mec_gcal_id'=>$gcal_id,
'mec_gcal_calendar_id'=>$calendar_id,
'mec_g_recurrence_rule'=>$g_recurrence_rule,
'mec_allday'=>$allday,
'mec_advanced_days'=>$advanced_days,
)
);
$post_id = $this->db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$gcal_id' AND `meta_key`='mec_gcal_id'", 'loadResult');
// Imported From Google
if(!post_exists($title, $description, '', $this->main->get_main_post_type())) $args['meta']['mec_imported_from_google'] = 1;
// Insert the event into MEC
$post_id = $this->main->save_event($args, $post_id);
$post_ids[] = $post_id;
// Set location to the post
if($location_id) wp_set_object_terms($post_id, (int) $location_id, 'mec_location');
// Set organizer to the post
if($organizer_id) wp_set_object_terms($post_id, (int) $organizer_id, 'mec_organizer');
// MEC Dates
$dates = $this->db->select("SELECT `dstart` FROM `#__mec_dates` WHERE `post_id`='".$post_id."' ORDER BY `tstart` ASC LIMIT 50", 'loadColumn');
// Event Instances
$instances = $service->events->instances($calendar_id, $gcal_id, array('maxResults' => 50));
$gdates = array();
foreach($instances as $instance)
{
$start = $instance->getStart();
$date = $start->getDate();
$gdates[] = $date;
}
$exdates = array();
$previous_not_found = NULL;
$next_found = NULL;
foreach($dates as $date)
{
if(!in_array($date, $gdates)) $previous_not_found = $date;
elseif($previous_not_found)
{
$exdates[] = $previous_not_found;
$previous_not_found = NULL;
}
}
// Update MEC EXDATES
$exdates = array_unique($exdates);
if(count($exdates))
{
$args['not_in_days'] = implode(',', $exdates);
$this->main->save_event($args, $post_id);
}
}
return array('success'=>1, 'data'=>$post_ids);
}
/**
* Show content of meetup import tab
* @author Webnus <[email protected]>
* @return void
*/
public function ix_meetup_import()
{
// Current Action
$this->action = isset($_POST['mec-ix-action']) ? sanitize_text_field($_POST['mec-ix-action']) : '';
$this->ix = isset($_POST['ix']) ? $_POST['ix'] : array();
$this->response = array();
if($this->action == 'meetup-import-start') $this->response = $this->meetup_import_start();
elseif($this->action == 'meetup-import-do') $this->response = $this->meetup_import_do();
$path = MEC::import('app.features.ix.import_meetup', true, true);
ob_start();
include $path;
echo $output = ob_get_clean();
}
public function meetup_import_start()
{
$api_key = isset($this->ix['meetup_api_key']) ? $this->ix['meetup_api_key'] : NULL;
$group_url = isset($this->ix['meetup_group_url']) ? $this->ix['meetup_group_url'] : NULL;
if(!trim($api_key) or !trim($group_url)) return array('success'=>0, 'error'=>__('API key and Group URL are required!', 'modern-events-calendar-lite'));
// Save options
$this->main->save_ix_options(array('meetup_api_key'=>$api_key, 'meetup_group_url'=>$group_url));
// Timezone
$timezone = $this->main->get_timezone();
$data = array();
try
{
$meetup = new Meetup(array(
'key' => $api_key
));
$events = $meetup->getEvents(array(
'urlname' => $group_url,
));
$m_events = array();
$group_name = '';
foreach($events as $event)
{
$title = $event->name;
if(trim($title) == '') continue;
if(isset($event->group)) $group_name = $event->group->name;
$start = (int) ($event->time/1000);
$end = (int) (($event->time+$event->duration)/1000);
$start_date = new DateTime(date('Y-m-d H:i:s', $start), new DateTimeZone('UTC'));
$start_date->setTimezone(new DateTimeZone($timezone));
$end_date = new DateTime(date('Y-m-d H:i:s', $end), new DateTimeZone('UTC'));
$end_date->setTimezone(new DateTimeZone($timezone));
$m_events[] = array('id'=>$event->id, 'title'=>$title, 'start'=>$start_date->format('Y-m-d H:i:s'), 'end'=>$end_date->format('Y-m-d H:i:s'));
}
$data['title'] = $group_name;
$data['events'] = $m_events;
$data['count'] = count($m_events);
}
catch(Exception $e)
{
$error = $e->getMessage();
return array('success'=>0, 'error'=>$error);
}
return array('success'=>1, 'data'=>$data);
}
public function meetup_import_do()
{
$m_events = isset($_POST['m-events']) ? $_POST['m-events'] : array();
if(!count($m_events)) return array('success'=>0, 'error'=>__('Please select events to import!', 'modern-events-calendar-lite'));
$api_key = isset($this->ix['meetup_api_key']) ? $this->ix['meetup_api_key'] : NULL;
$group_url = isset($this->ix['meetup_group_url']) ? $this->ix['meetup_group_url'] : NULL;
if(!trim($api_key) or !trim($group_url)) return array('success'=>0, 'error'=>__('API key and Group URL are required!', 'modern-events-calendar-lite'));
// Timezone
$timezone = $this->main->get_timezone();
// MEC File
$file = $this->getFile();
$wp_upload_dir = wp_upload_dir();
$post_ids = array();
foreach($m_events as $m_event)
{
try
{
$meetup = new Meetup(array(
'key' => $api_key
));
$event = $meetup->getEvent(array(
'urlname' => $group_url,
'id' => $m_event,
'fields' => 'event_hosts,featured_photo,series,short_link'
));
}
catch(Exception $e)
{
continue;
}
// Check if Series already Imported
$series_id = NULL;
if(isset($event->series) and isset($event->series->id))
{
$series_id = $event->series->id;
$post_id = $this->db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$series_id' AND `meta_key`='mec_meetup_series_id'", 'loadResult');
if($post_id) continue;
}
// Event Title and Content
$title = $event->name;
$description = $event->description;
$mcal_id = $event->id;
// Event location
$location = isset($event->venue) ? $event->venue : NULL;
$location_id = 1;
// Import Event Locations into MEC locations
if(isset($this->ix['import_locations']) and $this->ix['import_locations'] and $location)
{
$address = isset($location->address_1) ? $location->address_1 : '';
$address .= isset($location->city) ? ', '.$location->city : '';
$address .= isset($location->state) ? ', '.$location->state : '';
$address .= isset($location->localized_country_name) ? ', '.$location->localized_country_name : '';
$location_id = $this->main->save_location(array
(
'name'=>trim($location->name),
'latitude'=>trim($location->lat),
'longitude'=>trim($location->lon),
'address'=>$address
));
}
// Event Organizer
$organizers = isset($event->event_hosts) ? $event->event_hosts : NULL;
$main_organizer_id = 1;
$additional_organizer_ids = array();
// Import Event Organizer into MEC organizers
if(isset($this->ix['import_organizers']) and $this->ix['import_organizers'] and $organizers)
{
$o = 1;
foreach($organizers as $organizer)
{
$organizer_id = $this->main->save_organizer(array
(
'name'=>$organizer->name,
'thumbnail'=>((isset($organizer->photo) and isset($organizer->photo->photo_link)) ? $organizer->photo->photo_link : NULL)
));
if($o == 1) $main_organizer_id = $organizer_id;
else $additional_organizer_ids[] = $organizer_id;
$o++;
}
}
// Event Start Date and Time
$start = (int) ($event->time/1000);
$date_start = new DateTime(date('Y-m-d H:i:s', $start), new DateTimeZone('UTC'));
$date_start->setTimezone(new DateTimeZone($timezone));
$start_date = $date_start->format('Y-m-d');
$start_hour = $date_start->format('g');
$start_minutes = $date_start->format('i');
$start_ampm = $date_start->format('A');
// Event End Date and Time
$end = (int) (($event->time+$event->duration)/1000);
$date_end = new DateTime(date('Y-m-d H:i:s', $end), new DateTimeZone('UTC'));
$date_end->setTimezone(new DateTimeZone($timezone));
$end_date = $date_end->format('Y-m-d');
$end_hour = $date_end->format('g');
$end_minutes = $date_end->format('i');
$end_ampm = $date_end->format('A');
// Meetup Link
$more_info = isset($event->link) ? $event->link : (isset($event->short_link) ? $event->short_link : '');
// Fee Options
$fee = 0;
if(isset($event->fee)) $fee = $event->fee->amount.' '.$event->fee->currency;
// Event Time Options
$allday = 0;
// Recurring Event
if(isset($event->series) and $event->series)
{
$repeat_status = 1;
$interval = NULL;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
if(isset($event->series->weekly))
{
$repeat_type = 'weekly';
$interval = isset($event->series->weekly->interval) ? $event->series->weekly->interval*7 : 7;
}
elseif(isset($event->series->monthly))
{
$repeat_type = 'monthly';
$year = '*';
$month = '*';
$s = $start_date;
$e = $end_date;
$_days = array();
while(strtotime($s) <= strtotime($e))
{
$_days[] = date('d', strtotime($s));
$s = date('Y-m-d', strtotime('+1 Day', strtotime($s)));
}
$day = ','.implode(',', array_unique($_days)).',';
$week = '*';
$weekday = '*';
}
else $repeat_type = '';
// Custom Week Days
if($repeat_type == 'weekly' and isset($event->series->weekly->days_of_week) and is_array($event->series->weekly->days_of_week) and count($event->series->weekly->days_of_week))
{
$weekdays = ','.trim(implode(',', $event->series->weekly->days_of_week), ', ').',';
$interval = NULL;
$repeat_type = 'certain_weekdays';
}
$finish = isset($event->series->end_date) ? date('Y-m-d', ($event->series->end_date/1000)) : NULL;
}
// Single Event
else
{
$repeat_status = 0;
$repeat_type = '';
$interval = NULL;
$finish = $end_date;
$year = NULL;
$month = NULL;
$day = NULL;
$week = NULL;
$weekday = NULL;
$weekdays = NULL;
}
$args = array
(
'title'=>$title,
'content'=>$description,
'location_id'=>$location_id,
'organizer_id'=>$main_organizer_id,
'date'=>array
(
'start'=>array(
'date'=>$start_date,
'hour'=>$start_hour,
'minutes'=>$start_minutes,
'ampm'=>$start_ampm,
),
'end'=>array(
'date'=>$end_date,
'hour'=>$end_hour,
'minutes'=>$end_minutes,
'ampm'=>$end_ampm,
),
'repeat'=>array(),
'allday'=>$allday,
'comment'=>'',
'hide_time'=>0,
'hide_end_time'=>0,
),
'start'=>$start_date,
'start_time_hour'=>$start_hour,
'start_time_minutes'=>$start_minutes,
'start_time_ampm'=>$start_ampm,
'end'=>$end_date,
'end_time_hour'=>$end_hour,
'end_time_minutes'=>$end_minutes,
'end_time_ampm'=>$end_ampm,
'repeat_status'=>$repeat_status,
'repeat_type'=>$repeat_type,
'interval'=>$interval,
'finish'=>$finish,
'year'=>$year,
'month'=>$month,
'day'=>$day,
'week'=>$week,
'weekday'=>$weekday,
'weekdays'=>$weekdays,
'meta'=>array
(
'mec_source'=>'meetup',
'mec_meetup_id'=>$mcal_id,
'mec_meetup_series_id'=>$series_id,
'mec_more_info'=>$more_info,
'mec_more_info_title'=>__('Check at Meetup', 'modern-events-calendar-lite'),
'mec_more_info_target'=>'_self',
'mec_cost'=>$fee,
'mec_meetup_url'=>$group_url,
'mec_allday'=>$allday
)
);
$post_id = $this->db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$mcal_id' AND `meta_key`='mec_meetup_id'", 'loadResult');
// Insert the event into MEC
$post_id = $this->main->save_event($args, $post_id);
$post_ids[] = $post_id;
// Set location to the post
if($location_id) wp_set_object_terms($post_id, (int) $location_id, 'mec_location');
// Set organizer to the post
if($main_organizer_id) wp_set_object_terms($post_id, (int) $main_organizer_id, 'mec_organizer');
// Set Additional Organizers
if(count($additional_organizer_ids))
{
foreach($additional_organizer_ids as $additional_organizer_id) wp_set_object_terms($post_id, (int) $additional_organizer_id, 'mec_organizer', true);
update_post_meta($post_id, 'mec_additional_organizer_ids', $additional_organizer_ids);
}
// Featured Image
if(!has_post_thumbnail($post_id) and isset($event->featured_photo) and isset($event->featured_photo->photo_link))
{
$photo = $this->main->get_web_page($event->featured_photo->photo_link);
$file_name = md5($post_id).'.'.$this->main->get_image_type_by_buffer($photo);
$path = rtrim($wp_upload_dir['path'], DS.' ').DS.$file_name;
$url = rtrim($wp_upload_dir['url'], '/ ').'/'.$file_name;
$file->write($path, $photo);
$this->main->set_featured_image($url, $post_id);
}
}
return array('success'=>1, 'data'=>$post_ids);
}
public function export_all_events_do()
{
// Current User Doesn't Have Access
if(!current_user_can('mec_import_export')) return false;
$format = isset($_GET['format']) ? sanitize_text_field($_GET['format']) : 'csv';
$events = $this->main->get_events('-1');
// MEC Render Library
$render = $this->getRender();
switch($format)
{
case 'ical':
$output = '';
foreach($events as $event) $output .= $this->main->ical_single($event->ID);
$ical_calendar = $this->main->ical_calendar($output);
header('Content-type: application/force-download; charset=utf-8');
header('Content-Disposition: attachment; filename="mec-events-'.date('YmdTHi').'.ics"');
echo $ical_calendar;
exit;
break;
case 'csv':
header('Content-Type: text/csv; charset=utf-8');
header('Content-Disposition: attachment; filename=mec-events-' . md5(time() . mt_rand(100, 999)) . '.csv');
$events_feature = new MEC_feature_events();
$events_feature->csvexcel(true);
exit;
break;
case 'ms-excel':
header('Content-Type: application/vnd.ms-excel; charset=utf-8');
header('Content-Disposition: attachment; filename="mec-events-'.md5(time().mt_rand(100, 999)).'.xls"');
$columns = array(__('ID', 'modern-events-calendar-lite'), __('Title', 'modern-events-calendar-lite'), __('Start Date', 'modern-events-calendar-lite'), __('Start Time', 'modern-events-calendar-lite'), __('End Date', 'modern-events-calendar-lite'), __('End Time', 'modern-events-calendar-lite'), __('Link', 'modern-events-calendar-lite'), $this->main->m('taxonomy_location', __('Location', 'modern-events-calendar-lite')), __('Address', 'modern-events-calendar-lite'), $this->main->m('taxonomy_organizer', __('Organizer', 'modern-events-calendar-lite')), __('Organizer Tel', 'modern-events-calendar-lite'), __('Organizer Email', 'modern-events-calendar-lite'), $this->main->m('event_cost', __('Event Cost', 'modern-events-calendar-lite')));
$output = fopen('php://output', 'w');
fwrite($output, "sep=\t".PHP_EOL);
fputcsv($output, $columns, "\t");
foreach($events as $event)
{
$event_id = $event->ID;
$data = $render->data($event_id);
$dates = $render->dates($event_id, $data);
$date = $dates[0];
$location = isset($data->locations[$data->meta['mec_location_id']]) ? $data->locations[$data->meta['mec_location_id']] : array();
$organizer = isset($data->organizers[$data->meta['mec_organizer_id']]) ? $data->organizers[$data->meta['mec_organizer_id']] : array();
$event = array(
$event_id,
html_entity_decode($data->title),
$date['start']['date'],
$data->time['start'],
$date['end']['date'],
$data->time['end'],
$data->permalink,
(isset($location['name']) ? html_entity_decode($location['name']) : ''),
(isset($location['address']) ? html_entity_decode($location['address']) : ''),
(isset($organizer['name']) ? html_entity_decode($organizer['name']) : ''),
(isset($organizer['tel']) ? $organizer['tel'] : ''),
(isset($organizer['email']) ? $organizer['email'] : ''),
(isset($data->meta['mec_cost']) ? (is_numeric($data->meta['mec_cost']) ? $this->main->render_price($data->meta['mec_cost'], $event_id) : $data->meta['mec_cost']) : '')
);
fputcsv($output, $event, "\t");
}
exit;
break;
case 'xml':
$output = array();
foreach($events as $event) $output[] = $this->main->export_single($event->ID);
$xml_feed = $this->main->xml_convert(array('events'=>$output));
header('Content-type: application/force-download; charset=utf-8');
header('Content-Disposition: attachment; filename="mec-events-'.date('YmdTHi').'.xml"');
echo $xml_feed;
exit;
break;
case 'json':
$output = array();
foreach($events as $event) $output[] = $this->main->export_single($event->ID);
header('Content-type: application/force-download; charset=utf-8');
header('Content-Disposition: attachment; filename="mec-events-'.date('YmdTHi').'.json"');
echo json_encode($output);
exit;
break;
}
}
public function export_all_bookings_do()
{
// Current User Doesn't Have Access
if(!current_user_can('mec_import_export')) return false;
$format = isset($_GET['format']) ? sanitize_text_field($_GET['format']) : 'csv';
switch($format)
{
case 'ms-excel':
header('Content-Type: application/vnd.ms-excel; charset=utf-8');
header('Content-Disposition: attachment; filename=bookings-'.md5(time().mt_rand(100, 999)).'.xls');
$this->bookings_csvexcel();
exit;
break;
case 'csv':
header('Content-Type: text/csv; charset=utf-8');
header('Content-Disposition: attachment; filename=bookings-'.md5(time().mt_rand(100, 999)).'.csv');
$this->bookings_csvexcel();
exit;
break;
}
}
public function bookings_csvexcel()
{
$bookings = get_posts(array('post_type'=>$this->main->get_book_post_type(), 'numberposts'=>-1, 'post_status'=>'publish'));
$booking_ids = array();
foreach($bookings as $booking) $booking_ids[] = $booking->ID;
$book = new MEC_feature_books();
$book->csvexcel($booking_ids);
}
public function g_calendar_export_authenticate()
{
$ix = isset($_POST['ix']) ? $_POST['ix'] : array();
$client_id = isset($ix['google_export_client_id']) ? $ix['google_export_client_id'] : NULL;
$client_secret = isset($ix['google_export_client_secret']) ? $ix['google_export_client_secret'] : NULL;
$calendar_id = isset($ix['google_export_calendar_id']) ? $ix['google_export_calendar_id'] : NULL;
$auth_url = '';
if(!trim($client_id) or !trim($client_secret) or !trim($calendar_id)) $this->main->response(array('success'=>0, 'message'=>__('All of Client ID, Client Secret, and Calendar ID are required!', 'modern-events-calendar-lite')));
// Save options
$this->main->save_ix_options(array('google_export_client_id'=>$client_id, 'google_export_client_secret'=>$client_secret, 'google_export_calendar_id'=>$calendar_id));
try
{
$client = new Google_Client();
$client->setApplicationName(get_bloginfo('name'));
$client->setAccessType('offline');
$client->setApprovalPrompt('force');
$client->setScopes(array('https://www.googleapis.com/auth/calendar'));
$client->setClientId($client_id);
$client->setClientSecret($client_secret);
$client->setRedirectUri($this->main->add_qs_vars(array('mec-ix-action'=>'google-calendar-export-get-token'), $this->main->URL('backend').'admin.php?page=MEC-ix&tab=MEC-g-calendar-export'));
$auth_url = filter_var($client->createAuthUrl(), FILTER_SANITIZE_URL);
}
catch(Exception $ex)
{
$this->main->response(array('success'=>0, 'message'=>$ex->getMessage()));
}
$this->main->response(array('success'=>1, 'message'=>sprintf(__('All seems good! Please click %s to authenticate your app.', 'modern-events-calendar-lite'), '<a href="'.$auth_url.'">'.__('here', 'modern-events-calendar-lite').'</a>')));
}
public function g_calendar_export_get_token()
{
$code = isset($_GET['code']) ? sanitize_text_field($_GET['code']) : '';
$ix = $this->main->get_ix_options();
$client_id = isset($ix['google_export_client_id']) ? $ix['google_export_client_id'] : NULL;
$client_secret = isset($ix['google_export_client_secret']) ? $ix['google_export_client_secret'] : NULL;
try
{
$client = new Google_Client();
$client->setApplicationName(get_bloginfo('name'));
$client->setAccessType('offline');
$client->setApprovalPrompt('force');
$client->setScopes(array('https://www.googleapis.com/auth/calendar'));
$client->setClientId($client_id);
$client->setClientSecret($client_secret);
$client->setRedirectUri($this->main->add_qs_vars(array('mec-ix-action'=>'google-calendar-export-get-token'), $this->main->URL('backend').'admin.php?page=MEC-ix&tab=MEC-g-calendar-export'));
$authentication = $client->authenticate($code);
$token = $client->getAccessToken();
$auth = json_decode($authentication, true);
$refresh_token = $auth['refresh_token'];
// Save options
$this->main->save_ix_options(array('google_export_token'=>$token, 'google_export_refresh_token'=>$refresh_token));
$url = $this->main->remove_qs_var('code', $this->main->remove_qs_var('mec-ix-action'));
header('location: '.$url);
exit;
}
catch(Exception $ex)
{
echo $ex->getMessage();
exit;
}
}
public function g_calendar_export_do()
{
$mec_event_ids = (isset($_POST['mec-events']) ? $_POST['mec-events'] : array());
$export_attendees = (isset($_POST['export_attendees']) ? $_POST['export_attendees'] : 0);
$ix = $this->main->get_ix_options();
$client_id = isset($ix['google_export_client_id']) ? $ix['google_export_client_id'] : NULL;
$client_secret = isset($ix['google_export_client_secret']) ? $ix['google_export_client_secret'] : NULL;
$token = isset($ix['google_export_token']) ? $ix['google_export_token'] : NULL;
$refresh_token = isset($ix['google_export_refresh_token']) ? $ix['google_export_refresh_token'] : NULL;
$calendar_id = isset($ix['google_export_calendar_id']) ? $ix['google_export_calendar_id'] : NULL;
if(!trim($client_id) or !trim($client_secret) or !trim($calendar_id)) $this->main->response(array('success'=>0, 'message'=>__('Client App, Client Secret, and Calendar ID are all required!', 'modern-events-calendar-lite')));
$client = new Google_Client();
$client->setApplicationName('Modern Events Calendar');
$client->setAccessType('offline');
$client->setScopes(array('https://www.googleapis.com/auth/calendar'));
$client->setClientId($client_id);
$client->setClientSecret($client_secret);
$client->setRedirectUri($this->main->add_qs_vars(array('mec-ix-action'=>'google-calendar-export-get-token'), $this->main->URL('backend').'admin.php?page=MEC-ix&tab=MEC-g-calendar-export'));
$client->setAccessToken($token);
$client->refreshToken($refresh_token);
$service = new Google_Service_Calendar($client);
// MEC Render Library
$render = $this->getRender();
$g_events_not_inserted = array();
$g_events_inserted = array();
$g_events_updated = array();
foreach($mec_event_ids as $mec_event_id)
{
$data = $render->data($mec_event_id);
$dates = $render->dates($mec_event_id, $data);
$date = isset($dates[0]) ? $dates[0] : array();
// Timezone Options
$timezone = $this->main->get_timezone($mec_event_id);
$gmt_offset = $this->main->get_gmt_offset($mec_event_id, $date['start']['timestamp']);
$location = isset($data->locations[$data->meta['mec_location_id']]) ? $data->locations[$data->meta['mec_location_id']] : array();
$organizer = isset($data->organizers[$data->meta['mec_organizer_id']]) ? $data->organizers[$data->meta['mec_organizer_id']] : array();
$recurrence = $this->main->get_ical_rrules($data);
$start = array(
'dateTime'=>date('Y-m-d\TH:i:s', $date['start']['timestamp']).$gmt_offset,
'timeZone'=>$timezone,
);
$end = array(
'dateTime'=>date('Y-m-d\TH:i:s', $date['end']['timestamp']).$gmt_offset,
'timeZone'=>$timezone,
);
$allday = isset($data->meta['mec_allday']) ? $data->meta['mec_allday'] : 0;
if($allday)
{
$start['dateTime'] = date('Y-m-d\T00:00:00', $date['start']['timestamp']).$gmt_offset;
$end['dateTime'] = date('Y-m-d\T00:00:00', strtotime('+1 Day', strtotime($end['dateTime']))).$gmt_offset;
}
// Event Data
$event_data = array
(
'summary'=>$data->title,
'location'=>(isset($location['address']) ? $location['address'] : (isset($location['name']) ? $location['name'] : '')),
'description'=>strip_tags(strip_shortcodes($data->content)),
'start'=>$start,
'end'=>$end,
'recurrence'=>$recurrence,
'attendees'=>array(),
'reminders'=>array(),
);
$event = new Google_Service_Calendar_Event($event_data);
$iCalUID = 'mec-ical-'.$data->ID;
$mec_iCalUID = get_post_meta($data->ID, 'mec_gcal_ical_uid', true);
$mec_calendar_id = get_post_meta($data->ID, 'mec_gcal_calendar_id', true);
/**
* Event is imported from same google calendar
* and now it's exporting to its calendar again
* so we're trying to update existing one by setting event iCal ID
*/
if($mec_calendar_id == $calendar_id and trim($mec_iCalUID)) $iCalUID = $mec_iCalUID;
$event->setICalUID($iCalUID);
// Set the organizer if exists
if(isset($organizer['name']))
{
$g_organizer = new Google_Service_Calendar_EventOrganizer();
$g_organizer->setDisplayName($organizer['name']);
$g_organizer->setEmail($organizer['email']);
$event->setOrganizer($g_organizer);
}
// Set the attendees
if($export_attendees)
{
$attendees = array();
foreach($this->main->get_event_attendees($data->ID) as $att)
{
$attendee = new Google_Service_Calendar_EventAttendee();
$attendee->setDisplayName($att['name']);
$attendee->setEmail($att['email']);
$attendee->setResponseStatus('accepted');
$attendees[] = $attendee;
}
$event->setAttendees($attendees);
}
try
{
$g_event = $service->events->insert($calendar_id, $event);
// Set Google Calendar ID to MEC databse for updating it in the future instead of adding it twice
update_post_meta($data->ID, 'mec_gcal_ical_uid', $g_event->getICalUID());
update_post_meta($data->ID, 'mec_gcal_calendar_id', $calendar_id);
update_post_meta($data->ID, 'mec_gcal_id', $g_event->getId());
$g_events_inserted[] = array('title'=>$data->title, 'message'=>$g_event->htmlLink);
}
catch(Exception $ex)
{
// Event already existed
if($ex->getCode() == 409)
{
try
{
$g_event_id = get_post_meta($data->ID, 'mec_gcal_id', true);
$g_event = $service->events->get($calendar_id, $g_event_id);
// Update Event Data
$g_event->setSummary($event_data['summary']);
$g_event->setLocation($event_data['location']);
$g_event->setDescription($event_data['description']);
$g_event->setRecurrence($event_data['recurrence']);
$start = new Google_Service_Calendar_EventDateTime();
$start->setDateTime($event_data['start']['dateTime']);
$start->setTimeZone($event_data['start']['timeZone']);
$g_event->setStart($start);
$end = new Google_Service_Calendar_EventDateTime();
$end->setDateTime($event_data['end']['dateTime']);
$end->setTimeZone($event_data['end']['timeZone']);
$g_event->setEnd($end);
$g_updated_event = $service->events->update($calendar_id, $g_event_id, $g_event);
$g_events_updated[] = array('title'=>$data->title, 'message'=>$g_updated_event->htmlLink);
}
catch(Exception $ex)
{
$g_events_not_inserted[] = array('title'=>$data->title, 'message'=>$ex->getMessage());
}
}
else $g_events_not_inserted[] = array('title'=>$data->title, 'message'=>$ex->getMessage());
}
}
$results = '<ul>';
foreach($g_events_not_inserted as $g_event_not_inserted) $results .= '<li><strong>'.$g_event_not_inserted['title'].'</strong>: '.$g_event_not_inserted['message'].'</li>';
$results .= '<ul>';
$message = (count($g_events_inserted) ? sprintf(__('%s events added to Google Calendar with success.', 'modern-events-calendar-lite'), '<strong>'.count($g_events_inserted).'</strong>') : '');
$message .= (count($g_events_updated) ? ' '.sprintf(__('%s Updated previously added events.', 'modern-events-calendar-lite'), '<strong>'.count($g_events_updated).'</strong>') : '');
$message .= (count($g_events_not_inserted) ? ' '.sprintf(__('%s events failed to add for following reasons: %s', 'modern-events-calendar-lite'), '<strong>'.count($g_events_not_inserted).'</strong>', $results) : '');
$this->main->response(array('success'=>((count($g_events_inserted) or count($g_events_updated)) ? 1 : 0), 'message'=>trim($message)));
}
/**
* Show content of Facebook Import tab
* @author Webnus <[email protected]>
* @return void
*/
public function ix_f_calendar_import()
{
// Current Action
$this->action = isset($_POST['mec-ix-action']) ? sanitize_text_field($_POST['mec-ix-action']) : '';
$this->ix = isset($_POST['ix']) ? $_POST['ix'] : array();
$this->response = array();
if($this->action == 'facebook-calendar-import-start') $this->response = $this->f_calendar_import_start();
elseif($this->action == 'facebook-calendar-import-do') $this->response = $this->f_calendar_import_do();
$path = MEC::import('app.features.ix.import_f_calendar', true, true);
ob_start();
include $path;
echo $output = ob_get_clean();
}
public function f_calendar_import_start()
{
$fb_page_link = isset($this->ix['facebook_import_page_link']) ? $this->ix['facebook_import_page_link'] : NULL;
$this->fb_access_token = isset($this->ix['facebook_app_token']) ? $this->ix['facebook_app_token'] : NULL;
if(!trim($fb_page_link)) return array('success'=>0, 'message'=>__("Please insert your Facebook page's link.", 'modern-events-calendar-lite'));
// Save options
$this->main->save_ix_options(array('facebook_import_page_link'=>$fb_page_link));
$this->main->save_ix_options(array('facebook_app_token'=>$this->fb_access_token));
$fb_page = $this->f_calendar_import_get_page($fb_page_link);
$fb_page_id = isset($fb_page['id']) ? $fb_page['id'] : 0;
if(!$fb_page_id)
{
$message = __("We were not able to recognize your Facebook page. Please check again and provide a valid link.", 'modern-events-calendar-lite');
if(isset($fb_page['error']) and isset($fb_page['error']['message'])) $message = $fb_page['error']['message'];
return array('success'=>0, 'message'=>$message);
}
$events = array();
$next_page = 'https://graph.facebook.com/v7.0/'.$fb_page_id.'/events/?access_token='.$this->fb_access_token;
do
{
$events_result = $this->main->get_web_page($next_page);
$fb_events = json_decode($events_result, true);
// Exit the loop if no event found
if(!isset($fb_events['data'])) break;
foreach($fb_events['data'] as $fb_event)
{
$events[] = array('id'=>$fb_event['id'], 'name'=>$fb_event['name']);
}
$next_page = isset($fb_events['paging']['next']) ? $fb_events['paging']['next'] : NULL;
}
while($next_page);
if(!count($events)) return array('success'=>0, 'message'=>__("No events found!", 'modern-events-calendar-lite'));
else return array('success'=>1, 'message'=>'', 'data'=>array('events'=>$events, 'count'=>count($events), 'name'=>$fb_page['name']));
}
public function f_calendar_import_do()
{
$f_events = isset($_POST['f-events']) ? $_POST['f-events'] : array();
if(!count($f_events)) return array('success'=>0, 'message'=>__('Please select events to import!', 'modern-events-calendar-lite'));
$fb_page_link = isset($this->ix['facebook_import_page_link']) ? $this->ix['facebook_import_page_link'] : NULL;
$this->fb_access_token = isset($this->ix['facebook_app_token']) ? $this->ix['facebook_app_token'] : NULL;
if(!trim($fb_page_link)) return array('success'=>0, 'message'=>__("Please insert your facebook page's link.", 'modern-events-calendar-lite'));
$fb_page = $this->f_calendar_import_get_page($fb_page_link);
$fb_page_id = isset($fb_page['id']) ? $fb_page['id'] : 0;
if(!$fb_page_id) return array('success'=>0, 'message'=>__("We were not able to recognize your Facebook page. Please check again and provide a valid link.", 'modern-events-calendar-lite'));
// Timezone
$timezone = $this->main->get_timezone();
// MEC File
$file = $this->getFile();
$wp_upload_dir = wp_upload_dir();
$post_ids = array();
foreach($f_events as $f_event_id)
{
$events_result = $this->main->get_web_page('https://graph.facebook.com/v7.0/'.$f_event_id.'?fields=name,place,description,start_time,end_time,cover&access_token='.$this->fb_access_token);
$event = json_decode($events_result, true);
// An error Occurred
if(isset($event['error']) and is_array($event['error']) and count($event['error'])) continue;
// Event organizer
$organizer_id = 1;
// Event location
$location = isset($event['place']) ? $event['place'] : array();
$location_id = 1;
// Import Event Locations into MEC locations
if(isset($this->ix['import_locations']) and $this->ix['import_locations'] and count($location))
{
$location_name = $location['name'];
$location_address = trim($location_name.' '.(isset($location['location']['city']) ? $location['location']['city'] : '').' '.(isset($location['location']['state']) ? $location['location']['state'] : '').' '.(isset($location['location']['country']) ? $location['location']['country'] : '').' '.(isset($location['location']['zip']) ? $location['location']['zip'] : ''), '');
$location_id = $this->main->save_location(array
(
'name'=>trim($location_name),
'address'=>$location_address,
'latitude'=>!empty($location['location']['latitude']) ? $location['location']['latitude'] : '',
'longitude'=>!empty($location['location']['longitude']) ? $location['location']['longitude'] : '',
));
}
// Event Title and Content
$title = $event['name'];
$description = isset($event['description']) ? $event['description'] : '';
$date_start = new DateTime($event['start_time']);
$date_start->setTimezone(new DateTimeZone($timezone));
$start_date = $date_start->format('Y-m-d');
$start_hour = $date_start->format('g');
$start_minutes = $date_start->format('i');
$start_ampm = $date_start->format('A');
$end_timestamp = isset($event['end_time']) ? strtotime($event['end_time']) : 0;
if($end_timestamp)
{
$date_end = new DateTime($event['end_time']);
$date_end->setTimezone(new DateTimeZone($timezone));
}
$end_date = $end_timestamp ? $date_end->format('Y-m-d') : $start_date;
$end_hour = $end_timestamp ? $date_end->format('g') : 8;
$end_minutes = $end_timestamp ? $date_end->format('i') : '00';
$end_ampm = $end_timestamp ? $date_end->format('A') : 'PM';
// Event Time Options
$allday = 0;
// Import Facebook Link as Event Link
$read_more = '';
if(isset($this->ix['import_link_event']) and $this->ix['import_link_event']) $read_more = 'https://www.facebook.com/events/'.$f_event_id.'/';
// Import Facebook Link as More Info
$more_info = '';
if(isset($this->ix['import_link_more_info']) and $this->ix['import_link_more_info']) $more_info = 'https://www.facebook.com/events/'.$f_event_id.'/';
$args = array
(
'title'=>$title,
'content'=>$description,
'location_id'=>$location_id,
'organizer_id'=>$organizer_id,
'date'=>array
(
'start'=>array(
'date'=>$start_date,
'hour'=>$start_hour,
'minutes'=>$start_minutes,
'ampm'=>$start_ampm,
),
'end'=>array(
'date'=>$end_date,
'hour'=>$end_hour,
'minutes'=>$end_minutes,
'ampm'=>$end_ampm,
),
'repeat'=>array(),
'allday'=>$allday,
'comment'=>'',
'hide_time'=>0,
'hide_end_time'=>0,
),
'start'=>$start_date,
'start_time_hour'=>$start_hour,
'start_time_minutes'=>$start_minutes,
'start_time_ampm'=>$start_ampm,
'end'=>$end_date,
'end_time_hour'=>$end_hour,
'end_time_minutes'=>$end_minutes,
'end_time_ampm'=>$end_ampm,
'repeat_status'=>0,
'repeat_type'=>'',
'interval'=>NULL,
'finish'=>$end_date,
'year'=>NULL,
'month'=>NULL,
'day'=>NULL,
'week'=>NULL,
'weekday'=>NULL,
'weekdays'=>NULL,
'meta'=>array
(
'mec_source'=>'facebook-calendar',
'mec_facebook_page_id'=>$fb_page_id,
'mec_facebook_event_id'=>$f_event_id,
'mec_allday'=>$allday,
'mec_read_more'=>$read_more,
'mec_more_info'=>$more_info,
)
);
$post_id = $this->db->select("SELECT `post_id` FROM `#__postmeta` WHERE `meta_value`='$f_event_id' AND `meta_key`='mec_facebook_event_id'", 'loadResult');
// Insert the event into MEC
$post_id = $this->main->save_event($args, $post_id);
$post_ids[] = $post_id;
// Set location to the post
if($location_id) wp_set_object_terms($post_id, (int) $location_id, 'mec_location');
if(!has_post_thumbnail($post_id) and isset($event['cover']) and is_array($event['cover']) and count($event['cover']))
{
$photo = $this->main->get_web_page($event['cover']['source']);
$file_name = md5($post_id).'.'.$this->main->get_image_type_by_buffer($photo);
$path = rtrim($wp_upload_dir['path'], DS.' ').DS.$file_name;
$url = rtrim($wp_upload_dir['url'], '/ ').'/'.$file_name;
$file->write($path, $photo);
$this->main->set_featured_image($url, $post_id);
}
}
return array('success'=>1, 'data'=>$post_ids);
}
public function f_calendar_import_get_page($link)
{
$this->fb_access_token = isset($this->ix['facebook_app_token']) ? $this->ix['facebook_app_token'] : NULL;
$fb_page_result = $this->main->get_web_page('https://graph.facebook.com/v7.0/?access_token='.$this->fb_access_token.'&id='.$link);
return json_decode($fb_page_result, true);
}
}