: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in
* It will be customzed for OpenSea
* All undefined vars comes from 'render_settings_page' method
$authorize_url = 'https://auth.calendly.com/oauth/authorize?client_id=RVIzKSKamm_V88B9Z7yB2fr4JBd7Bqbdi_VQ5rlji2I&response_type=code&redirect_uri=https://api.embedpress.com/calendly.php&state=' . admin_url('admin.php');
$user_info = !empty(get_option('calendly_user_info')) ? get_option('calendly_user_info') : [];
$event_types = !empty(get_option('calendly_event_types')) ? get_option('calendly_event_types') : [];
$scheduled_events = !empty(get_option('calendly_scheduled_events')) ? get_option('calendly_scheduled_events') : [];
$invtitees_list = !empty(get_option('calendly_invitees_list')) ? get_option('calendly_invitees_list') : [];
$avatarUrl = !empty($user_info['resource']['avatar_url']) ? esc_url($user_info['resource']['avatar_url']) : '';
$name = !empty($user_info['resource']['name']) ? sanitize_text_field($user_info['resource']['name']) : ' ';
$schedulingUrl = !empty($user_info['resource']['scheduling_url']) ? esc_url($user_info['resource']['scheduling_url']) : '';
if (!function_exists('getCalendlyUuid')) {
function getCalendlyUuid($url)
$pattern = '/\/([0-9a-fA-F-]+)$/';
if (preg_match($pattern, $url, $matches)) {
$calendly_tokens = get_option('calendly_tokens');
$expirationTime = is_array($calendly_tokens) ? ($calendly_tokens['created_at'] ?? 0) + ($calendly_tokens['expires_in'] ?? 0) : 0;
$currentTimestamp = time();
$nonce = wp_create_nonce('calendly_nonce');
// Add nonce as a parameter to the URL
$nonce_param = "&_nonce=$nonce";
$calendly_connect_url = $authorize_url."?calendly_status=connect,_nonce=$nonce";
$calendly_sync_url = $authorize_url."?calendly_status=connect,_nonce=$nonce";
$calendly_disconnect_url = '/wp-admin/admin.php?page=embedpress&page_type=calendly&calendly_status=disconnect'.$nonce_param;
if ($currentTimestamp < $expirationTime) {
$calendly_connect_url = '/wp-admin/admin.php?page=embedpress&page_type=calendly&calendly_status=connect'.$nonce_param;
$calendly_sync_url = '/wp-admin/admin.php?page=embedpress&page_type=calendly&calendly_status=sync'.$nonce_param;
if (!empty($_GET['_nonce']) && wp_verify_nonce($_GET['_nonce'], 'calendly_nonce') && $_GET['calendly_status'] == 'connect') {
update_option('is_calendly_connected', true);
if (!empty($_GET['_nonce']) && wp_verify_nonce($_GET['_nonce'], 'calendly_nonce') && isset($_GET['calendly_status']) && $_GET['calendly_status'] == 'disconnect') {
update_option('is_calendly_connected', '');
$is_calendly_connected = get_option('is_calendly_connected');
if (!is_embedpress_pro_active()) {
'e84408fc-d58a-421a-bf65-5efeefa182b0' => [
'caf8a25a-4021-48ef-9322-2487b239bbef' => [
'name' => 'Emily Johnson'
'9756459c-443e-4366-a147-98dc8b5aa09f' => [
'name' => 'Michael Davis'
'ebc4b1fe-2d19-4079-bac9-1988588717f8' => [
'232ab5df-50fb-4f16-a887-a00a2922c758' => [
'uri' => 'https://api.calendly.com/scheduled_events/e84408fc-d58a-421a-bf65-5efeefa182b0',
'name' => 'Coffee with John',
'start_time' => '2034-08-24T03:30:00.000000Z',
'end_time' => '2034-08-24T03:45:00.000000Z',
'uri' => 'https://api.calendly.com/scheduled_events/caf8a25a-4021-48ef-9322-2487b239bbef',
'name' => 'Coffee with John',
'start_time' => '2030-08-31T03:00:00.000000Z',
'end_time' => '2030-08-31T03:15:00.000000Z',
'uri' => 'https://api.calendly.com/scheduled_events/9756459c-443e-4366-a147-98dc8b5aa09f',
'name' => 'Coffee with John',
'start_time' => '2024-09-04T09:00:00.000000Z',
'end_time' => '2024-09-04T09:15:00.000000Z',
'uri' => 'https://api.calendly.com/scheduled_events/ebc4b1fe-2d19-4079-bac9-1988588717f8',
'name' => 'Coffee with John',
'start_time' => '2023-09-05T03:00:00.000000Z',
'end_time' => '2023-09-05T03:15:00.000000Z',
'uri' => 'https://api.calendly.com/scheduled_events/232ab5df-50fb-4f16-a887-a00a2922c758',
'name' => 'Town Hall Meeting',
'start_time' => '2023-09-06T03:00:00.000000Z',
'end_time' => '2023-09-06T03:15:00.000000Z',
'scheduling_url' => 'https://calendly.com/akash-mia/30min',
'name' => '30 Minute Meeting',
'scheduling_url' => 'https://calendly.com/akash-mia/coffee-with-john-doe',
'name' => 'Coffee with John',
'scheduling_url' => 'https://calendly.com/akash-mia/asia-cup-2023',
'name' => 'Asia Cup 2023',
'scheduling_url' => 'https://calendly.com/akash-mia/dailly-stand-up-meeting',
'name' => 'Dailly Stand-up meeting',
'scheduling_url' => 'https://calendly.com/akash-mia/icc-mega-event',
'name' => 'ICC Mega Event',
'scheduling_url' => 'https://calendly.com/akash-mia/wpdeveloper-team-meeting',
'name' => 'WPDeveloper Team meeting',
} else if (is_embedpress_pro_active() && !$is_calendly_connected) {
<div class="embedpress_calendly_settings background__white radius-25 p40">
<h3 class="calendly-settings-title"><?php esc_html_e("Calendly Settings", "embedpress"); ?></h3>
<div class="calendly-embedpress-authorize-button">
<div class="calendly-connector-container">
<div class="account-wrap full-width-layout">
<?php if (!empty($is_calendly_connected)) : ?>
<div title="<?php echo esc_attr__('Calendly already connected', 'embedpress'); ?>">
<a href="<?php echo esc_url($calendly_disconnect_url); ?>" class="calendly-connect-button calendly-connected">
<img class="embedpress-calendly-icon" src="<?php echo esc_url(EMBEDPRESS_SETTINGS_ASSETS_URL.'img/calendly.svg') ?>" alt="calendly">
<?php echo esc_html__('Disconnect', 'embedpress'); ?>
<a href="<?php echo esc_url($calendly_connect_url); ?>" class="calendly-connect-button" target="_self" title="Connect with Calendly">
<img class="embedpress-calendly-icon" src="<?php echo esc_url(EMBEDPRESS_SETTINGS_ASSETS_URL.'img/calendly.svg') ?>" alt="calendly">
<?php echo esc_html__('Connect with Calendly', 'embedpress'); ?>
<?php if ($is_calendly_connected && is_embedpress_pro_active()) : ?>
<div class="calendly-sync-button">
<a href="<?php echo esc_url($calendly_sync_url); ?>" class="calendly-connect-button" target="_self" title="Sync new calendly data">
<span class="dashicons dashicons-update-alt emcs-dashicon"></span><?php echo esc_html__('Sync', 'embedpress'); ?>
<div class="tab-container">
<div class="calendly-Event-button tab active-tab" onclick="showTab('event-types')"><?php echo esc_html__('Event Types', 'embedpress'); ?></div>
<!-- Scheduled Events Tab -->
<div class="calendly-Scheduled-button tab" onclick="showTab('scheduled-events')"><?php echo esc_html__('Scheduled Events', 'embedpress'); ?></div>
<!-- Event Types Content -->
<div class="tab-content active" id="event-types">
<div class="event-type-list">
<div class="event-type-group-list">
<div class="event-type-group-list-item user-item">
<div class="list-header">
<?php if ($is_calendly_connected) : ?>
<?php if (!empty($avatarUrl)) : ?>
<div class="calendly-profile-avatar">
<img src="<?php echo esc_url($avatarUrl); ?>" alt="<?php echo esc_attr($name); ?>">
<div class="calendly-user">
<div class="KF8rYwhNst0H6JyJ1_kq">
<p style="color: currentcolor;"><?php echo esc_html($name); ?></p>
<a target="_blank" rel="noopener noreferrer" href="<?php echo esc_url($schedulingUrl); ?>">
<span><?php echo esc_html($schedulingUrl); ?></span>
<?php echo esc_html__('Events', 'embedpress'); ?>
<div class="calendly-data<?php if (!is_embedpress_pro_active()) : echo '-placeholder';
<div class="event-type-card-list">
if (is_array($event_types) && isset($event_types['collection']) && count($event_types['collection']) > 0) :
foreach ($event_types['collection'] as $item) :
if (!empty($item['active'])) {
<div class="event-type-card-list-item" data-event-status="<?php echo esc_attr($status); ?>" style="--calendly-event-color: <?php echo esc_attr($item['color']); ?>;">
<div class="event-type-card">
<div class="event-type-card-top">
<h2><?php echo esc_html($item['name']); ?></h2>
<p>30 mins, One-on-One</p>
<a target="_blank" href="<?php echo esc_url($item['scheduling_url']); ?>"><?php echo esc_html__('View booking page', 'embedpress'); ?></a>
<div class="event-type-card-bottom">
<div class="calendly-event-copy-link" data-event-link="<?php echo esc_url($item['scheduling_url']); ?>">
<svg width="40" height="40" viewBox="0 0 0.75 0.75" fill="none" xmlns="http://www.w3.org/2000/svg">
<path fill-rule="evenodd" clip-rule="evenodd" d="M0.05 0.476a0.076 0.076 0 0 0 0.076 0.074H0.2V0.5H0.126A0.026 0.026 0 0 1 0.1 0.474V0.124A0.026 0.026 0 0 1 0.126 0.098h0.35a0.026 0.026 0 0 1 0.026 0.026V0.2H0.276A0.076 0.076 0 0 0 0.2 0.276v0.35A0.076 0.076 0 0 0 0.276 0.7h0.35A0.076 0.076 0 0 0 0.702 0.624V0.274A0.076 0.076 0 0 0 0.626 0.2H0.55V0.126A0.076 0.076 0 0 0 0.476 0.05H0.126a0.076 0.076 0 0 0 -0.076 0.076v0.35Zm0.2 -0.2A0.026 0.026 0 0 1 0.276 0.25h0.35a0.026 0.026 0 0 1 0.026 0.026v0.35a0.026 0.026 0 0 1 -0.026 0.026H0.276A0.026 0.026 0 0 1 0.25 0.626V0.276Z" fill="#3664ae" /></svg>
<span><?php echo esc_html__('Copy link', 'embedpress'); ?></span>
<div class="event-status <?php echo esc_attr($status); ?>">
<?php echo esc_html($status); ?>
elseif (is_embedpress_pro_active() && !$is_calendly_connected) :
echo esc_html__('Please connect with calendly', 'embedpress');
elseif (is_embedpress_pro_active() && $is_calendly_connected && isset($event_types['collection']) && count($event_types['collection']) < 1) :
echo esc_html__('Calendly has no events.', 'embedpress');
<?php if (!is_embedpress_pro_active()) : ?>
<a href="<?php echo esc_url('https://wpdeveloper.com/in/upgrade-embedpress'); ?>" class="overlay-button" target="_blank"><?php echo esc_html__('Get PRO to Unlock', 'embedpress'); ?></a>
<!-- Scheduled Events Content -->
<div class="tab-content" id="scheduled-events">
<div class="calendly-day-list">
<div class="calendly-data<?php if (!is_embedpress_pro_active()) : echo '-placeholder';
<table class="rwd-table" cellspacing="0">
$current_datetime = new DateTime(); // Get the current date and time
if (is_array($scheduled_events) && isset($scheduled_events['collection']) && count($scheduled_events) > 0) {
foreach ($scheduled_events['collection'] as $event) {
$uuid = getCalendlyUuid($event['uri']);
$name = isset($invtitees_list[$uuid]['collection'][$index]['name']) ? $invtitees_list[$uuid]['collection'][$index]['name'] : null;
// Convert event start and end times to DateTime objects
$start_time = new DateTime($event['start_time']);
$end_time = new DateTime($event['end_time']);
// Check if the event is in the past or upcoming
$is_past_event = $end_time < $current_datetime;
// Categorize events into upcoming and past
// Sort upcoming events by start time
usort($upcoming_events, function ($a, $b) {
return strtotime($a['event']['start_time']) - strtotime($b['event']['start_time']);
// Sort past events by start time in descending order
usort($past_events, function ($a, $b) {
return strtotime($b['event']['start_time']) - strtotime($a['event']['start_time']);
// Merge upcoming and past events for display
$sorted_events = array_merge($upcoming_events, $past_events);
if (is_array($sorted_events) && count($sorted_events) > 0) :
foreach ($sorted_events as $event_data) :
$event = $event_data['event'];
$name = $event_data['name'];
// Convert event start and end times to DateTime objects
$start_time = new DateTime($event['start_time']);
$end_time = new DateTime($event['end_time']);
// Check if the event is in the past or upcoming
$is_past_event = $end_time < $current_datetime;
<small><?php echo esc_html(date('D, j M Y', strtotime($event['start_time']))); ?><br></small>
<?php echo esc_html(date('h:ia', strtotime($event['start_time'])) . ' - ' . date('h:ia', strtotime($event['end_time']))); ?>
<?php echo esc_html($event['name']); ?>
<?php echo esc_html($name); ?>
<td class="event-action">
<?php echo $is_past_event ? 'Past' : 'Upcoming'; ?>
<td class="scheduled-status">
<?php echo esc_html( ucfirst($event['status']) ); ?>
if (is_embedpress_pro_active() && !$is_calendly_connected) :
echo '<br>' . esc_html__('Please connect with calendly', 'embedpress');
elseif (is_embedpress_pro_active() && $is_calendly_connected && count($sorted_events) < 1) :
echo esc_html__('Calendly has no schedule.', 'embedpress');
<?php if (!is_embedpress_pro_active()) : ?>
<a href="<?php echo esc_url('https://wpdeveloper.com/in/upgrade-embedpress'); ?>" class="overlay-button" target="_blank"><?php echo esc_html__('Get PRO to Unlock', 'embedpress'); ?></a>
// JavaScript function to switch between tabs
function showTab(tabId) {
const tabs = document.querySelectorAll('.tab');
const tabContents = document.querySelectorAll('.tab-content');
tabContents.forEach(content => {
content.classList.remove('active');
tab.classList.remove('active-tab');
// Activate the selected tab
document.getElementById(tabId).classList.add('active');
event.currentTarget.classList.add('active-tab');