<?php
/**
* The admin-specific functionality of the plugin.
*
* @link saleswonder.biz
* @since 1.0.0
*
* @package Cf7_Customizer
* @subpackage Cf7_Customizer/admin
*/
/**
* The admin-specific functionality of the plugin.
*
* Defines the plugin name, version, and two examples hooks for how to
* enqueue the admin-specific stylesheet and JavaScript.
*
* @package Cf7_Customizer
* @subpackage Cf7_Customizer/admin
* @author Tobias Conrad <tc@saleswonder.biz>
*/
class Cf7_Customizer_Admin {
/**
* The ID of this plugin.
*
* @since 1.0.0
* @access private
* @var string $plugin_name The ID of this plugin.
*/
private $plugin_name;
/**
* The version of this plugin.
*
* @since 1.0.0
* @access private
* @var string $version The current version of this plugin.
*/
private $version;
/**
* Initialize the class and set its properties.
*
* @since 1.0.0
* @param string $plugin_name The name of this plugin.
* @param string $version The version of this plugin.
*/
public function __construct( $plugin_name, $version ) {
$this->plugin_name = $plugin_name;
$this->version = $version;
}
/**
* Register the stylesheets for the admin area.
*
* @since 1.0.0
*/
public function enqueue_styles() {
if(isset($_GET['page']) && sanitize_text_field($_GET['page']) == 'cf7cstmzr_page') {
wp_enqueue_style( 'wp-color-picker' );
wp_enqueue_style( 'codemirror', plugin_dir_url( __FILE__ ) . 'vendors/codemirror.css', array(), $this->version . time(), 'all' );
wp_enqueue_style( $this->plugin_name, plugin_dir_url( __FILE__ ) . 'css/cf7-customizer-admin.css', array(), $this->version . time(), 'all' );
}
wp_enqueue_style( $this->plugin_name . '-global', plugin_dir_url( __FILE__ ) . 'css/cf7-customizer-admin-global.css', array(), $this->version . time(), 'all' );
}
/**
* Register the JavaScript for the admin area.
*
* @since 1.0.0
*/
public function enqueue_scripts() {
if(isset($_GET['page']) && (sanitize_text_field($_GET['page']) == 'cf7cstmzr_page' || sanitize_text_field($_GET['page']) == 'cf7cstmzr_tutorial_page')) {
wp_enqueue_code_editor(array('type' => 'text/css'));
if ( ! did_action( 'wp_enqueue_media' ) ) {
wp_enqueue_media();
}
wp_enqueue_script( 'codemirror', plugin_dir_url( __FILE__ ) . 'vendors/codemirror.js', array( 'jquery' ), '5.49.2', true );
wp_enqueue_script( 'jRespond', plugin_dir_url( __FILE__ ) . 'js/jRespond.js', array( 'jquery' ), '0.10', true );
wp_enqueue_script( $this->plugin_name, plugin_dir_url( __FILE__ ) . 'js/cf7-customizer-admin.js', array( 'jquery', 'jquery-ui-core', 'wp-color-picker' ), $this->version . time(), true );
}
}
public function settings_page() {
$is_welcome_done = get_option('cf7cstmzr_welcome_done');
if (!cf7cstmzr_is_plugin_activated( 'contact-form-7', 'wp-contact-form-7.php' )) {
add_menu_page(
__( 'CF7 Styler', 'cf7-styler' ),
__( 'CF7 Styler', 'cf7-styler' ),
'administrator',
'cf7cstmzr_page',
array($this, 'render_settings_page'),
'dashicons-email-alt',
6
);
if (!empty($is_welcome_done)) {
add_submenu_page(
'cf7cstmzr_page',
__( 'Support & KB', 'cf7-styler' ),
__( 'Support & KB', 'cf7-styler' ),
'administrator',
'cf7cstmzrcf7cstmzr_tutorial_page',
array($this, 'render_tutorials_page')
);
}
} else {
add_submenu_page(
'wpcf7',
__( 'CF7 Styler', 'cf7-styler' ),
__( 'CF7 Styler', 'cf7-styler' ),
'administrator',
'cf7cstmzr_page',
array($this, 'render_settings_page')
);
if (!empty($is_welcome_done)) {
add_submenu_page(
'wpcf7',
__( 'Support & KB', 'cf7-styler' ),
'<span class="cf7cstmzr-submenu-item">'.__( 'Support & KB', 'cf7-styler' ).'</span>',
'administrator',
'cf7cstmzr_tutorial_page',
array($this, 'render_settings_page')
);
}
}
}
public function render_settings_page() {
$is_welcome_done = get_option('cf7cstmzr_welcome_done');
if (!empty($_GET['page']) && ('cf7cstmzr_tutorial_page' === sanitize_text_field($_GET['page']) || empty($is_welcome_done))) {
include_once CF7CSTMZR_PLUGIN_PATH . 'admin/partials/cf7-customizer-admin-tutorial.php';
} else {
include_once CF7CSTMZR_PLUGIN_PATH . 'admin/partials/cf7-customizer-admin-display.php';
}
}
public function check_installation() {
$style_schemes = get_option('cf7cstmzr_style_schemes', array());
if (empty($style_schemes)) {
$default_scheme = array(
'default' => Cf7_Style_Scheme::get_default_style_scheme()
);
update_option('cf7cstmzr_style_schemes', $default_scheme);
}
}
public function rewrite_rule() {
flush_rewrite_rules();
add_rewrite_rule('^cf7cstmzr-form-customizer/(.*)/?', 'index.php?cf7cstmzr-form=$matches[1]', 'top');
add_rewrite_tag( '%cf7cstmzr-form%', '([^&]+)' );
}
public function check_version() {
$plugin_version = Cf7_License::get_license_version();
if ('free' === $plugin_version) {
delete_option('cf7cstmzr_enabled_globally');
$individually_styled_forms = Cf7_Style_Scheme::get_individually_styled_forms();
}
}
public function template_redirect() {
$permalink_structure = get_option('permalink_structure');
if (!empty($permalink_structure)) {
$form_id = get_query_var( 'cf7cstmzr-form' );
} else {
if (!empty($_GET['cf7cstmzr_page']) && !empty($_GET['form_id'])) {
$form_id = $_GET['form_id'];
}
}
if ($form_id) {
$form_post = get_post($form_id);
if (!$form_post || 'publish' !== $form_post->post_status) {
die;
}
global $content_width;
if (empty($content_width)) {
$content_width = 640;
}
$content_width = $content_width . 'px';
$content_width = '90%';
$form = get_post($form_id);
get_header();
if (!empty($form)) {
$preview_mode = get_option('cf7cstmzr-preview-mode', false);
$is_split_mode = $preview_mode === 'split-mode';
?>
<div id="style-preview-container" style="max-width: <?php echo $content_width ?>; margin: auto; padding: 20px;">
<?php
if ($is_split_mode) {
$split_mode = get_option('cf7cstmzr-split-mode', 'live-style');
?>
<style>
#style-preview-container {
width: 90%!important;
}
@media screen and (min-width: 599px) {
#style-preview-container {
width: 80%!important;
}
}
@media screen and (min-width: 961px) {
#style-preview-container {
width: 70%!important;
}
}
@media screen and (min-width: 1200px) {
#style-preview-container {
width: 60%!important;
}
}
#split-container:after {
display: table;
content: ' ';
clear: both;
}
.split, .gutter.gutter-horizontal {
float: left;
}
.gutter.gutter-horizontal {
margin-right: 2px;
margin-left: 2px;
cursor: ew-resize;
background-color: #ddd;
border-top: 1px solid #eee;
border-right: 1px solid #ccc;
border-bottom: 1px solid #ccc;
border-left: 1px solid #eee;
background-image: url("<?php echo CF7CSTMZR_PLUGIN_URL . '/public/vendors/vertical.png'; ?>");
background-size: contain;
background-repeat: no-repeat!important;
background-position: center center!important;
}
.float-split .split {
overflow-y: auto;
overflow-x: hidden;
}
.float-split .split .split-inner {
float: left;
}
.float-split .split:last-child .split-inner {
float: right;
}
.scroll-split .split {
overflow-y: auto;
overflow-x: scroll;
}
</style>
<div id="split-container" class="float-split" style="display:flex">
<div class="split current-style" id="split-left">
<div class="split-inner">
<?php echo do_shortcode('[contact-form-7 id="'.$form_id.'" title="' . $form->post_title . '"]'); ?>
</div>
</div>
<div class="split <?php echo $split_mode; ?>" id="split-right">
<div class="split-inner">
<?php echo do_shortcode('[contact-form-7 id="'.$form_id.'" title="' . $form->post_title . '"]'); ?>
</div>
</div>
</div>
<script>
(function($){
var sizes = localStorage.getItem('split-sizes')
if (sizes) {
sizes = JSON.parse(sizes)
} else {
sizes = [50, 50] // default sizes
}
var splitInstance;
var height = 0;
$(document).ready(function () {
recalculateSplit();
splitInstance = Split(['#split-left', '#split-right'], {
sizes: sizes,
minSize: 0,
gutter: function (index, direction) {
var gutter = document.createElement('div');
gutter.className = 'gutter gutter-' + direction + ' logo-gutter';
gutter.style.height = height + 'px';
return gutter
},
onDragEnd: function(sizes) {
localStorage.setItem('split-sizes', JSON.stringify(sizes))
},
gutterSize: 10
});
setTimeout(function () {
recalculateGutterHeight();
}, 100);
});
$(window).on( 'resize', function() {
recalculateSplit();
setTimeout(function () {
recalculateGutterHeight();
}, 100);
} );
function recalculateGutterHeight() {
var splitInner = $('.split-inner');
if (splitInner.length) {
height = 0;
splitInner.each(function() {
var splitHeight = $(this).outerHeight();
if (height < splitHeight) {
height = splitHeight;
}
});
}
$('#style-preview-container .gutter-horizontal').outerHeight(height);
}
function recalculateSplit() {
var form = $('.cf7cstmzr-form');
var split = $('.split');
var splitInner = $('.split-inner');
var splitContainer = $('#split-container');
var stylePreviewContainer = $('#style-preview-container');
var width = stylePreviewContainer.width();
if (splitInner.length) {
splitInner.each(function() {
$(this).outerWidth(width - 16);
});
}
}
})(jQuery);
</script>
<?php
} else {
?>
<style>
#style-preview-container {
width: 90%!important;
}
@media screen and (min-width: 599px) {
#style-preview-container {
width: 80%!important;
}
}
@media screen and (min-width: 961px) {
#style-preview-container {
width: 70%!important;
}
}
@media screen and (min-width: 1200px) {
#style-preview-container {
width: 60%!important;
}
}
</style>
<?php
echo do_shortcode('[contact-form-7 id="'.$form_id.'" title="' . $form->post_title . '"]');
}
?>
</div>
<?php
}
get_footer();
die;
}
}
public function show_admin_bar($show_admin_bar) {
$permalink_structure = get_option('permalink_structure');
if (!empty($permalink_structure)) {
$form_id = get_query_var( 'cf7cstmzr-form' );
} else {
if (!empty($_GET['cf7cstmzr_page']) && !empty($_GET['form_id'])) {
$form_id = $_GET['form_id'];
}
}
if ($form_id) {
return false;
}
return $show_admin_bar;
}
public function admin_body_class($classes) {
if(isset($_GET['page']) && sanitize_text_field($_GET['page']) == 'cf7cstmzr_page') {
$classes = $classes . ' cf7cstmzr-body';
if (!empty($_GET["fw"])) {
$classes = $classes . ' my-body-noscroll-class';
}
}
return $classes;
}
public function add_cf7_metabox($panels) {
$plugin_version = Cf7_License::get_license_version();
$panels['cf7cstmzr-style-scheme'] = array(
'title' => __('CF7 Styler', 'cf7-styler'),
'callback' => array($this, 'show_metabox')
);
return $panels;
}
public function show_metabox($contact_form) {
$plugin_version = Cf7_License::get_license_version();
$style_schemes = get_option('cf7cstmzr_style_schemes', array());
$form_id = $contact_form->id();
$selected_style = get_post_meta($form_id, 'cf7cstmzr_style_scheme', true);
$individually_styled_forms = Cf7_Style_Scheme::get_individually_styled_forms();
if ('free' === $plugin_version && !empty($individually_styled_forms)) {
foreach ($individually_styled_forms as $styled_form_id => $styled_form_style) {
$styled_form = get_post($styled_form_id);
if (!empty($styled_form)) {
$styled_form_title = $styled_form->post_title;
$styled_form_style_title = $style_schemes[$styled_form_style]['title'];
}
}
}
if (!empty($style_schemes)) {
?>
<h2>
<?php echo __('Select style scheme for this form', 'cf7-styler') ?>
</h2>
<select name="cf7cstmzr_style_scheme" id="cf7cstmzr_style_scheme" class="large-text">
<option value=""><?php echo __('- disable style scheme -', 'cf7-styler') ?></option>
<?php
foreach ($style_schemes as $slug => $scheme) {
if ('free' === $plugin_version && 'default' !== $slug) {
continue;
}
?>
<option value="<?php echo $slug ?>"<?php echo $slug === $selected_style ? ' selected' : ''; ?>><?php echo $scheme['title'] ?></option>
<?php
}
?>
</select>
<?php
if ('free' === $plugin_version && empty($selected_style) && !empty($styled_form_title)) {
?>
<p>
<?php
echo sprintf( __( 'Currently <strong>%s</strong> form is styled with <strong>%s</strong>. As in free version you can style only one form at a time and if you activate style for current form, style will be removed from other form.', 'cf7-styler' ), $styled_form_title, $styled_form_style_title );
?>
</p>
<?php
}
?>
<a class="button button-primary" target="_blank" href="<?php echo get_admin_url(); ?>/admin.php?page=cf7cstmzr_page&tab=form-customize">
<?php _e('Open styler', 'cf7-styler') ?>
</a>
<?php
}
}
public function save_cf7_metabox($post_ID, $post, $update) {
$plugin_version = Cf7_License::get_license_version();
$cf7cstmzr_style_scheme = !empty($_POST['cf7cstmzr_style_scheme']) ? sanitize_text_field($_POST['cf7cstmzr_style_scheme']) : false;
if (!empty($cf7cstmzr_style_scheme)) {
if ('free' === $plugin_version) {
global $wpdb;
$sql = "DELETE FROM {$wpdb->postmeta} WHERE meta_key='cf7cstmzr_style_scheme';";
$wpdb->query($sql);
}
update_post_meta( $post_ID, 'cf7cstmzr_style_scheme', $cf7cstmzr_style_scheme );
} else {
delete_post_meta($post_ID, 'cf7cstmzr_style_scheme');
}
}
public function plugin_menu_optin() {
global $submenu;
if (function_exists('cf7_styler')) {
$reconnect_url = cf7_styler()->get_activation_url( array(
'nonce' => wp_create_nonce( cf7_styler()->get_unique_affix() . '_reconnect' ),
'fs_action' => ( cf7_styler()->get_unique_affix() . '_reconnect' ),
) );
$is_registered = cf7_styler()->is_registered();
if (!$is_registered && isset($submenu["wpcf7"])) {
$submenu["wpcf7"][] = array(
'<span class="cf7cstmzr-submenu-item">' . __('Opt-in to see account', 'cf7-styler') . '</span>',
'manage_options',
$reconnect_url
);
}
}
}
}