File: /home/innocamp/public_html/wp-content/plugins/shortcoder/admin/edit.php
<?php
if( ! defined( 'ABSPATH' ) ) exit;
class SC_Admin_Edit{
public static function init(){
add_action( 'edit_form_after_title', array( __CLASS__, 'after_title' ) );
add_action( 'add_meta_boxes', array( __CLASS__, 'add_meta_boxes' ) );
add_action( 'save_post_' . SC_POST_TYPE, array( __CLASS__, 'save_post' ) );
add_filter( 'wp_insert_post_data' , array( __CLASS__, 'before_insert_post' ) , 99, 1 );
add_action( 'admin_enqueue_scripts', array( __CLASS__, 'enqueue_scripts' ) );
add_filter( 'admin_footer_text', array( __CLASS__, 'footer_text' ) );
}
public static function after_title( $post ){
if( $post->post_type != SC_POST_TYPE ){
return;
}
$settings = Shortcoder::get_sc_settings( $post->ID );
echo '<div id="sc_name">';
echo '<input type="text" class="widefat" title="' . esc_attr__( 'Name of the shortcode. Allowed characters are alphabets, numbers, hyphens and underscore.', 'shortcoder' ) . '" value="' . esc_attr( $post->post_name ) . '" name="post_name" id="post_name" pattern="[a-zA-z0-9\-_]+" required placeholder="' . esc_attr__( 'Enter shortcode name', 'shortcoder' ) . '" />';
echo '</div>';
echo '<div id="edit-slug-box">';
echo '<strong>' . esc_html__( 'Your shortcode', 'shortcoder' ) . ': </strong>';
echo '<code class="sc_preview_text">' . esc_html( Shortcoder::get_sc_tag( $post->ID ) ) . '</code>';
echo '<span id="edit-slug-buttons"><button type="button" class="sc_copy button button-small"><span class="dashicons dashicons-yes"></span> ' . esc_html__( 'Copy', 'shortcoder' ) . '</button></span>';
echo '<a href="#sc_mb_settings" class="sc_settings_link">' . esc_html__( 'Settings', 'shortcoder' ) . '</a>';
echo '</div>';
// Editor
self::editor( $post, $settings );
// Hidden section
self::hidden_section( $post, $settings );
}
public static function add_meta_boxes(){
add_meta_box( 'sc_mb_settings', __( 'Shortcode settings', 'shortcoder' ), array( __CLASS__, 'settings_form' ), SC_POST_TYPE, 'normal', 'default' );
add_meta_box( 'sc_mb_more_plugins', __( 'Support', 'shortcoder' ), array( __CLASS__, 'more_plugins' ), SC_POST_TYPE, 'side', 'default' );
add_meta_box( 'sc_mb_links', __( 'WordPress News', 'shortcoder' ), array( __CLASS__, 'feedback' ), SC_POST_TYPE, 'side', 'default' );
remove_meta_box( 'slugdiv', SC_POST_TYPE, 'normal' );
remove_meta_box( 'commentstatusdiv', SC_POST_TYPE, 'normal' );
remove_meta_box( 'commentsdiv', SC_POST_TYPE, 'normal' );
}
public static function settings_form( $post ){
wp_nonce_field( 'sc_post_nonce', 'sc_nonce' );
$settings = Shortcoder::get_sc_settings( $post->ID );
$fields = array(
array( __( 'Display name', 'shortcoder' ), SC_Admin_Form::field( 'text', array(
'value' => $post->post_title,
'name' => 'post_title',
'class' => 'widefat',
'helper' => __( 'Name of the shortcode to display when it is listed', 'shortcoder' )
))),
array( __( 'Description', 'shortcoder' ), SC_Admin_Form::field( 'textarea', array(
'value' => $settings[ '_sc_description' ],
'name' => '_sc_description',
'class' => 'widefat',
'helper' => __( 'Description of the shortcode for identification', 'shortcoder' )
))),
array( __( 'Temporarily disable shortcode', 'shortcoder' ), SC_Admin_Form::field( 'select', array(
'value' => $settings[ '_sc_disable_sc' ],
'name' => '_sc_disable_sc',
'list' => array(
'yes' => 'Yes',
'no' => 'No'
),
'helper' => __( 'Select to disable the shortcode from executing in all the places where it is used.', 'shortcoder' )
))),
array( __( 'Disable shortcode for administrators', 'shortcoder' ), SC_Admin_Form::field( 'select', array(
'value' => $settings[ '_sc_disable_admin' ],
'name' => '_sc_disable_admin',
'list' => array(
'yes' => 'Yes',
'no' => 'No'
),
'helper' => __( 'Select to disable the shortcode from executing for administrators.', 'shortcoder' )
))),
array( __( 'Execute shortcode on devices', 'shortcoder' ), SC_Admin_Form::field( 'select', array(
'value' => $settings[ '_sc_allowed_devices' ],
'name' => '_sc_allowed_devices',
'list' => array(
'all' => 'All devices',
'desktop_only' => 'Desktop only',
'mobile_only' => 'Mobile only'
),
'helper' => __( 'Select the devices where the shortcode should be executed. Note: If any caching plugin is used, a separate caching for desktop and mobile might be required.', 'shortcoder' )
))),
);
echo SC_Admin_Form::table( apply_filters( 'sc_mod_sc_settings_fields', $fields, $settings ) );
}
public static function save_post( $post_id ){
// Checks save status
$is_autosave = wp_is_post_autosave( $post_id );
$is_revision = wp_is_post_revision( $post_id );
$is_valid_nonce = ( isset( $_POST[ 'sc_nonce' ] ) && wp_verify_nonce( $_POST[ 'sc_nonce' ], 'sc_post_nonce' ) );
// Exits script depending on save status
if ( $is_autosave || $is_revision || !$is_valid_nonce ){
return;
}
$default_settings = Shortcoder::default_sc_settings();
$skip_sanitize = array();
foreach( $default_settings as $key => $val ){
if( array_key_exists( $key, $_POST ) ){
if( in_array( $key, $skip_sanitize ) ){
$val = current_user_can( 'unfiltered_html' ) ? $_POST[ $key ] : wp_kses_post( $_POST[ $key ] );
}else{
$val = sanitize_text_field( $_POST[ $key ] );
}
update_post_meta( $post_id, $key, $val );
}
}
}
public static function before_insert_post( $post ){
if( $post[ 'post_type' ] != SC_POST_TYPE ){
return $post;
}
$post_title = sanitize_text_field( $post[ 'post_title' ] );
if( empty( $post_title ) ){
$post[ 'post_title' ] = sanitize_text_field( $post[ 'post_name' ] );
}
if( $_POST && isset( $_POST[ 'sc_content' ] ) ){
$post[ 'post_content' ] = current_user_can( 'unfiltered_html' ) ? $_POST[ 'sc_content' ] : wp_kses_post( $_POST[ 'sc_content' ] );
}
return $post;
}
public static function editor_props( $settings ){
$g = SC_Admin::clean_get();
if( empty( $settings[ '_sc_editor' ] ) ){
$general_settings = Shortcoder::get_settings();
$settings[ '_sc_editor' ] = $general_settings[ 'default_editor' ];
}
$list = apply_filters( 'sc_mod_editors', array(
'text' => __( 'Text editor', 'shortcoder' ),
'visual' => __( 'Visual editor', 'shortcoder' ),
'code' => __( 'Code editor', 'shortcoder' )
));
$editor = ( isset( $g[ 'editor' ] ) && array_key_exists( $g[ 'editor' ], $list ) ) ? $g[ 'editor' ] : $settings[ '_sc_editor' ];
$switch = '<span class="sc_editor_list sc_editor_icon_' . esc_attr( $editor ) . '">';
$switch .= '<select name="_sc_editor" class="sc_editor" title="' . esc_attr__( 'Switch editor', 'shortcoder' ) . '">';
foreach( $list as $id => $name ){
$switch .= '<option value="' . esc_attr( $id ) . '" ' . selected( $editor, $id, false ) . '>' . esc_html( $name ) . '</option>';
}
$switch .= '</select>';
$switch .= '</span>';
return array(
'active' => $editor,
'switch_html' => $switch
);
}
public static function editor( $post, $settings ){
$editor = self::editor_props( $settings );
echo '<div class="hidden">';
echo '<div class="sc_editor_toolbar">';
echo '<button class="button button-primary sc_insert_param"><span class="dashicons dashicons-plus"></span>' . esc_html__( 'Insert shortcode parameters', 'shortcoder' ) . '<span class="dashicons dashicons-arrow-down"></span></button>';
echo $editor[ 'switch_html' ];
echo '</div>';
echo '</div>';
$post_data = get_post( $post->ID );
$post_content = $post_data->post_content;
if( SC_Admin::is_edit_page( 'new' ) ){
$general_settings = Shortcoder::get_settings();
$post_content = $general_settings[ 'default_content' ];
}
if( $editor[ 'active' ] == 'code' ){
echo '<div class="sc_cm_menu"></div>';
echo '<textarea name="sc_content" id="sc_content" class="sc_cm_content">' . esc_textarea( $post_content ) . '</textarea>';
}
if( in_array( $editor[ 'active' ], array( 'text', 'visual' ) ) ){
wp_editor( $post_content, 'sc_content', array(
'wpautop'=> false,
'textarea_rows'=> 20,
'tinymce' => ( $editor[ 'active' ] == 'visual' )
));
}
if( !current_user_can( 'unfiltered_html' ) ){
echo '<div class="notice notice-info"><p>' . esc_html__( 'Note: Your user role does not permit saving unrestricted HTML. Some tags and attributes will be removed before saving the content.', 'shortcoder' ) . '</p></div>';
}
do_action( 'sc_do_after_editor', $post, $settings, $editor );
}
public static function enqueue_scripts( $hook ){
global $post;
if( !SC_Admin::is_sc_admin_page() || $hook == 'edit.php' || $hook == 'edit-tags.php' || $hook == 'term.php' || $hook == 'shortcoder_page_settings' ){
return false;
}
$settings = Shortcoder::get_sc_settings( $post->ID );
$editor = self::editor_props( $settings );
wp_localize_script( 'sc-admin-js', 'SC_EDITOR', array(
'active' => $editor[ 'active' ]
));
if( $editor[ 'active' ] != 'code' ){
return false;
}
$cm_settings = array();
$cm_settings[ 'codeEditor' ] = wp_enqueue_code_editor(array(
'type' => 'htmlmixed'
));
wp_localize_script( 'sc-admin-js', 'SC_CODEMIRROR', $cm_settings );
}
public static function custom_params_list(){
$sc_wp_params = Shortcoder::wp_params_list();
echo '<ul class="sc_params_list">';
foreach( $sc_wp_params as $group => $group_info ){
echo '<li><span class="dashicons dashicons-' . esc_attr( $group_info['icon'] ) . '"></span>';
echo esc_html( $group_info[ 'name' ] );
echo '<ul class="sc_wp_params">';
foreach( $group_info[ 'params' ] as $param_id => $param_name ){
echo '<li data-id="' . esc_attr( $param_id ) . '">' . esc_html( $param_name ) . '</li>';
}
echo '</ul></li>';
}
echo '<li><span class="dashicons dashicons-list-view"></span>' . esc_html__( 'Custom parameter', 'shortcoder' ) . '<ul>';
echo '<li class="sc_params_form">';
echo '<p>' . esc_html__( 'Insert parameters in content and replace them with custom values when using the shortcode.', 'shortcoder' ) . '<a href="https://www.aakashweb.com/docs/shortcoder/custom-parameters/" target="_blank" title="' . esc_attr__( 'More information', 'shortcoder' ) . '"><span class="dashicons dashicons-info"></span></a></p>';
echo '<h4>' . esc_html__( 'Enter custom parameter name', 'shortcoder' ) . '</h4>';
echo '<input type="text" class="sc_cp_box widefat" pattern="[a-zA-Z0-9_-]+"/>';
echo '<h4>' . esc_html__( 'Default value', 'shortcoder' ) . '</h4>';
echo '<input type="text" class="sc_cp_default widefat"/>';
echo '<button class="button sc_cp_btn">' . esc_html__( 'Insert parameter', 'shortcoder' ) . '</button>';
echo '<p class="sc_cp_info"><small>' . esc_html__( 'Only alphabets, numbers, underscores and hyphens are allowed. Custom parameters are case insensitive', 'shortcoder' ) . '</small></p></li>';
echo '</ul></li>';
echo '<li><span class="dashicons dashicons-screenoptions"></span>' . esc_html__( 'Custom Fields', 'shortcoder' ) . '<ul>';
echo '<li class="sc_params_form">';
echo '<p>' . esc_html__( 'Pull a custom field value of the current post and display it inside the shortcode content.', 'shortcoder' ) . '<a href="https://www.aakashweb.com/docs/shortcoder/shortcode-parameters/#custom-fields" target="_blank" title="' . esc_attr__( 'More information', 'shortcoder' ) . '"><span class="dashicons dashicons-info"></span></a></p>';
echo '<h4>' . esc_html__( 'Enter custom field name', 'shortcoder' ) . '</h4>';
echo '<input type="text" class="sc_cf_box widefat" pattern="[a-zA-Z0-9_-]+"/>';
echo '<button class="button sc_cf_btn">' . esc_html__( 'Insert custom field', 'shortcoder' ) . '</button>';
echo '<p class="sc_cf_info"><small>' . esc_html__( 'Only alphabets, numbers, underscore and hyphens are allowed. Cannot be empty.', 'shortcoder' ) . '</small></p></li>';
echo '</ul></li>';
echo '</ul>';
}
public static function hidden_section( $post, $settings ){
self::custom_params_list();
}
public static function feedback( $post ){
echo '<div class="feedback">';
echo '<p>Get updates on the WordPress plugins, tips and tricks to enhance your WordPress experience. No spam.</p>';
echo '<div class="subscribe_form" data-action="https://aakashweb.us19.list-manage.com/subscribe/post-json?u=b7023581458d048107298247e&id=ef5ab3c5c4&c=">
<input type="text" value="' . esc_attr( get_option( 'admin_email' ) ) . '" class="subscribe_email_box" placeholder="Your email address">
<p class="subscribe_confirm">Thanks for subscribing !</p>
<button class="button subscribe_btn"><span class="dashicons dashicons-email"></span> Subscribe</button>
</div>';
echo '</div>';
}
public static function more_plugins( $post ){
echo '<div class="feedback">';
echo '<ul>';
echo '<li><a href="https://twitter.com/intent/follow?screen_name=aakashweb" target="_blank"><span class="dashicons dashicons-twitter"></span> Follow on Twitter</a></li>';
echo '<li><a href="https://www.facebook.com/aakashweb/" target="_blank"><span class="dashicons dashicons-facebook-alt"></span> Follow on Facebook</a></li>';
echo '<li><a href="https://www.aakashweb.com/forum/discuss/wordpress-plugins/shortcoder/" target="_blank"><span class="dashicons dashicons-format-chat"></span> Support Forum</a></li>';
echo '<li><a href="https://wordpress.org/support/plugin/shortcoder/reviews/?rate=5#new-post" target="_blank"><span class="dashicons dashicons-star-filled"></span> Rate plugin</a></li>';
echo '</ul>';
echo '<h3>More WordPress plugins from us</h3>';
echo '<ul>';
echo '<li><a href="https://www.aakashweb.com/wordpress-plugins/super-rss-reader/?utm_source=shortcoder&utm_medium=sidebar&utm_campaign=srr-pro" target="_blank">Super RSS Reader</a> - Display RSS feeds</li>';
echo '<li><a href="https://www.aakashweb.com/wordpress-plugins/announcer/?utm_source=shortcoder&utm_medium=sidebar&utm_campaign=announcer-pro" target="_blank">Announcer</a> - Add notification message bars easily</li>';
echo '<li><a href="https://www.aakashweb.com/wordpress-plugins/ultimate-floating-widgets/?utm_source=shortcoder&utm_medium=sidebar&utm_campaign=ufw-pro" target="_blank">Ultimate Floating Widget</a> - Create floating sidebar popup and add widgets inside</li>';
echo '<li><a href="https://www.aakashweb.com/wordpress-plugins/wp-socializer/?utm_source=shortcoder&utm_medium=sidebar&utm_campaign=wpsr-pro" target="_blank">WP Socializer</a> - Add beautiful social media share icons</li>';
echo '<li><a href="https://www.aakashweb.com/wordpress-plugins/?utm_source=shortcoder&utm_medium=sidebar&utm_campaign=aw" target="_blank">More</a> <span class="dashicons dashicons-arrow-right-alt"></span></li>';
echo '</ul>';
echo '</div>';
}
public static function footer_text( $text ){
if( SC_Admin::is_sc_admin_page() ){
return '<span class="footer_thanks">Thanks for using <a href="https://www.aakashweb.com/wordpress-plugins/shortcoder/" target="_blank">Shortcoder</a> • Please <a href="https://wordpress.org/support/plugin/shortcoder/reviews/?rate=5#new-post" target="_blank">rate 5 stars</a> and spread the word.</span>';
}
return $text;
}
}
SC_Admin_Edit::init();
?>