38217-vm/wp-content/plugins/onecom-themes-plugins/inc/class-onecom-walkthrough.php
2026-02-05 17:08:59 +03:00

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
}
}
}
}