647 lines
27 KiB
PHP
647 lines
27 KiB
PHP
<?php
|
|
/**
|
|
* adds one.com walkthrough tour to wordpress admin
|
|
*/
|
|
if ( ! class_exists( 'Onecom_Walkthrough' ) ) {
|
|
class Onecom_Walkthrough {
|
|
const BUTTON_2 = 'button2';
|
|
const CONTENT = 'content';
|
|
const PARENT = 'parent';
|
|
const VCACHE_PLUGIN = 'onecom-vcache/vcaching.php';
|
|
const WEBSHOP_PLUGIN = 'onecom-webshop/webshop.php';
|
|
const WEBSHOP_SETTINGS = 'one-webshop-settings';
|
|
const PHP_SCANNER = 'onecom-php-scanner/onecom-compatibility-scanner.php';
|
|
const OC_FUNCTION = 'function';
|
|
const DISMISSED_POINTERS = 'dismissed_wp_pointers';
|
|
|
|
// Initiate construct
|
|
public function __construct() {
|
|
add_action(
|
|
'admin_enqueue_scripts',
|
|
array(
|
|
$this,
|
|
'oc_enqueue_scripts',
|
|
)
|
|
); // Hook to admin_enqueue_scripts
|
|
add_action( 'wp_ajax_ocwkt_reset_tour', array( $this, 'oc_walkthrough_reset_tour' ) );
|
|
add_action( 'admin_head', array( $this, 'onecom_restart_tour' ) );
|
|
}
|
|
|
|
public function oc_enqueue_scripts() {
|
|
// Check to see if user has already dismissed the pointer tour
|
|
$dismissed = explode( ',', get_user_meta( wp_get_current_user()->ID, self::DISMISSED_POINTERS, true ) );
|
|
$do_tour = ! in_array( 'oc_walthrough_pointer', $dismissed );
|
|
$welcome_modal_closed = false;
|
|
$user_id = get_current_user_id();
|
|
if ( $user_id ) {
|
|
// Retrieve the user meta
|
|
$welcome_modal_closed = get_user_meta( $user_id, 'oc-welcome-modal-closed', true );
|
|
}
|
|
// If not, we are good to continue
|
|
if ( $do_tour && $welcome_modal_closed ) {
|
|
// Enqueue WP pointer scripts and styles
|
|
wp_enqueue_style( 'wp-pointer' );
|
|
wp_enqueue_script( 'wp-pointer' );
|
|
|
|
// Finish hooking to WP admin areas
|
|
add_action(
|
|
'admin_print_footer_scripts',
|
|
array(
|
|
$this,
|
|
'walkthrough_footer_scripts',
|
|
)
|
|
); // Hook to admin footer scripts
|
|
}
|
|
add_action( 'admin_head', array( $this, 'css_admin_head' ) ); // Hook to admin head
|
|
}
|
|
|
|
// Used to add css of walkthrough
|
|
public function css_admin_head() {
|
|
?>
|
|
<style>
|
|
#pointer-primary, .oc-button-secondary.gv-button.gv-button-cancel {
|
|
margin: 0 0 0 5px;
|
|
background: var(--color-on-fixed-white);
|
|
border: 0;
|
|
}
|
|
|
|
.ocwt_pointer .wp-pointer-buttons a {
|
|
float: left;
|
|
}
|
|
|
|
.ocwt_pointer .oc-button-secondary {
|
|
border: 1px solid #FFFFFFA6;
|
|
margin-right: 16px;
|
|
}
|
|
|
|
/*.ocwt_pointer .oc-button-secondary:hover {*/
|
|
/* background: transparent;*/
|
|
/* border: 1px solid #fff;*/
|
|
/*}*/
|
|
|
|
.ocwt_pointer .wp-pointer-content h4 {
|
|
font-weight: 600;
|
|
font-size: 14px;
|
|
line-height: 21px;
|
|
letter-spacing: 0.04px;
|
|
color: #FFFFFF;
|
|
margin: 0 0 4px;
|
|
}
|
|
|
|
.ocwt_pointer .wp-pointer-content p {
|
|
padding: 0;
|
|
/*margin: 0;*/
|
|
font-size: 12px;
|
|
font-weight: 500;
|
|
line-height: 18px;
|
|
letter-spacing: 0.05px;
|
|
color: #FFFFFF;
|
|
}
|
|
|
|
.ocwt_pointer .wp-pointer-buttons {
|
|
padding: 0px;
|
|
margin-top: 15px;
|
|
}
|
|
|
|
.ocwt_pointer {
|
|
z-index: 99999 !important;
|
|
max-width: 312px;
|
|
|
|
}
|
|
|
|
.oc-pointer-wrap .ocwt_pointer .wp-pointer-content {
|
|
background: #0078C8;
|
|
border: 1px solid #0078C8;
|
|
}
|
|
|
|
.oc-pointer-wrap .ocwt_pointer .wp-pointer-arrow, .oc-pointer-wrap .ocwt_pointer .wp-pointer-arrow-inner {
|
|
border-right-color: #0078C8;
|
|
}
|
|
|
|
.oc-reset-wlk-tour span.oc_reset {
|
|
text-decoration: none !important;
|
|
color: #d5d5d5;
|
|
float: left;
|
|
margin-right: 10px;
|
|
}
|
|
|
|
.ocwt_pointer .wp-pointer-content {
|
|
padding: 24px;
|
|
}
|
|
|
|
.oc-walk-img {
|
|
padding-left: 4px;
|
|
}
|
|
|
|
.oc-pointer-wrap {
|
|
position: fixed;
|
|
top: 0;
|
|
left: 0;
|
|
width: 100%;
|
|
height: 100%;
|
|
background: rgb(60, 60, 60, 0.5);
|
|
z-index: 99999;
|
|
}
|
|
|
|
.img-holder {
|
|
min-height: 72px;
|
|
}
|
|
.ocwt_pointer p{
|
|
max-width: 228px;
|
|
}
|
|
.ocwt_pointer .wp-pointer-content{
|
|
max-width: 300px;
|
|
border-radius: 4px;
|
|
}
|
|
|
|
#oc_hmwidget_spinner {
|
|
background: url() no-repeat;
|
|
background-size: 20px 20px;
|
|
display: inline-block;
|
|
visibility: hidden;
|
|
float: none;
|
|
vertical-align: middle;
|
|
opacity: .7;
|
|
width: 20px;
|
|
height: 20px;
|
|
margin: 0 10px 0;
|
|
}
|
|
|
|
.oc-close-tour, #oc-close-tour {
|
|
float: right;
|
|
color: #ffffff;
|
|
}
|
|
#ocwk-pointer-close{
|
|
max-width: 125px;
|
|
padding: 0 16px;
|
|
white-space: nowrap;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
display: inline-block;
|
|
line-height: 28px;
|
|
}
|
|
|
|
@media screen and (max-width: 782px) {
|
|
.ocwt_pointer, .oc-pointer-wrap, .oc-reset-wlk-tour a {
|
|
display: none;
|
|
}
|
|
}
|
|
</style>
|
|
<?php
|
|
}
|
|
|
|
// Define footer scripts
|
|
public function walkthrough_footer_scripts() {
|
|
$tour = $this->oc_generate_array();
|
|
|
|
// Determine the current page in query parameter
|
|
$page = isset( $_GET['page'] ) ? $_GET['page'] . '-tour' : '';
|
|
$tab = isset( $_GET['tab'] ) ? $_GET['tab'] : '';
|
|
|
|
// Define other variables
|
|
$function = '';
|
|
$button2 = '';
|
|
$id = '';
|
|
$options = array();
|
|
$show_pointer = false;
|
|
|
|
if ( $page != '' && in_array( $page, array_keys( $tour ) ) && $tab == '' ) {
|
|
$show_pointer = true;
|
|
$parent = true;
|
|
$screen = $page;
|
|
if ( isset( $tour[ $page ]['id'] ) ) {
|
|
$id = $tour[ $page ]['id'];
|
|
}
|
|
$options = array(
|
|
self::CONTENT => $tour[ $page ][ self::CONTENT ],
|
|
'pointerWidth' => '342',
|
|
'position' => array(
|
|
'edge' => 'left',
|
|
'align' => 'left',
|
|
),
|
|
);
|
|
|
|
$button2 = false;
|
|
$function = '';
|
|
|
|
if ( isset( $tour[ $page ][ self::BUTTON_2 ] ) ) {
|
|
$button2 = $tour[ $page ][ self::BUTTON_2 ];
|
|
}
|
|
if ( isset( $tour[ $page ][ self::OC_FUNCTION ] ) ) {
|
|
$function = $tour[ $page ][ self::OC_FUNCTION ];
|
|
}
|
|
$parent = $tour[ $page ][ self::PARENT ];
|
|
}
|
|
|
|
if ( $show_pointer && $id == '#onecom_themes' ) {
|
|
$this->make_pointer_script( $id, $options, __( 'Got it!', 'onecom-wp' ), $button2, $function, $parent, $screen );
|
|
} elseif ( $show_pointer && $id == '#onecom_home' ) {
|
|
$this->make_pointer_script( $id, $options, __( 'End tour', 'onecom-wp' ), $button2, $function, $parent, $screen );
|
|
} elseif ( $show_pointer ) {
|
|
$this->make_pointer_script( $id, $options, __( 'Back', 'onecom-wp' ), $button2, $function, $parent, $screen );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* returns array which will be used for generating pointers(apart from default)
|
|
*/
|
|
public function oc_generate_array( $arr = array() ) {
|
|
$home_page = $this->onecom_home_tour();
|
|
$themes_page = $this->onecom_theme_page_tour();
|
|
$plugins_page = $this->onecom_plugins_tour();
|
|
$staging_page = $this->onecom_staging_tour();
|
|
$health_monitor_page = $this->onecom_health_monitor_tour();
|
|
$cookie_banner_page = $this->onecom_utility_tour();
|
|
$error_page = $this->onecom_utility_tour();
|
|
$webshop = $this->onecom_utility_tour();
|
|
$one_photo = $this->onecom_utility_tour();
|
|
$maintenance_mode = $this->onecom_utility_tour();
|
|
$php_scanner = $this->onecom_utility_tour();
|
|
$performance_cache_page = $this->onecom_performance_cache_tour();
|
|
$wp_rocket_page = $this->onecom_performance_cache_tour();
|
|
// adding -tour to the page slug is required for generating the walkthrough
|
|
$tours = array(
|
|
'onecom-home-tour' => $home_page,
|
|
'onecom-wp-themes-tour' => $themes_page,
|
|
'onecom-marketplace' => $plugins_page,
|
|
'onecom-wp-staging-tour' => $staging_page,
|
|
'onecom-wp-health-monitor-tour' => $health_monitor_page,
|
|
'onecom-wp-spam-protection-tour' => $health_monitor_page,
|
|
'onecom-wp-cookie-banner-tour' => $cookie_banner_page,
|
|
'onecom-wp-error-page-tour' => $error_page,
|
|
'onecom-php-compatibility-scanner-tour' => $php_scanner,
|
|
'onecom-wp-under-construction-tour' => $maintenance_mode,
|
|
'onecom-vcache-plugin-tour' => $performance_cache_page,
|
|
'onecom-wp-rocket-tour' => $wp_rocket_page,
|
|
'one-webshop-settings-tour' => $webshop,
|
|
'oc_onephoto-tour' => $one_photo,
|
|
);
|
|
|
|
if ( isset( $arr ) && ! empty( $arr ) ) {
|
|
return array_merge( $tours, $arr );
|
|
}
|
|
|
|
return $tours;
|
|
}
|
|
|
|
/**
|
|
* generates parameters array for landing page [i.e, home]
|
|
*/
|
|
public function onecom_home_tour() {
|
|
$health_mn = array(
|
|
'id' => '#onecom_home',
|
|
self::CONTENT => '<p class="oc-step-no gv-caption-sm gv-mb-md">' . sprintf( __( 'Step %s of %s', 'onecom-wp' ), '1', '6' ) . '</p>'
|
|
. '<h4 class="gv-text-sm gv-text-bold ">' . __( 'Home', 'onecom-wp' ) . '</h4>'
|
|
. '<p>' . __( 'Here you find shortcuts to main features of our one.com plugin, such as performance and security tools.', 'onecom-wp' ) . __( 'Get inspired by our selected articles or browse the complete help centre.', 'onecom-wp' ) . __( "If you need support, you've also come to the right place.", 'onecom-wp' ) . '</p>',
|
|
|
|
self::PARENT => true,
|
|
);
|
|
$button2 = array(
|
|
self::BUTTON_2 => __( 'Next', 'onecom-wp' ),
|
|
self::OC_FUNCTION => 'window.location="' . menu_page_url( 'onecom-wp-health-monitor', false ) . '"',
|
|
// We are relocating to "Settings" page with the 'site_title' query var
|
|
);
|
|
$health_mn = array_merge( $health_mn, $button2 );
|
|
|
|
return $health_mn;
|
|
}
|
|
|
|
/**
|
|
* generates parameters array for themes
|
|
*/
|
|
public function onecom_theme_page_tour() {
|
|
return array(
|
|
'id' => '#onecom_themes',
|
|
self::CONTENT => '<p class="oc-step-no gv-caption-sm gv-mb-md">' . sprintf( __( 'Step %s of %s', 'onecom-wp' ), '6', '6' ) . '</p>'
|
|
. '<h4 class="gv-heading-sm">Themes</h4>'
|
|
. '<p>' . __( 'Choose the perfect theme to suit your brand and give your site a professional appearance.', 'onecom-wp' ) . '</p>',
|
|
//self::BUTTON_2 => __( 'Next', 'onecom-wp' ),
|
|
//self::OC_FUNCTION => 'window.location="' . menu_page_url( 'onecom-marketplace', false ) . '"',
|
|
self::PARENT => true,
|
|
);
|
|
}
|
|
|
|
/**
|
|
* generates parameters array for plugins
|
|
*/
|
|
|
|
public function onecom_plugins_tour() {
|
|
return array(
|
|
'id' => '#onecom_plugins',
|
|
self::CONTENT => '<p class="oc-step-no gv-caption-sm gv-mb-md">' . sprintf( __( 'Step %s of %s', 'onecom-wp' ), '7', '7' ) . '</p>'
|
|
. '<h4>Plugins</h4>'
|
|
. '<p>' . __( 'Get a contact form, social media buttons, galleries and much more by adding plugins to your website.', 'onecom-wp' ) . '</p>',
|
|
self::PARENT => true,
|
|
);
|
|
}
|
|
|
|
/**
|
|
* generates parameters array for staging
|
|
*/
|
|
public function onecom_staging_tour() {
|
|
$staging = array(
|
|
'id' => '#onecom_staging',
|
|
self::CONTENT => '<p class="oc-step-no gv-caption-sm gv-mb-md">' . sprintf( __( 'Step %s of %s', 'onecom-wp' ), '4', '6' ) . '</p>'
|
|
. '<h4>Staging</h4>'
|
|
. '<p>' . __( 'Create a copy fo your page to try out new plugins and themes without disturbing or breaking your existing website.', 'onecom-wp' ) . '</p>',
|
|
self::PARENT => true,
|
|
);
|
|
|
|
if ( is_plugin_active( self::WEBSHOP_PLUGIN ) ) {
|
|
$button2 = array(
|
|
self::BUTTON_2 => __( 'Next', 'onecom-wp' ),
|
|
self::OC_FUNCTION => 'window.location="' . menu_page_url( 'one-webshop-settings', false ) . '"',
|
|
);
|
|
$staging = array_merge( $staging, $button2 );
|
|
} else {
|
|
$button2 = array(
|
|
self::BUTTON_2 => __( 'Next', 'onecom-wp' ),
|
|
self::OC_FUNCTION => 'window.location="' . menu_page_url( 'onecom-wp-error-page', false ) . '"',
|
|
);
|
|
$staging = array_merge( $staging, $button2 );
|
|
}
|
|
|
|
return $staging;
|
|
}
|
|
|
|
/**
|
|
* generates parameters array for health & security category
|
|
*/
|
|
public function onecom_health_monitor_tour() {
|
|
$health_mn = array(
|
|
'id' => '#onecom_health_security',
|
|
self::CONTENT => '<p class="oc-step-no gv-caption-sm gv-mb-md">' . sprintf( __( 'Step %s of %s', 'onecom-wp' ), '2', '6' ) . '</p>'
|
|
. '<h4 class="gv-text-sm gv-text-bold ">Health and Security</h4>'
|
|
. '<p>' . sprintf( __( '%1$s and %2$s keeps an eye on any issues, spammers, vulnerabilities and lets you fix most of them with just 1-click.', 'onecom-wp' ), '<b>Health Monitor</b>', '<b>Spam Protection</b>' ) . '</p><p>' . __( 'The tour can be restarted anytime from the dashboard.', 'onecom-wp' ) . '</p>',
|
|
self::PARENT => true,
|
|
);
|
|
|
|
if ( is_plugin_active( self::VCACHE_PLUGIN ) ) {
|
|
$button2 = array(
|
|
self::BUTTON_2 => __( 'Next', 'onecom-wp' ),
|
|
self::OC_FUNCTION => 'window.location="' . menu_page_url( 'onecom-vcache-plugin', false ) . '"',
|
|
// We are relocating to "Settings" page with the 'site_title' query var
|
|
);
|
|
$health_mn = array_merge( $health_mn, $button2 );
|
|
} else {
|
|
$button2 = array(
|
|
self::BUTTON_2 => __( 'Next', 'onecom-wp' ),
|
|
self::OC_FUNCTION => 'window.location="' . menu_page_url( 'onecom-wp-rocket', false ) . '"',
|
|
);
|
|
$health_mn = array_merge( $health_mn, $button2 );
|
|
}
|
|
|
|
return $health_mn;
|
|
}
|
|
|
|
/**
|
|
* generates parameters array for performance tools
|
|
*/
|
|
public function onecom_performance_cache_tour() {
|
|
// if ( ! is_plugin_active( self::VCACHE_PLUGIN ) ) {
|
|
// return false;
|
|
// }
|
|
$performance_cache = array(
|
|
'id' => '#onecom-performance-tools',
|
|
self::CONTENT => '<p class="oc-step-no gv-caption-sm gv-mb-md">' . sprintf( __( 'Step %s of %s', 'onecom-wp' ), '3', '6' ) . '</p>'
|
|
. '<h4>Performance Tools</h4>'
|
|
. '<p>' . sprintf( __( '%1$s, %2$s and %3$s will enhance the speed of your website and improve its overall performance.', 'onecom-wp' ), '<b>Performance Cache</b>', '<b>CDN</b>', '<b>WP Rocket</b>' ) . '</p>',
|
|
self::PARENT => true,
|
|
);
|
|
$button2 = array(
|
|
self::BUTTON_2 => __( 'Next', 'onecom-wp' ),
|
|
self::OC_FUNCTION => 'window.location="' . menu_page_url( 'onecom-wp-staging', false ) . '"',
|
|
// We are relocating to "Settings" page with the 'site_title' query var
|
|
);
|
|
$performance_cache = array_merge( $performance_cache, $button2 );
|
|
|
|
return $performance_cache;
|
|
}
|
|
|
|
/**
|
|
* generates parameters array for utility
|
|
*/
|
|
public function onecom_utility_tour() {
|
|
$utility = array(
|
|
'id' => '#onecom-utility',
|
|
self::CONTENT => '<p class="oc-step-no gv-caption-sm gv-mb-md">' . sprintf( __( 'Step %s of %s', 'onecom-wp' ), '5', '6' ) . '</p>'
|
|
. '<h4>Utility Tools</h4>'
|
|
. '<p>' . sprintf( __( 'Add features such as an %1$s, %2$s or a %3$s to increase the usability of your site.', 'onecom-wp' ), '<b>Error Page</b>', '<b>Cookie Banner</b>', '<b>Maintenance Mode</b>' ) . '</p>',
|
|
self::PARENT => true,
|
|
);
|
|
$button2 = array(
|
|
self::BUTTON_2 => __( 'Next', 'onecom-wp' ),
|
|
self::OC_FUNCTION => 'window.location="' . menu_page_url( 'onecom-wp-themes', false ) . '"',
|
|
);
|
|
$utility = array_merge( $utility, $button2 );
|
|
|
|
return $utility;
|
|
}
|
|
|
|
/**
|
|
* generates Jquery script for the pointers
|
|
*/
|
|
public function make_pointer_script( $id, $options, $button1, $button2 = false, $function = '', $parent = false, $screen = '' ) {
|
|
?>
|
|
<script type="text/javascript">
|
|
(function ($) {
|
|
$(document).ready(function () {
|
|
|
|
// Define pointer options
|
|
let wp_pointers_tour_opts =<?php echo json_encode( $options ); ?>, setup,
|
|
|
|
pointerElement = document.getElementsByClassName('ocwt_pointer'),
|
|
id = '<?php echo $id; ?>',
|
|
tabScreenSize = false,
|
|
button;
|
|
const screen = '<?php echo $screen; ?>';
|
|
// For tablet screen sizes
|
|
if (window.screen.width < 960) {
|
|
id = '#toplevel_page_onecom-wp';
|
|
tabScreenSize = true;
|
|
}
|
|
|
|
wp_pointers_tour_opts = $.extend(wp_pointers_tour_opts, {
|
|
pointerClass: 'ocwt_pointer',
|
|
// Add 'Close' button & Got it for the final screen i.e plugins
|
|
buttons: function (event, t) {
|
|
if (screen === "onecom-wp-themes-tour") {
|
|
button = jQuery(`<a id="ocwk-pointer-close" href="javascript:;" class="oc-button-secondary gv-button gv-button-cancel gv-mode-condensed"><?php echo $button1; ?></a>`);
|
|
button.bind('click.pointer', function () {
|
|
t.element.pointer('close');
|
|
});
|
|
|
|
} else if (screen === "onecom-home-tour") {
|
|
button = jQuery(`<a id="ocwk-pointer-close" href="javascript:;" class="oc-button-secondary gv-button gv-button-primary gv-mode-condensed"><?php echo $button1; ?></a>`);
|
|
button.bind('click.pointer', function () {
|
|
t.element.pointer('close');
|
|
});
|
|
} else {
|
|
button = jQuery(`<a id="ocwk-pointer-close" href="javascript:;" class="oc-button-secondary gv-button gv-button-primary gv-mode-condensed"><?php echo $button1; ?></a>`);
|
|
|
|
$(document).on('click', '#ocwk-pointer-close', function () {
|
|
window.history.back(); // This will navigate to the previous screen
|
|
});
|
|
|
|
}
|
|
return button;
|
|
},
|
|
close: function () {
|
|
// Post to admin ajax to disable pointers when user clicks "Close"
|
|
$.post(ajaxurl, {
|
|
pointer: 'oc_walthrough_pointer',
|
|
action: 'dismiss-wp-pointer'
|
|
});
|
|
$(document).find('.oc-pointer-wrap').remove();
|
|
let args = {
|
|
'event_action': 'close',
|
|
'item_category': 'blog',
|
|
'item_name': 'onecom_tour',
|
|
'referrer': screen,
|
|
}
|
|
oc_push_stats_by_js(args);
|
|
}
|
|
});
|
|
|
|
|
|
$(document).on('click', '#oc-close-tour', function () {
|
|
wp_pointers_tour_opts.close();
|
|
});
|
|
|
|
|
|
// This is used for our "button2" value above (advances the pointers)
|
|
setup = function () {
|
|
<?php if ( $parent ) { ?>
|
|
$('<?php echo $id; ?>').parent().pointer(wp_pointers_tour_opts).pointer('open');
|
|
|
|
<?php } else { ?>
|
|
$('<?php echo $id; ?>').pointer(wp_pointers_tour_opts).pointer('open');
|
|
|
|
<?php
|
|
}
|
|
if ( $button2 ) {
|
|
?>
|
|
|
|
let onePhoto = $(document).find('.ocop_pointer');
|
|
|
|
// To avoid conflict with onephoto
|
|
if (onePhoto.length > 0) {
|
|
// setTimeout(function(){
|
|
$(".ocop_pointer #pointer-primary").removeAttr('id');
|
|
// }, 3000);
|
|
|
|
}
|
|
jQuery('#ocwk-pointer-close').after('<a id="pointer-primary" class="gv-button gv-button-cancel gv-mode-condensed">' + '<?php echo $button2; ?>' + '</a>');
|
|
jQuery('#pointer-primary').click(function () {
|
|
<?php echo $function; ?> // Execute button2 function
|
|
});
|
|
|
|
<?php } ?>
|
|
|
|
if (tabScreenSize) {
|
|
$(pointerElement).css('left', function () {
|
|
return $('#adminmenuback').width() + 'px';
|
|
})
|
|
}
|
|
};
|
|
|
|
if (wp_pointers_tour_opts.position && wp_pointers_tour_opts.position.defer_loading) {
|
|
|
|
$(window).bind('load.wp-pointers', setup);
|
|
} else {
|
|
setup();
|
|
}
|
|
let adminBar = document.getElementById('wpadminbar'),
|
|
posPointer = pointerElement[0].getBoundingClientRect(),
|
|
height = ($('#wpadminbar').height() * 2),
|
|
posAdminBar = adminBar.getBoundingClientRect();
|
|
|
|
if (id == '#onecom-performance-tools') {
|
|
height = height + 35;
|
|
} else if (id == "#onecom_staging") {
|
|
height = height + 55;
|
|
} else if (id == '#onecom-utility') {
|
|
height = height + 75;
|
|
} else if (id == '#onecom_themes') {
|
|
height = height + 105;
|
|
} else if (id == '#onecom_plugins') {
|
|
height = height + 135;
|
|
}
|
|
|
|
|
|
// This is to adjust the top margin of pointer in case of overlap with admin bar
|
|
/*if (
|
|
posAdminBar.bottom > posPointer.top ||
|
|
posAdminBar.top < posPointer.bottom &&
|
|
id == '#onecom-performance-tools'
|
|
) {*/
|
|
$(pointerElement).css('top', function () {
|
|
return height + 'px';
|
|
})
|
|
let targetElem = $(document).find(id)[0];
|
|
$(pointerElement).find('.wp-pointer-arrow').css('top', ($(targetElem).offset().top - $(pointerElement).offset().top + 15 + 'px'));
|
|
$(pointerElement).wrap('<div class="oc-pointer-wrap gv-activated"></div>');
|
|
$(pointerElement).find('.wp-pointer-content').prepend('<a id="oc-close-tour" href="javascript:;"><gv-icon class="oc-close-tour" src="<?php echo ONECOM_WP_URL . '/modules/home/assets/icons/close.svg'; ?>"></gv-icon></a>');
|
|
// This is to adjust the popup and arrow position for the top submenu //
|
|
if (id == '#onecom_health_security') {
|
|
$(pointerElement).css('top', function () {
|
|
return ($('#wpadminbar').height() * 2) + 'px';
|
|
})
|
|
$(pointerElement).find('wp-pointer-arrow').css('top', $(pointerElement).offset().top);
|
|
}
|
|
});
|
|
})(jQuery);
|
|
</script>
|
|
<?php
|
|
}
|
|
|
|
|
|
public function oc_walkthrough_reset_tour() {
|
|
$pointers = get_user_meta( get_current_user_id(), self::DISMISSED_POINTERS, true );
|
|
update_user_meta( get_current_user_id(), 'oc-welcome-modal-closed', true );
|
|
$pointersArr = explode( ',', $pointers );
|
|
$pointer_key = array_search( 'oc_walthrough_pointer', $pointersArr );
|
|
if ( $pointer_key !== false ) {
|
|
unset( $pointersArr[ $pointer_key ] );
|
|
}
|
|
|
|
$newpointers = join( ',', $pointersArr );
|
|
if ( $newpointers === $pointers ) {
|
|
die( json_encode( array( 'status' => false ) ) );
|
|
} elseif ( update_user_meta( get_current_user_id(), self::DISMISSED_POINTERS, $newpointers ) ) {
|
|
wp_send_json_success( admin_url( 'admin.php?page=onecom-home' ) );
|
|
}
|
|
}
|
|
|
|
public function onecom_restart_tour() {
|
|
$current_screen = get_current_screen();
|
|
if ( $current_screen->id === 'one-com_page_onecom-home' || $current_screen->id === 'dashboard' ) {
|
|
?>
|
|
<script type="text/javascript">
|
|
(function ($) {
|
|
jQuery(document).ready(function () {
|
|
jQuery(".oc-reset-wlk-tour a").on('click', function (e) {
|
|
e.preventDefault();
|
|
$(document).find('#oc_hmwidget_spinner').css('visibility', 'visible');
|
|
jQuery.post(ajaxurl,
|
|
{
|
|
'action': 'ocwkt_reset_tour',
|
|
'nonce': 'asdsadsad'
|
|
},
|
|
function (response) {
|
|
$(document).find('#oc_hmwidget_spinner').css('visibility', 'hidden');
|
|
if ("object" === typeof response && response.success && response.data != undefined) {
|
|
window.location.href = response.data;
|
|
} else {
|
|
window.location.href = "<?php echo admin_url( 'admin.php?page=onecom-home' ); ?>";
|
|
}
|
|
}, 'json', false, 0);
|
|
});
|
|
})
|
|
})(jQuery);
|
|
</script>
|
|
<?php
|
|
}
|
|
}
|
|
}
|
|
}
|