HOME


Mini Shell 1.0
DIR: /var/www/rhodeworks/wp-content/plugins/ocean-extra/includes/wizard/
Upload File :
Current File : /var/www/rhodeworks/wp-content/plugins/ocean-extra/includes/wizard/wizard.php
<?php
/**
 * Theme Wizard
 *
 * @package Ocean_Extra
 * @category Core
 * @author OceanWP
 */

// Exit if accessed directly.
if ( ! defined( 'ABSPATH' ) ) {
	exit;
}

if ( ! class_exists( 'Ocean_Extra_Theme_Wizard' ) ) :

	/**
	 * Start Class Ocean_Extra_Theme_Wizard.
	 */
	class Ocean_Extra_Theme_Wizard {

		/**
		 * Current step
		 *
		 * @var string
		 */
		private $step = '';

		/**
		 * Steps for the setup wizard
		 *
		 * @var array
		 */
		private $steps = array();

		/**
		 * __construct
		 *
		 * @return void
		 */
		public function __construct() {
			$this->includes();
			add_action( 'admin_menu', array( $this, 'add_ocean_wizard_menu' ) );
			add_action( 'admin_init', array( $this, 'ocean_wizard_setup' ), 99 );
			add_action( 'wp_loaded', array( $this, 'remove_notice' ) );
			add_action( 'admin_print_styles', array( $this, 'add_notice' ) );
			add_action( 'add_second_notice', array( $this, 'install' ) );
		}

		/**
		 * Install.
		 *
		 * @return void
		 */
		public static function install() {
			if ( ! get_option( 'owp_wizard' ) ) {
				update_option( 'owp_wizard', 'un-setup' );
				( wp_safe_redirect( admin_url( 'admin.php?page=owp_setup' ) ) );
			} else {
				// first run for automatic message after first 24 hour.
				if ( ! get_option( 'automatic_2nd_notice' ) ) {
					update_option( 'automatic_2nd_notice', 'second-time' );

				} else {
					// clear cronjob after second 24 hour.
					wp_clear_scheduled_hook( 'add_second_notice' );
					delete_option( 'automatic_2nd_notice' );
					delete_option( '2nd_notice' );
					delete_option( 'owp_wizard' );
					wp_safe_redirect( admin_url() );
					exit;
				}
			}
		}

		/**
		 * Clear cronjob when deactivate plugin.
		 *
		 * @return void
		 */
		public static function uninstall() {
			wp_clear_scheduled_hook( 'add_second_notice' );
			delete_option( 'automatic_2nd_notice' );
			delete_option( '2nd_notice' );
			delete_option( 'owp_wizard' );
		}

		public function remove_notice() {
			if ( isset( $_GET['owp_wizard_hide_notice'] ) && $_GET['owp_wizard_hide_notice'] == 'install' ) { // WPCS: input var ok, CSRF ok.
				// when install is finished.
				delete_option( 'owp_wizard' );
				// clear cronjob when install is finished.
				wp_clear_scheduled_hook( 'add_second_notice' );
				delete_option( '2nd_notice' );
				if ( isset( $_GET['show'] ) ) {
					wp_safe_redirect( home_url() );
					exit;
				}
			} elseif ( isset( $_GET['owp_wizard_hide_notice'] ) && $_GET['owp_wizard_hide_notice'] == '2nd_notice' ) { // WPCS: input var ok, CSRF ok.
				// when install is skipped.
				delete_option( 'owp_wizard' );
				if ( ! get_option( '2nd_notice' ) ) {
					update_option( '2nd_notice', 'second-time' );
					$timezone_string = get_option( 'timezone_string' );
					if ( ! $timezone_string ) {
						return false;
					}
					date_default_timezone_set( $timezone_string );

					// set time for next day.
					$new_time_format = time() + ( 24 * 60 * 60 );
					// add "add_second_notice" cronjob.
					if ( ! wp_next_scheduled( 'add_second_notice' ) ) {
						wp_schedule_event( $new_time_format, 'daily', 'add_second_notice' );
					}
				} else {
					// clear cronjob when wizard is skipped for the second time.
					wp_clear_scheduled_hook( 'add_second_notice' );
				}
				if ( isset( $_GET['show'] ) ) {
					wp_safe_redirect( home_url() );
					exit;
				} else {
					wp_safe_redirect( admin_url() );
					exit;
				}
			}
		}
		
		/**
		 * Add notice.
		 *
		 * @return void
		 */
		public function add_notice() {
			if ( current_user_can( 'administrator' ) ) {
				if ( ( get_option( 'owp_wizard' ) == 'un-setup' ) && ( empty( $_GET['page'] ) || 'owp_setup' !== $_GET['page'] ) ) {
					if ( ! get_option( '2nd_notice' ) && ! get_option( 'automatic_2nd_notice' ) ) {?>
						<div class="updated notice-success owp-extra-notice">
							<div class="notice-inner">
								<div class="notice-content">
									<p><?php esc_html_e( '<strong>Welcome to OceanWP</strong> - Are you ready to create an amazing website?', 'ocean-extra' ); ?></p>
									<p class="submit">
										<a href="<?php echo esc_url( admin_url( 'admin.php?page=owp_setup' ) ); ?>" class="btn button-primary"><?php esc_html_e( 'Run the Setup Wizard', 'ocean-extra' ); ?></a>
										<a class="btn button-secondary" href="<?php echo esc_url( ( add_query_arg( 'owp_wizard_hide_notice', '2nd_notice' ) ) ); ?>"><?php esc_html_e( 'Skip setup', 'ocean-extra' ); ?></a>
									</p>
								</div>
							</div>
						</div>
						<?php
					}
					?>

					<style type="text/css">
						.owp-extra-notice {
							display: none;
						}
					
						body.wp-admin .owp-extra-notice {
							display: block;
						}
						
						body.wp-admin > .owp-extra-notice {
							margin-left: 180px;
						}

						body.folded > .owp-extra-notice {
							margin-left: 56px;
						}
					
						.owp-extra-notice.updated { border-color: #13aff0; }
						.owp-extra-notice .button-primary { background: #13aff0; border-color: #1e9bd0; box-shadow: inset 0 1px 0 rgba(255,255,255,.25), 0 1px 0 #1e9bd0; color: #fff; text-shadow: 0 -1px 1px #1e9bd0, 1px 0 1px #1e9bd0, 0 1px 1px #1e9bd0, -1px 0 1px #1e9bd0; }

						.owp-extra-notice.owp-contest-notice { position: relative; border: none; padding: 0; }
						.owp-extra-notice.owp-contest-notice:after { content: ''; display: block; visibility: hidden; clear: both; zoom: 1; height: 0; }
						.owp-extra-notice.owp-contest-notice { position: relative; }
						.owp-extra-notice.owp-contest-notice span.icon-side { color: #fff; position: absolute; top: 0; left: 0; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -webkit-align-items: center; -moz-align-items: center; align-items: center; font-size: 30px; width: 60px; height: 100%; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
						.owp-extra-notice.owp-contest-notice span.dashicons-heart { background-color: #13aff0; }
						.owp-extra-notice.owp-contest-notice { padding: 10px 40px 15px 74px; }
						.owp-extra-notice.owp-contest-notice p { font-size: 14px; }
						.owp-extra-notice.owp-contest-notice p:first-child { margin-top: 0; }
						.owp-extra-notice.owp-contest-notice p:last-child { margin-bottom: 0; }
						.owp-extra-notice.owp-contest-notice a { text-decoration: none; -webkit-box-shadow: none !important; box-shadow: none !important; }
						.owp-extra-notice.owp-contest-notice a.btn { height: auto; font-size: 12px; line-height: 1; background-color: #13aff0; color: #fff; border: 1px solid #13aff0; padding: 10px 18px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px; text-shadow: none; transition: all .3s ease; -webkit-transition: all .3s ease; -moz-transition: all .3s ease; -o-transition: all .3s ease; -ms-transition: all .3s ease; }
						.owp-extra-notice.owp-contest-notice a.btn:hover { background-color: #0b7cac; border-color: #0b7cac; }
						.owp-extra-notice.owp-contest-notice a.btn.button-secondary { background-color: #f2f2f2; color: #666; border-color: #dadada; margin-left: 10px; }
						.owp-extra-notice.owp-contest-notice a.btn.button-secondary:hover { background-color: #e6e6e6; border-color: #e6e6e6; }
						.owp-extra-notice.owp-contest-notice a.dismiss { position: absolute; top: 10px; right: 10px; text-decoration: none; color: #13aff0; -webkit-box-shadow: none !important; box-shadow: none !important; }

						/* Rating notice */
						.owp-extra-notice.oe-rating-notice.owp-contest-notice span.dashicons-star-filled { background-color: #ffb900; }
						.owp-extra-notice.oe-rating-notice.owp-contest-notice p:last-child { margin-top: 20px; }
						.owp-extra-notice.oe-rating-notice.owp-contest-notice a.btn { background-color: #ffb900; border-color: #ffb900; }
						.owp-extra-notice.oe-rating-notice.owp-contest-notice a.btn:hover { background-color: #e6a803; border-color: #e6a803; }
						.owp-extra-notice.oe-rating-notice.owp-contest-notice a.btn.button-secondary { background-color: #f2f2f2; color: #666; border-color: #dadada; }
						.owp-extra-notice.oe-rating-notice.owp-contest-notice a.btn.button-secondary:hover { background-color: #e6e6e6; border-color: #e6e6e6; }
						.owp-extra-notice.oe-rating-notice.owp-contest-notice a span { vertical-align: middle; }
						.owp-extra-notice.oe-rating-notice.owp-contest-notice a span.dashicons { font-size: 1.4em; padding-right: 5px; height: auto; }
						.owp-extra-notice.oe-rating-notice.owp-contest-notice a.dismiss { color: #ffb900; }

						body.rtl .owp-extra-notice.owp-contest-notice span.dashicons-heart { right: 0; left: auto; }
						body.rtl .owp-extra-notice.owp-contest-notice { padding-right: 74px; padding-left: 40px; }
						body.rtl .owp-extra-notice.owp-contest-notice a.btn.button-secondary { margin-right: 10px; margin-left: 0; }
						body.rtl .owp-extra-notice.owp-contest-notice a.dismiss { left: 10px; right: auto; }

						@media screen and ( max-width: 480px ) {
							.owp-extra-notice.owp-contest-notice span.dashicons-heart { display: none; }
							.owp-extra-notice.owp-contest-notice { padding-left: 14px;  }
							body.rtl .owp-extra-notice.owp-contest-notice { padding-right: 14px; }
						}
					</style>

					<?php
				}
			}
		}

		private function includes() {
			require_once OE_PATH . '/includes/wizard/classes/QuietSkin.php';
			require_once OE_PATH . '/includes/wizard/classes/WizardAjax.php';
		}

		public function add_ocean_wizard_menu() {
			add_dashboard_page( '', '', 'manage_options', 'owp_setup', '' );
		}

		public function ocean_wizard_setup() {
			if ( ! current_user_can( 'manage_options' ) ) {
				return;
			}
			if ( empty( $_GET['page'] ) || 'owp_setup' !== $_GET['page'] ) { // WPCS: CSRF ok, input var ok.
				return;
			}
			$default_steps = array(
				'welcome'   => array(
					'name' => __( 'Welcome', 'ocean-extra' ),
					'view' => array( $this, 'ocean_welcome' ),
				),
				'demo'      => array(
					'name' => __( 'Choosing Demo', 'ocean-extra' ),
					'view' => array( $this, 'ocean_demo_setup' ),
				),
				'customize' => array(
					'name' => __( 'Customize', 'ocean-extra' ),
					'view' => array( $this, 'ocean_customize_setup' ),
				),
				'ready'     => array(
					'name' => __( 'Ready', 'ocean-extra' ),
					'view' => array( $this, 'ocean_ready_setup' ),
				),
			);
			$this->steps   = apply_filters( 'owp_setup_wizard_steps', $default_steps );
			$this->step    = isset( $_GET['step'] ) ? sanitize_key( $_GET['step'] ) : current( array_keys( $this->steps ) ); // WPCS: CSRF ok, input var ok.
			// CSS.
			wp_enqueue_style( 'owp-wizard-style', plugins_url( '/assets/css/style.min.css', __FILE__ ) );

			// RTL.
			if ( is_RTL() ) {
				wp_enqueue_style( 'owp-wizard-rtl', plugins_url( '/assets/css/rtl.min.css', __FILE__ ) );
			}

			// JS.
			wp_enqueue_script( 'owp-wizard-js', plugins_url( '/assets/js/wizard.min.js', __FILE__ ), array( 'jquery', 'wp-util', 'updates' ) );

			wp_localize_script(
				'owp-wizard-js',
				'owpDemos',
				array(
					'ajaxurl'                 => admin_url( 'admin-ajax.php' ),
					'demo_data_nonce'         => wp_create_nonce( 'get-demo-data' ),
					'owp_import_data_nonce'   => wp_create_nonce( 'owp_import_data_nonce' ),
					'content_importing_error' => esc_html__( 'There was a problem during the importing process resulting in the following error from your server:', 'ocean-extra' ),
					'button_activating'       => esc_html__( 'Activating', 'ocean-extra' ) . '&hellip;',
					'button_active'           => esc_html__( 'Active', 'ocean-extra' ),
				)
			);

			global $current_screen, $hook_suffix, $wp_locale;
			if ( empty( $current_screen ) ) {
				set_current_screen();
			}
			$admin_body_class = preg_replace( '/[^a-z0-9_-]+/i', '-', $hook_suffix );

			ob_start();
			?>
			<!DOCTYPE html>
			<html <?php language_attributes(); ?>>
				<head>
					<meta name="viewport" content="width=device-width" />
					<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
					<title><?php esc_html_e( 'OceanWP &rsaquo; Setup Wizard', 'ocean-extra' ); ?></title>
					<script type="text/javascript">
						addLoadEvent = function (func) {
							if (typeof jQuery != "undefined")
								jQuery(document).ready(func);
							else if (typeof wpOnload != 'function') {
								wpOnload = func;
							} else {
								var oldonload = wpOnload;
								wpOnload = function () {
									oldonload();
									func();
								}
							}
						};
						var ajaxurl = '<?php echo admin_url( 'admin-ajax.php', 'relative' ); ?>',
								pagenow = '<?php echo $current_screen->id; ?>',
								typenow = '<?php echo $current_screen->post_type; ?>',
								adminpage = '<?php echo $admin_body_class; ?>',
								thousandsSeparator = '<?php echo addslashes( $wp_locale->number_format['thousands_sep'] ); ?>',
								decimalPoint = '<?php echo addslashes( $wp_locale->number_format['decimal_point'] ); ?>',
								isRtl = <?php echo (int) is_rtl(); ?>;
					</script>
			<?php
			// include demos script.
			wp_print_scripts( 'owp-wizard-js' );

			// include custom scripts in specifiec steps.
			if ( $this->step == 'demo' || $this->step == 'welcome' || $this->step == 'customize' ) {
				wp_print_styles( 'themes' );
				wp_print_styles( 'buttons' );
				wp_print_styles( 'dashboard' );
				wp_print_styles( 'common' );
			}

			if ( $this->step == 'customize' ) {
				wp_print_styles( 'media' );
				wp_enqueue_media();
				wp_enqueue_style( 'wp-color-picker' );
				wp_enqueue_script( 'wp-color-picker' );
			}

			// add admin styles.
			do_action( 'admin_print_styles' );

			do_action( 'admin_head' );
			?>
				</head>
				<body class="owp-setup wp-core-ui">
			<?php $logo = apply_filters( 'oceanwp_setup_wizard_logo', '<a href="https://oceanwp.org/?utm_source=dash&utm_medium=wizard&utm_campaign=logo">OceanWP<span class="circle"></span></a>' ); ?>
					<div id="owp-logo"><?php echo $logo; ?></div>
					<?php
					$this->setup_wizard_steps();
					$this->setup_wizard_content();
					_wp_footer_scripts();
					do_action( 'admin_footer' );
					?>
				</body>
			</html>
			<?php
			exit;
		}

		/**
		 * Output the steps.
		 */
		public function setup_wizard_steps() {
			$output_steps = $this->steps;
			?>
			<ol class="owp-setup-steps">
			<?php
			foreach ( $output_steps as $step_key => $step ) {
				$is_completed = array_search( $this->step, array_keys( $this->steps ), true ) > array_search( $step_key, array_keys( $this->steps ), true );

				if ( $step_key === $this->step ) {
					?>
						<li class="active"><?php echo esc_html( $step['name'] ); ?></li>
						<?php
				} elseif ( $is_completed ) {
					?>
						<li class="done">
							<a href="<?php echo esc_url( add_query_arg( 'step', $step_key, remove_query_arg( 'activate_error' ) ) ); ?>"><?php echo esc_html( $step['name'] ); ?></a>
						</li>
					<?php
				} else {
					?>
						<li><?php echo esc_html( $step['name'] ); ?></li>
						<?php
				}
			}
			?>
			</ol>
				<?php
		}

			/**
			 * Output the content for the current step.
			 */
		public function setup_wizard_content() {
			echo '<div class="owp-setup-content">';
			if ( ! empty( $this->steps[ $this->step ]['view'] ) ) {
				call_user_func( $this->steps[ $this->step ]['view'], $this );
			}
			echo '</div>';
		}

			/**
			 * Get Next Step
			 *
			 * @param type $step
			 * @return string
			 */
		public function get_next_step_link( $step = '' ) {
			if ( ! $step ) {
				$step = $this->step;
			}

			$keys = array_keys( $this->steps );
			if ( end( $keys ) === $step ) {
				return admin_url();
			}

			$step_index = array_search( $step, $keys, true );
			if ( false === $step_index ) {
				return '';
			}

			return add_query_arg( 'step', $keys[ $step_index + 1 ], remove_query_arg( 'activate_error' ) );
		}

			/**
			 * Get Previous Step
			 *
			 * @param type $step
			 * @return string
			 */
		public function get_previous_step_link( $step = '' ) {

			if ( ! $step ) {
				$step = $this->step;
			}

			$keys = array_keys( $this->steps );

			$step_index = array_search( $step, $keys, true );

			if ( false === $step_index ) {
				return '';
			}
			$url = false;

			if ( isset( $keys[ $step_index - 1 ] ) ) {
				$url = add_query_arg( 'step', $keys[ $step_index - 1 ], remove_query_arg( 'activate_error' ) );
			}
			return $url;
		}

			/**
			 * Helper method to retrieve the current user's email address.
			 *
			 * @return string Email address
			 */
		protected function get_current_user_email() {
			$current_user = wp_get_current_user();
			$user_email   = $current_user->user_email;

			return $user_email;
		}

			/**
			 * Step 1 Welcome.
			 */
		public function ocean_welcome() {
			// Image.
			$img = plugins_url( '/assets/img/jack.png', __FILE__ );

			// Button icon.
			if ( is_RTL() ) {
				$icon = 'left';
			} else {
				$icon = 'right';
			}
			?>

			<div class="owp-welcome-wrap owp-wrap">
				<h2><?php esc_html_e( 'Setup Wizard', 'ocean-extra' ); ?></h2>
				<h1><?php esc_html_e( 'Welcome!', 'ocean-extra' ); ?></h1>
				<div class="owp-thumb">
					<img src="<?php echo esc_url( $img ); ?>" width="425" height="290" alt="Jack the Shark" />
				</div>
				<p><?php esc_html_e( "Thank you for choosing OceanWP, in this quick setup wizard we'll take you through the 2 essential steps for you to get started building your dream website. Make sure to go through it to the end, where we also included a little bonus as well.", 'ocean-extra' ); ?></p>
				<div class="owp-wizard-setup-actions">
					<a class="skip-btn continue" href="<?php echo esc_url( $this->get_next_step_link() ); ?>"><?php esc_html_e( 'Get started', 'ocean-extra' ); ?><i class="dashicons dashicons-arrow-<?php echo esc_attr( $icon ); ?>-alt"></i></a>
				</div>
				<a class="owp-setup-footer-links" href="<?php echo esc_url( ( add_query_arg( array( 'owp_wizard_hide_notice' => '2nd_notice' ), admin_url() ) ) ); ?>"><?php esc_html_e( 'Skip Setup Wizard', 'ocean-extra' ); ?></a>
			</div>
			<?php
		}

		/**
		 * Step 2 list demo.
		 */
		public function ocean_demo_setup() {
			// Button icon.
			if ( is_RTL() ) {
				$icon = 'left';
			} else {
				$icon = 'right';
			}
			?>

			<div class="owp-demos-wrap owp-wrap">
				<div class="demo-import-loader preview-all"></div>
				<div class="demo-import-loader preview-icon"><i class="custom-loader"></i></div>

				<div class="owp-demo-wrap">
					<h1><?php esc_html_e( 'Selecting your demo template', 'ocean-extra' ); ?></h1>
					<p>
					<?php
						echo sprintf(
							__( 'Clicking %1$sLive Preview%2$s will open the demo in a new window for you to decide which template to use. Then %1$sSelect%2$s the demo you want and click %1$sInstall Demo%2$s in the bottom.', 'ocean-extra' ),
							'<strong>',
							'</strong>'
						);
					?>
						</p>
					<div class="theme-browser rendered">

						<?php
						// Vars.
						$demos    = OceanWP_Demos::get_demos_data();
						$el_demos = $demos['elementor'];
						$gu_demos = '';
						$el_cat   = OceanWP_Demos::get_demo_all_categories( $el_demos );

						// If Gutenberg.
						if ( ! empty( $demos['gutenberg'] ) ) {
							$gu_demos = $demos['gutenberg'];
							$gu_cat   = OceanWP_Demos::get_demo_all_categories( $gu_demos );
						}
						?>

						<div class="owp-header-bar">
							<nav class="owp-navigation">
								<?php
								if ( ! empty( $gu_demos ) ) {
									?>
									<ul class="owp-demo-linked">
										<li class="active"><a href="#" class="owp-elementor-link"><?php esc_html_e( 'Elementor', 'ocean-extra' ); ?></a></li>
										<li><a href="#" class="owp-gutenberg-link"><?php esc_html_e( 'Gutenberg', 'ocean-extra' ); ?></a></li>
									</ul>
									<?php
								}
								?>

								<?php
								if ( ! empty( $el_cat ) ) {
									?>
									<ul class="elementor-demos">
										<li class="active"><a href="#all" class="owp-navigation-link"><?php esc_html_e( 'All', 'ocean-extra' ); ?></a></li>
										<?php foreach ( $el_cat as $key => $name ) { ?>
											<li><a href="#<?php echo esc_attr( $key ); ?>" class="owp-navigation-link"><?php echo esc_html( $name ); ?></a></li>
										<?php } ?>
									</ul>
									<?php
								}
								?>

								<?php
								if ( ! empty( $gu_demos )
									&& ! empty( $gu_cat ) ) {
									?>
									<ul class="gutenberg-demos" style="display: none;">
										<li class="active"><a href="#all" class="owp-navigation-link"><?php esc_html_e( 'All', 'ocean-extra' ); ?></a></li>
										<?php foreach ( $gu_cat as $key => $name ) { ?>
											<li><a href="#<?php echo esc_attr( $key ); ?>" class="owp-navigation-link"><?php echo esc_html( $name ); ?></a></li>
										<?php } ?>
									</ul>
									<?php
								}
								?>
							</nav>

						</div>

						<div class="themes wp-clearfix elementor-items">

							<?php
							// Loop through all demos.
							foreach ( $el_demos as $demo => $key ) {

								// Vars.
								$item_categories = OceanWP_Demos::get_demo_item_categories( $key );
								?>

								<div class="theme-wrap" data-categories="<?php echo esc_attr( $item_categories ); ?>" data-name="<?php echo esc_attr( strtolower( $demo ) ); ?>">

									<div class="theme owp-open-popup" data-demo-id="<?php echo esc_attr( $demo ); ?>" data-demo-type="elementor" >

										<div class="theme-screenshot">
											<img src="<?php echo esc_url( OWP_Install_Demos::img_url( $demo ) ); ?>" />

											<div class="demo-import-loader preview-all preview-all-<?php echo esc_attr( $demo ); ?>"></div>

											<div class="demo-import-loader preview-icon preview-<?php echo esc_attr( $demo ); ?>"><i class="custom-loader"></i></div>
										</div>

										<div class="theme-id-container">

											<h2 class="theme-name" id="<?php echo esc_attr( $demo ); ?>"><span><?php echo esc_html( ucwords( $demo ) ); ?></span></h2>

											<div class="theme-actions">
												<a class="button button-primary" href="https://<?php echo esc_attr( $demo ); ?>.oceanwp.org/" target="_blank"><?php esc_html_e( 'Live Preview', 'ocean-extra' ); ?></a>
											</div>

										</div>

									</div>

								</div>

								<?php
							}
							?>

						</div>

						<?php
						if ( ! empty( $gu_demos ) ) {
							?>

							<div class="themes wp-clearfix gutenberg-items" style="display: none;">

								<?php
								// Loop through all demos.
								foreach ( $gu_demos as $demo => $key ) {

									// Vars.
									$item_categories = OceanWP_Demos::get_demo_item_categories( $key );
									?>

									<div class="theme-wrap" data-categories="<?php echo esc_attr( $item_categories ); ?>" data-name="<?php echo esc_attr( strtolower( $demo ) ); ?>">

										<div class="theme owp-open-popup" data-demo-id="<?php echo esc_attr( $demo ); ?>" data-demo-type="gutenberg">

											<div class="theme-screenshot">
												<img src="<?php echo esc_url( OWP_Install_Demos::img_url( $demo ) ); ?>" />

												<div class="demo-import-loader preview-all preview-all-<?php echo esc_attr( $demo ); ?>"></div>

												<div class="demo-import-loader preview-icon preview-<?php echo esc_attr( $demo ); ?>"><i class="custom-loader"></i></div>
											</div>

											<div class="theme-id-container">

												<h2 class="theme-name" id="<?php echo esc_attr( $demo ); ?>"><span><?php echo esc_html( ucwords( $demo ) ); ?></span></h2>

												<div class="theme-actions">
													<a class="button button-primary" href="https://<?php echo esc_attr( $demo ); ?>.oceanwp.org/" target="_blank"><?php esc_html_e( 'Live Preview', 'ocean-extra' ); ?></a>
												</div>

											</div>

										</div>

									</div>

									<?php
								}
								?>

							</div>

							<?php
						}
						?>

						</div>
						<div class="owp-wizard-setup-actions">
							<button class="install-demos-button disabled" disabled data-next_step="<?php echo esc_url( $this->get_next_step_link() ); ?>"><?php esc_attr_e( 'Install Demo', 'ocean-extra' ); ?></button>
							<a class="skip-btn" href="<?php echo esc_url( $this->get_next_step_link() ); ?>"><?php esc_html_e( 'Skip Step', 'ocean-extra' ); ?></a>
						</div>
					</div>

				</div>

				<div class="owp-wizard-setup-actions wizard-install-demos-buttons-wrapper final-step">
					<a class="skip-btn continue" href="<?php echo esc_url( $this->get_next_step_link() ); ?>"><?php esc_html_e( 'Next Step', 'ocean-extra' ); ?><i class="dashicons dashicons-arrow-<?php echo esc_attr( $icon ); ?>-alt"></i></a>
				</div>
			</div>
			<?php
		}

		/**
		 * Step 3 customize step.
		 */
		public function ocean_customize_setup() {

			if ( isset( $_POST['save_step'] ) && ! empty( $_POST['save_step'] ) ) {
				$this->save_ocean_customize();
			}

			// Button icon.
			if ( is_RTL() ) {
				$icon = 'left';
			} else {
				$icon = 'right';
			}
			?>

			<div class="owp-customize-wrap owp-wrap">
				<form method="POST" name="owp-customize-form">
					<?php wp_nonce_field( 'owp_customize_form' ); ?>
					<div class="field-group">
						<?php
						$custom_logo = get_theme_mod( 'custom_logo' );
						$display     = 'none';
						$url         = '';

						if ( $custom_logo ) {
							$display = 'inline-block';
							if ( ! ( $url = wp_get_attachment_image_url( $custom_logo ) ) ) {
								$custom_logo = '';
								$display     = 'none';
							}
						}
						?>
						<h1><?php esc_html_e( 'Logo', 'ocean-extra' ); ?></h1>
						<p><?php esc_html_e( 'Please add your logo below.', 'ocean-extra' ); ?></p>
						<div class="upload">
							<img  src="<?php echo esc_url( $url ); ?>"  width="115px" height="115px" id="ocean-logo-img" style="display:<?php echo esc_attr( $display ); ?>;"/>
							<div>
								<input type="hidden" name="ocean-logo" id="ocean-logo" value="<?php echo esc_attr( $custom_logo ); ?>" />
								<button type="submit" data-name="ocean-logo" class="upload_image_button button"><?php esc_html_e( 'Upload', 'ocean-extra' ); ?></button>
								<button  style="display:<?php echo esc_attr( $display ); ?>;" type="submit" data-name="ocean-logo" class="remove_image_button button">&times;</button>
							</div>
						</div>

					</div>

					<div class="field-group">

						<?php
						$ocean_retina_logo = get_theme_mod( 'ocean_retina_logo' );
						$display           = 'none';
						$url               = '';

						if ( $ocean_retina_logo ) {
							$display = 'inline-block';
							$url     = wp_get_attachment_image_url( $ocean_retina_logo );
							if ( ! ( $url = wp_get_attachment_image_url( $ocean_retina_logo ) ) ) {
								$ocean_retina_logo = '';
								$display           = 'none';
							}
						}
						?>
						<h1><?php esc_html_e( 'Retina Logo', 'ocean-extra' ); ?></h1>
						<p><?php esc_html_e( 'Please add your Retina Logo below.', 'ocean-extra' ); ?></p>
						<div class="upload">
							<img src="<?php echo esc_url( $url ); ?>" width="115px" height="115px" id="ocean-retina-logo-img" style="display:<?php echo esc_attr( $display ); ?>;"/>
							<div>
								<input type="hidden" name="ocean-retina-logo" id="ocean-retina-logo" value="<?php echo esc_attr( $ocean_retina_logo ); ?>" />
								<button type="submit" data-name="ocean-retina-logo" class="upload_image_button button"><?php esc_html_e( 'Upload', 'ocean-extra' ); ?></button>
								<button  style="display:<?php echo esc_attr( $display ); ?>;" type="submit" data-name="ocean-retina-logo" class="remove_image_button button">&times;</button>
							</div>
						</div>

					</div>

					<div class="field-group">
						<h1><?php esc_html_e( 'Site Title', 'ocean-extra' ); ?></h1>
						<p><?php esc_html_e( 'Please add your Site Title below.', 'ocean-extra' ); ?></p>
						<input type="text" name="ocean-site-title" id="ocean-site-title" class="ocean-input" value="<?php echo esc_attr( get_option( 'blogname' ) ); ?>">
					</div>

					<div class="field-group">
						<h1><?php esc_html_e( 'Tagline', 'ocean-extra' ); ?></h1>
						<p><?php esc_html_e( 'Please add your Tagline below.', 'ocean-extra' ); ?></p>
						<input type="text" name="ocean-tagline" id="ocean-tagline" class="ocean-input" value="<?php echo esc_attr( get_option( 'blogdescription' ) ); ?>">
					</div>

					<div class="field-group">

						<?php
						$favicon = get_option( 'site_icon' );
						$display = 'none';
						$url     = '';

						if ( $favicon ) {
							$display = 'inline-block';
							$url     = wp_get_attachment_image_url( $favicon );
							if ( ! ( $url = wp_get_attachment_image_url( $favicon ) ) ) {
								$favicon = '';
								$display = 'none';
							}
						}
						?>
						<h1><?php esc_html_e( 'Site Icon', 'ocean-extra' ); ?></h1>
						<p><?php esc_html_e( 'Site Icons are what you see in browser tabs, bookmark bars, and within the WordPress mobile apps. Upload one here! Site Icons should be square and at least 512 × 512 pixels.', 'ocean-extra' ); ?></p>
						<div class="upload">
							<img src="<?php echo esc_url( $url ); ?>" width="115px" height="115px" id="ocean-favicon-img" style="display:<?php echo esc_attr( $display ); ?>;"/>
							<div>
								<input type="hidden" name="ocean-favicon" id="ocean-favicon" value="<?php echo esc_attr( $favicon ); ?>" />
								<button type="submit" data-name="ocean-favicon" class="upload_image_button button"><?php esc_html_e( 'Upload', 'ocean-extra' ); ?></button>
								<button  style="display:<?php echo esc_attr( $display ); ?>;" type="submit" data-name="ocean-favicon" class="remove_image_button button">&times;</button>
							</div>
						</div>

					</div>

					<div class="field-group">
						<h1><?php esc_html_e( 'Primary Color', 'ocean-extra' ); ?></h1>
						<p><?php esc_html_e( 'Please add your Primary Color below.', 'ocean-extra' ); ?></p>
						<div class="upload">
							<input name="ocean-primary-color" id="ocean-primary-color" class="color-picker-field" value="<?php echo esc_attr( get_theme_mod( 'ocean_primary_color' ) ); ?>">
						</div>
					</div>

					<div class="field-group">
						<h1><?php esc_html_e( 'Hover Primary Color', 'ocean-extra' ); ?></h1>
						<p><?php esc_html_e( 'Please add your Hover Primary Color below.', 'ocean-extra' ); ?></p>
						<div class="upload">
							<input name="ocean-hover-primary-color" id="ocean-hover-primary-color" class="color-picker-field" value="<?php echo esc_attr( get_theme_mod( 'ocean_hover_primary_color' ) ); ?>">
						</div>
					</div>

					<div class="field-group">
						<h1><?php esc_html_e( 'Main Border Color', 'ocean-extra' ); ?></h1>
						<p><?php esc_html_e( 'Please add your Main Border Color below.', 'ocean-extra' ); ?></p>
						<div class="upload">
							<input name="ocean-main-border-color" id="ocean-main-border-color" class="color-picker-field" value="<?php echo esc_attr( get_theme_mod( 'ocean_main_border_color' ) ); ?>">
						</div>
					</div>

					<div class="field-group">
						<h1><?php esc_html_e( 'Links Color', 'ocean-extra' ); ?></h1>
						<p><?php esc_html_e( 'Please add your Links Color below.', 'ocean-extra' ); ?></p>
						<div class="upload">
							<input name="ocean-links-color" id="ocean-links-color" class="color-picker-field" value="<?php echo esc_attr( get_theme_mod( 'ocean_links_color' ) ); ?>">
						</div>
					</div>

					<div class="field-group">
						<h1><?php esc_html_e( 'Links Hover Color', 'ocean-extra' ); ?></h1>
						<p><?php esc_html_e( 'Please add your Links Hover Color below.', 'ocean-extra' ); ?></p>
						<div class="upload">
							<input name="ocean-links-hover-color" id="ocean-links-hover-color" class="color-picker-field" value="<?php echo esc_attr( get_theme_mod( 'ocean_links_color_hover' ) ); ?>">
						</div>
					</div>

					<div class="owp-wizard-setup-actions">
						<input type="hidden" name="save_step" value="save_step"/>
						<button class="continue" type="submit" ><?php esc_html_e( 'Continue', 'ocean-extra' ); ?><i class="dashicons dashicons-arrow-<?php echo esc_attr( $icon ); ?>-alt"></i></button>
						<a class="skip-btn" href="<?php echo esc_url( $this->get_next_step_link() ); ?>"><?php esc_html_e( 'Skip Step', 'ocean-extra' ); ?></a>
					</div>
				</form>
			</div>
			<?php
		}

		/**
		 * Save Info In Step3
		 */
		public function save_ocean_customize() {

			if ( current_user_can( 'manage_options' ) && isset( $_REQUEST['_wpnonce'] ) && wp_verify_nonce( $_REQUEST['_wpnonce'], 'owp_customize_form' ) ) {
				if ( isset( $_POST['ocean-logo'] ) ) {
					set_theme_mod( 'custom_logo', $_POST['ocean-logo'] );
				}

				if ( isset( $_POST['ocean-retina-logo'] ) ) {
					set_theme_mod( 'ocean_retina_logo', $_POST['ocean-retina-logo'] );
				}

				if ( isset( $_POST['ocean-site-title'] ) ) {
					$site_title = wp_filter_nohtml_kses( $_POST['ocean-site-title'] );
				}
				$this->removeElementorUpdateOptionAction( 'blogname' );
				update_option( 'blogname', esc_html( $site_title ) );

				if ( isset( $_POST['ocean-tagline'] ) ) {
					$site_tagline = wp_filter_nohtml_kses( $_POST['ocean-tagline'] );
				}
				$this->removeElementorUpdateOptionAction( 'blogdescription' );
				update_option( 'blogdescription', esc_html( $site_tagline ) );

				if ( isset( $_POST['ocean-favicon'] ) ) {
					update_option( 'site_icon', $_POST['ocean-favicon'] );
				}

				if ( isset( $_POST['ocean-primary-color'] ) ) {
					$primary_color = sanitize_hex_color( $_POST['ocean-primary-color'] );
				}
				set_theme_mod( 'ocean_primary_color', esc_html( $primary_color ) );

				if ( isset( $_POST['ocean-hover-primary-color'] ) ) {
					$primary_color_hover = sanitize_hex_color( $_POST['ocean-hover-primary-color'] );
				}
				set_theme_mod( 'ocean_hover_primary_color', esc_html( $primary_color_hover ) );

				if ( isset( $_POST['ocean-main-border-color'] ) ) {
					$main_border_color = sanitize_hex_color( $_POST['ocean-main-border-color'] );
				}
				set_theme_mod( 'ocean_main_border_color', esc_html( $main_border_color ) );

				if ( isset( $_POST['ocean-links-color'] ) ) {
					$links_color = sanitize_hex_color( $_POST['ocean-links-color'] );
				}
				set_theme_mod( 'ocean_links_color', esc_html( $links_color ) );

				if ( isset( $_POST['ocean-links-hover-color'] ) ) {
					$links_color_hover = sanitize_hex_color( $_POST['ocean-links-hover-color'] );
				}
				set_theme_mod( 'ocean_links_color_hover', esc_html( $links_color_hover ) );

				wp_safe_redirect( $this->get_next_step_link() );
				exit;
			} else {
				print 'Your are not authorized to submit this form';
				exit;
			}
		}

		/**
		 * Step 4 ready step
		 */
		public function ocean_ready_setup() {
				$user_email = $this->get_current_user_email();
			?>

				<div class="owp-ready-wrap owp-wrap">
					<h2><?php esc_attr_e( 'Your website is ready', 'ocean-extra' ); ?></h2>
					<h1 style="font-size: 30px;"><?php esc_attr_e( 'Get the extension bundle for free!', 'ocean-extra' ); ?></h1>
					<p style="font-size: 14px;"><?php esc_attr_e( 'Win the Core Extension Bundle by entering our giveaway. Every month we randomly draw 5 people that get the full suite of pro extensions for free. Enter with your email below.', 'ocean-extra' ); ?></p>
					<div class="owp-newsletter">
						<p><?php esc_attr_e( 'Input your email below to get the chance to win.', 'ocean-extra' ); ?></p>

						<form id="owp_email_signup" class="klaviyo_styling klaviyo_gdpr_embed_J7zjRA" action="//manage.kmail-lists.com/subscriptions/subscribe" data-ajax-submit="//manage.kmail-lists.com/ajax/subscriptions/subscribe" method="GET" target="_blank" novalidate="novalidate">
							<input type="hidden" name="g" value="J7zjRA">
							<input type="hidden" name="$fields" value="owp_use">

							<div class="klaviyo_field_group">
								<input class="" type="email" value="<?php echo esc_attr( $user_email ); ?>" name="email" id="k_id_email" placeholder="<?php esc_attr_e( 'Email address', 'ocean-extra' ); ?>"/>

								<div class="klaviyo_field_group klaviyo_form_actions klaviyo_form_checkboxes">
									<div class="klaviyo_helptext"><?php esc_html_e( 'What&rsquo;s your intended use of OceanWP?', 'ocean-extra' ); ?></div>

									<label for="consent-ecommerce"><input type="checkbox" name="owp_use" id="consent-ecommerce" value="ecommerce"><?php esc_html_e( 'E-Commerce', 'ocean-extra' ); ?></label>
									<label for="consent-agency"><input type="checkbox" name="owp_use" id="consent-agency" value="agency"><?php esc_html_e( 'Agency', 'ocean-extra' ); ?></label>
									<label for="consent-blog"><input type="checkbox" name="owp_use" id="consent-blog" value="blog"><?php esc_html_e( 'Blog', 'ocean-extra' ); ?></label>
									<label for="consent-other"><input type="checkbox" name="owp_use" id="consent-other" value="other"><?php esc_html_e( 'Other', 'ocean-extra' ); ?></label>
								</div>
							</div>

							<div class="klaviyo_form_actions">
								<button type="submit" class="klaviyo_submit_button"><?php esc_html_e( 'Enter Now', 'ocean-extra' ); ?></button>

								<div class="klaviyo_helptext klaviyo_gdpr_text">
									<?php
									echo sprintf(
										esc_html__( 'By entering your email, you agree to our %1$sTerms of Services%2$s and %3$sPrivacy Policy%4$s.', 'ocean-extra' ),
										'<a href="https://oceanwp.org/terms-and-conditions/" target="_blank">',
										'</a>',
										'<a href="https://oceanwp.org/privacy-policy/" target="_blank">',
										'</a>'
									);
									?>
								</div>
							</div>

							<div class="klaviyo_messages">
								<div class="success_message" style="display:none;"><?php esc_html_e( 'Thank you for participating!', 'ocean-extra' ); ?></div>
								<div class="error_message" style="display:none;"></div>
							</div>
						</form>

						<script type="text/javascript" src="//www.klaviyo.com/media/js/public/klaviyo_subscribe.js"></script>
						<script type="text/javascript">
							KlaviyoSubscribe.attachToForms('#owp_email_signup', {
								custom_success_message: true,
								success: function ($form) {
									jQuery('.owp-wizard-setup-actions a').attr('href', "
									<?php
									echo esc_url(
										( add_query_arg(
											array(
												'owp_wizard_hide_notice' => 'install',
												'show' => '1',
											),
											admin_url()
										) )
									);
									?>
																						")
								},
								extra_properties: {
									$source: '$embed',
									$method_type: "Klaviyo Form",
									$method_id: 'embed',
									$consent_version: 'Embed default text'
								}
							});

						</script>
					</div>

					<div class="owp-wizard-setup-actions">
						<a class="button button-next button-large" href="
						<?php
						echo esc_url(
							( add_query_arg(
								array(
									'owp_wizard_hide_notice' => '2nd_notice',
									'show' => '1',
								),
								admin_url()
							) )
						);
						?>
																			"><?php esc_html_e( 'View Your Website', 'ocean-extra' ); ?></a>
					</div>
				</div>
				<?php
		}

		/**
		 * Define cronjob
		 */
		public static function cronjob_activation() {
			$timezone_string = get_option( 'timezone_string' );
			if ( ! $timezone_string ) {
				return false;
			}
			date_default_timezone_set( $timezone_string );
			$new_time_format = time() + ( 24 * 60 * 60 );
			if ( ! wp_next_scheduled( 'add_second_notice' ) ) {
				wp_schedule_event( $new_time_format, 'daily', 'add_second_notice' );
			}
		}

		/**
		 * Delete cronjob
		 */
		public static function cronjob_deactivation() {
			wp_clear_scheduled_hook( 'add_second_notice' );

		}

		/**
		 * Remove Elementor Update Option
		 */
		private function removeElementorUpdateOptionAction( $option_name ) {
			$action_name = 'update_option_' . $option_name;
			global $wp_filter;
			if ( isset( $wp_filter[ $action_name ] ) ) {
				foreach ( $wp_filter[ $action_name ]->callbacks as $priority => $callbacks ) {
					foreach ( $callbacks as $callback_key => $callback_data ) {
						unset( $wp_filter[ $action_name ]->callbacks[ $priority ][ $callback_key ] );
					}
				}
			}
		}

	}

	new Ocean_Extra_Theme_Wizard();

	register_activation_hook( OE_FILE_PATH, 'Ocean_Extra_Theme_Wizard::install' );
	// when deactivate plugin.
	register_deactivation_hook( OE_FILE_PATH, 'Ocean_Extra_Theme_Wizard::uninstall' );
	// when activate plugin for automatic second notice.
	register_activation_hook( OE_FILE_PATH, array( 'Ocean_Extra_Theme_Wizard', 'cronjob_activation' ) );
	register_deactivation_hook( OE_FILE_PATH, array( 'Ocean_Extra_Theme_Wizard', 'cronjob_deactivation' ) );
endif;