Mini Shell
<?php
//////////////////////////////////////////////////////////////
//===========================================================
// ajax.php
//===========================================================
// PAGELAYER
// Inspired by the DESIRE to be the BEST OF ALL
// ----------------------------------------------------------
// Started by: Pulkit Gupta
// Date: 23rd Jan 2017
// Time: 23:00 hrs
// Site: http://pagelayer.com/wordpress (PAGELAYER)
// ----------------------------------------------------------
// Please Read the Terms of use at http://pagelayer.com/tos
// ----------------------------------------------------------
//===========================================================
// (c)Pagelayer Team
//===========================================================
//////////////////////////////////////////////////////////////
// Are we being accessed directly ?
if(!defined('PAGELAYER_VERSION')) {
exit('Hacking Attempt !');
}
// Is the nonce there ?
if(empty($_REQUEST['pagelayer_nonce'])){
return;
}
pagelayer_memory_limit(128);
// The ajax handler
add_action('wp_ajax_pagelayer_wp_widget', 'pagelayer_wp_widget_ajax');
function pagelayer_wp_widget_ajax(){
global $pagelayer;
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
if(!current_user_can('edit_theme_options')){
$ret['error'][] = __pl('no_permission');
pagelayer_json_output($ret);
}
pagelayer_load_shortcodes();
header('Content-Type: application/json');
$ret = [];
$tag = @$_POST['tag'];
//pagelayer_print($pagelayer->shortcodes[$tag]);
// No tag ?
if(empty($pagelayer->shortcodes[$tag])){
$ret['error'][] = __pl('no_tag');
pagelayer_json_output($ret);
}
// Include the widgets
include_once(ABSPATH . 'wp-admin/includes/widgets.php');
$class = $pagelayer->shortcodes[$tag]['widget'];
// Check the widget class exists ?
if(empty($class) || !class_exists($class)){
$ret['error'][] = __pl('no_widget_class');
pagelayer_json_output($ret);
}
$instance = [];
$widget = new $class();
$widget->_set('pagelayer-widget-1234567890');
// Is there any existing data ?
if(!empty($_POST['widget_data'])){
$json = json_decode(stripslashes($_POST['widget_data']), true);
//pagelayer_print($json);die();
if(!empty($json)){
$instance = $json;
}
}
// Are there any form values ?
if(!empty($_POST['values'])){
parse_str(stripslashes($_POST['values']), $data);
//pagelayer_print($data);die();
// Any data ?
if(!empty($data)){
// Rss widget checkboxes fix
if(!empty($data['widget-rss'])){
$data['widget-rss']['pagelayer-widget-1234567890']['show_summary'] = empty($data['widget-rss']['pagelayer-widget-1234567890']['show_summary'])? 0 : 1;
$data['widget-rss']['pagelayer-widget-1234567890']['show_author'] = empty($data['widget-rss']['pagelayer-widget-1234567890']['show_author'])? 0 : 1;
$data['widget-rss']['pagelayer-widget-1234567890']['show_date'] = empty($data['widget-rss']['pagelayer-widget-1234567890']['show_date'])? 0 : 1;
}
// First key is useless
$data = current($data);
// Do we still have valid data ?
if(!empty($data)){
// 2nd key is useless and just over-ride instance
$instance = current($data);
}
}
}
// Settings instance For Text widget
if($widget->id_base == 'text'){
$instance['visual'] = false;
$instance['legacy'] = false;
}
// Get the form
ob_start();
$widget->form($instance);
$ret['form'] = ob_get_contents();
ob_end_clean();
// Get the html
ob_start();
$widget->widget([], $instance);
$ret['html'] = ob_get_contents();
ob_end_clean();
// Widget data to set
if(!empty($instance)){
$ret['widget_data'] = $instance;
}
// Custom html widget form elements
if(!empty($widget) && $widget->name=='Custom HTML'){
$custom_html = explode('>', $ret['form']);
$custom_html[0] = '<label for="widget-custom_html-pagelayer-widget-1234567890-title">Title:</label>'.$custom_html[0];
$custom_html[0] = str_replace('type="hidden"', 'type="text"',$custom_html[0]);
$custom_html[1] = '<label for="widget-custom_html-pagelayer-widget-1234567890-content">Content:</label>'.$custom_html[1];
$custom_html[1] = str_replace('hidden', '', $custom_html[1]);
$ret['form'] = implode('>', $custom_html);
}
pagelayer_json_output($ret);
}
// Update Post content
add_action('wp_ajax_pagelayer_save_content', 'pagelayer_save_content');
function pagelayer_save_content(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$content = $_POST['pagelayer_update_content'];
$postID = (int) $_GET['postID'];
if(empty($postID)){
$msg['error'] = __pl('invalid_post_id');
pagelayer_json_output($msg);
}
$_post = get_post($postID);
// Post found ?
if(empty($_post)){
$msg['error'] = __pl('invalid_post_id');
pagelayer_json_output($msg);
}
// Are you allowed to edit ?
if(!pagelayer_user_can_edit($postID)){
$msg['error'][] = __pl('no_permission');
pagelayer_json_output($msg);
}
// Check if the post exists
if(!empty($postID)){
$content = base64_decode($content);
/*if(!pagelayer_is_utf8($content)){
$content = utf8_encode($content);
}*/
$content = wp_slash($content);
$post = array(
'ID' => $postID,
'post_content' => $content,
);
$is_xss = pagelayer_xss_content($content);
if(!pagelayer_user_can_add_js_content() && strlen($is_xss) > 0){
$msg['error'][] = __pl('xss_found').' - '.$is_xss;
pagelayer_json_output($msg);
}
// Any properties ?
$allowed = ['post_title', 'post_name', 'post_excerpt', 'post_status', 'post_password', 'post_date', 'post_author', 'post_parent', 'menu_order'];
foreach($allowed as $k){
if(isset($_REQUEST[$k])){
$post[$k] = $_REQUEST[$k];
}
}
if(!empty($post['post_password']) && $_REQUEST['post_sticky'] == true){
$msg['error'] = __pl('post_pass_with_sticky_err');
pagelayer_json_output($msg);
}
$post['comment_status'] = !empty($_REQUEST['comment_status']) ? 'open' : 'closed';
$post['ping_status'] = !empty($_REQUEST['ping_status']) ? 'open' : 'closed';
$post['post_status'] = empty($post['post_status']) ? $_post->post_status : $post['post_status'];
if(!empty($post['post_status']) && $post['post_status'] == 'publish'){
// Allowed to publish pages ?
if($_post->post_type == 'page' && !current_user_can('publish_pages')){
$msg['error'][] = __pl('no_publish_permission');
pagelayer_json_output($msg);
}
// Allowed to publish posts ?
if($_post->post_type == 'post' && !current_user_can('publish_posts')){
$post['post_status'] = 'pending';
}
}
if(!empty($post['post_password'])){
$post['post_password'] = (in_array($post['post_status'], array('pass_protected', 'publish')) ? $post['post_password'] : '');
$post['post_status'] = 'publish';
}else{
$post['post_status'] = ($post['post_status'] == 'pass_protected') ? 'publish' : $post['post_status'];
$post['post_password'] = '';
}
// Set post GMT time
if(!empty($post['post_date']) && '0000-00-00 00:00:00' !== $post['post_date']){
$post['post_date_gmt'] = get_gmt_from_date( $post['post_date'] );
if( in_array($post['post_status'], array('future', 'publish')) && $_post->post_date_gmt === '0000-00-00 00:00:00' ){
$post['edit_date'] = true;
}
}
$_REQUEST['featured_image'] = (int) $_REQUEST['featured_image'];
if(!empty($_REQUEST['featured_image'])){
set_post_thumbnail($postID, $_REQUEST['featured_image']);
}else{
delete_post_thumbnail($postID);
}
if(!isset($_REQUEST['post_category'])){
$_REQUEST['post_category'] = '';
}
if(!isset($_REQUEST['post_tags'])){
$_REQUEST['post_tags'] = '';
}
if($_post->post_type == 'post'){
$post['post_category'] = pagelayer_sanitize_text_field($_REQUEST['post_category']);
$post['tags_input'] = pagelayer_sanitize_text_field($_REQUEST['post_tags']);
}else{
$cat_name = pagelayer_post_type_category($_post->post_type);
if($cat_name){
$post['tax_input'][$cat_name] = pagelayer_sanitize_text_field($_REQUEST['post_category']);
}
$tag_name = pagelayer_post_type_tag($_post->post_type);
if($tag_name){
$post['tax_input'][$tag_name] = pagelayer_sanitize_text_field($_REQUEST['post_tags']);
}
}
if(isset($_REQUEST['post_sticky']) && !empty($_REQUEST['post_sticky'])){
stick_post( $postID );
}else{
if(is_sticky($postID)){
unstick_post( $postID );
}
}
// Any contact templates ?
if(!empty($_REQUEST['contacts'])){
update_post_meta($postID, 'pagelayer_contact_templates', $_REQUEST['contacts']);
}else{
delete_post_meta($postID, 'pagelayer_contact_templates');
}
// Save copyright
if(isset($_REQUEST['copyright']) && current_user_can('manage_options')){
update_option('pagelayer-copyright', wp_unslash($_REQUEST['copyright']));
}
// Apply a filter
$post = apply_filters('pagelayer_save_content', $post);
// Update the post into the database
$ret = wp_update_post($post, true);
// Render the post
//update_post_meta($postID, 'pagelayer_rendered_post', pagelayer_get_post_content($postID));
if (is_wp_error($ret)) {
$errors = $ret->get_error_messages();
$msg['error'] = __pl('post_update_err').' : '.implode('', $errors);
}else{
// Get the updated post
$_post = get_post($postID);
// Is this a Pagelayer post
$data = get_post_meta($postID, 'pagelayer-data', true);
if(empty($data)){
// Convert to pagelayer accessed post
if(!add_post_meta($postID, 'pagelayer-data', time(), true)){
update_post_meta($postID, 'pagelayer-data', time());
}
}
$msg['success'] = __pl('post_update_success');
}
}else{
$msg['error'] = __pl('post_update_err');
}
$msg['post_status'] = (empty($_post->post_password)) ? $_post->post_status : 'pass_protected';
// Save global widgets data
if(!empty($_REQUEST['global_widgets'])){
pagelayer_save_templ_content(true);
}
// Save nav menu data
if(!empty($_REQUEST['pagelayer_nav_items']) && current_user_can('edit_theme_options')){
$menu_items = (array) $_REQUEST['pagelayer_nav_items'];
foreach($menu_items as $items){
pagelayer_save_nav_menu_items($items);
}
}
// Save Customizer data
if(!empty($_REQUEST['pagelayer_customizer_options']) && current_user_can('edit_theme_options')){
$customizer_options = wp_unslash($_REQUEST['pagelayer_customizer_options']);
$customizer_options = json_decode($customizer_options, true);
// Add current post type
$customizer_options['pagelayer_current_post_type'] = $_post->post_type;
pagelayer_save_customizer_options($customizer_options);
}
pagelayer_json_output($msg);
}
// Save sections and global sections
add_action('wp_ajax_pagelayer_save_templ_content', 'pagelayer_save_templ_content');
function pagelayer_save_templ_content($echo = false){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
if ( ! current_user_can( get_post_type_object( 'pagelayer-template' )->cap->create_posts ) ) {
$ret['error'][$g_post_id] = __pl('no_permission');
pagelayer_json_output($ret);
return false;
}
// Are you allowed to edit ?
if(!pagelayer_user_can_edit($_REQUEST['postID'])){
$msg['error'][] = __pl('no_permission');
pagelayer_json_output($msg);
}
$ret = array();
// Save global widgets data
if(empty($_REQUEST['global_widgets'])){
$ret['error'][] = 'No widgets given';
pagelayer_json_output($ret);
return false;
}
$global_widgets = $_REQUEST['global_widgets'];
foreach($global_widgets as $key => $value){
$g_post_id = (int) $value['post_id'];
// Are you allowed to edit ?
if(!empty($g_post_id) && !pagelayer_user_can_edit($g_post_id)){
$ret['error'][$g_post_id] = __pl('no_permission').' : '.$g_post_id;
continue;
}
// Decode base64 data
$value['content'] = base64_decode($value['content']);
$value['content'] = wp_slash($value['content']);
$is_xss = pagelayer_xss_content($value['content']);
if(!current_user_can('manage_options') && strlen($is_xss) > 0){
$ret['error'][$g_post_id] = __pl('xss_found').' - '.$is_xss;
pagelayer_json_output($ret);
}
// We need to create the post
if(empty($value['post_id'])){
$g_ret = wp_insert_post([
'post_type' => 'pagelayer-template',
'post_title' => $value['title'],
'post_content' => $value['content'],
'post_status' => 'publish',
'comment_status' => 'closed',
'ping_status' => 'closed'
]);
$g_post_id = $g_ret;
// Save our template metas
update_post_meta($g_post_id, 'pagelayer_template_type', $value['type']);
update_post_meta($g_post_id, 'pagelayer-data', time());
}else if(!empty($value['content'])){
// Save global widget content
$post = array(
'ID' => $g_post_id,
'post_title' => $value['title'],
'post_content' => $value['content'],
);
wp_update_post($post);
}
if(is_wp_error($g_post_id)){
$ret['error'][$g_post_id] = __pl('template_update_err');
}else{
$ret['success'][$g_post_id] = __pl('template_update_success');
}
}
if(!$echo){
pagelayer_json_output($ret);
}else{
return $ret;
}
}
// Update the Site Title
add_action('wp_ajax_pagelayer_set_jscss_giver', 'pagelayer_set_jscss_giver');
function pagelayer_set_jscss_giver(){
global $wpdb;
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
if( !current_user_can('manage_options') ){
$ret['error'] = __pl('no_permission');
pagelayer_json_output($ret);
}
$val = (int) @$_REQUEST['set'];
if(in_array($val, [1, -1])){
update_option('pagelayer_enable_giver', $val);
}
$ret['success'] = 1;
pagelayer_json_output($ret);
}
// Shortcodes Widget Handler
add_action('wp_ajax_pagelayer_do_shortcodes', 'pagelayer_do_shortcodes');
function pagelayer_do_shortcodes(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
if(!current_user_can('edit_posts')){// TODO : WooCommerce
$ret['error'][] = __pl('no_permission');
pagelayer_json_output($ret);
}
$data = '';
if(isset($_REQUEST['shortcode_data'])){
$data = stripslashes($_REQUEST['shortcode_data']);
}
// Load shortcodes
pagelayer_load_shortcodes();
$data = pagelayer_the_content($data);
// Create the HTML object
$node = pagelayerQuery::parseStr($data);
$node->query('.pagelayer-ele')->removeClass('pagelayer-ele');
echo $node->html();
wp_die();
}
// Give the JS
add_action('wp_ajax_pagelayer_givejs', 'pagelayer_givejs');
function pagelayer_givejs(){
global $pagelayer;
// WordPress adds the Expires header in all AJAX calls. We need to remove it for cache to work
header_remove("Expires");
header_remove("Cache-Control");
// Load shortcodes
pagelayer_load_shortcodes();
// Load font options
pagelayer_load_font_options();
// Pagelayer Template Loading Mechanism
include_once(PAGELAYER_DIR.'/js/givejs.php');
exit();
}
add_action('wp_ajax_pagelayer_givecss', 'pagelayer_givecss');
add_action('wp_ajax_nopriv_pagelayer_givecss', 'pagelayer_givecss');
function pagelayer_givecss(){
global $pagelayer;
// WordPress adds the Expires header in all AJAX calls. We need to remove it for cache to work
header_remove("Expires");
header_remove("Cache-Control");
// Pagelayer Template Loading Mechanism
include_once(PAGELAYER_DIR.'/css/givecss.php');
exit();
}
// Shortcodes Widget Handler
add_action('wp_ajax_pagelayer_get_section_shortcodes', 'pagelayer_get_section_shortcodes');
function pagelayer_get_section_shortcodes(){
global $pagelayer;
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
if(!current_user_can('edit_posts')){
$ret['error'][] = __pl('no_permission');
pagelayer_json_output($ret);
}
$data = '';
if(isset($_REQUEST['pagelayer_section_id'])){
$get_url = PAGELAYER_API.'/library.php?give_id='.$_REQUEST['pagelayer_section_id'].(!empty($pagelayer->license['license']) ? '&license='.$pagelayer->license['license'] : '');
// For SitePad users
if(function_exists('get_softaculous_file')){
$get_url = get_softaculous_file($get_url, 1);
}
$fetch = wp_remote_get($get_url, array('timeout' => 60));
if ( is_array( $fetch ) && ! is_wp_error( $fetch ) && isset( $fetch['body'] ) ) {
$data = json_decode( $fetch['body'], true ); // use the content
}else{
$data['error'] = __pl('The response was malformed');
pagelayer_json_output($data);
}
}
if(isset($_REQUEST['postID'])){
$post_id = (int) $_REQUEST['postID'];
if(!empty($post_id)){
$post = get_post( $post_id );
// Need to make the reviews post global
if ( !empty( $post ) ) {
$GLOBALS['post'] = $post;
$GLOBALS['wp_query'] = new WP_Query([
'post_type' => $GLOBALS['post']->post_type,
'post__in' => array($post_id),
]);
}
}
}
// Upload the images if any in the shortcode
preg_match_all('/"'.preg_quote('{{pl_lib_images}}', '/').'([^"]*)"/is', $data['code'], $matches);
foreach($matches[0] as $k => $v){
$image_url = trim($v, '"\'');
$urls[$image_url] = $image_url;
}
foreach($urls as $k => $image_url){
$file = basename($image_url);
$id = 0;
// Upload this
if(!empty($data[$file])){
$id = pagelayer_upload_media($file, base64_decode($data[$file]));
if(!empty($id)){
$data['code'] = str_replace('"'.$image_url.'"', '"'.$id.'"', $data['code']);
}
}
}
// Load shortcodes
pagelayer_load_shortcodes();
if(!empty($data['code'])){
$data['code'] = pagelayer_the_content($data['code'], true);
}
pagelayer_json_output($data);
}
// Shortcodes Widget Handler
add_action('wp_ajax_pagelayer_get_section_blocks', 'pagelayer_get_section_blocks');
function pagelayer_get_section_blocks(){
global $pagelayer;
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
if(!current_user_can('edit_posts')){
$ret['error'][] = __pl('no_permission');
pagelayer_json_output($ret);
}
$data = '';
if(isset($_REQUEST['pagelayer_section_id'])){
$get_url = PAGELAYER_API.'/library.php?give_id='.$_REQUEST['pagelayer_section_id'].(!empty($pagelayer->license['license']) ? '&license='.$pagelayer->license['license'] : '');
// For SitePad users
if(function_exists('get_softaculous_file')){
$get_url = get_softaculous_file($get_url, 1);
}
$fetch = wp_remote_get($get_url, array('timeout' => 60));
if ( is_array( $fetch ) && ! is_wp_error( $fetch ) && isset( $fetch['body'] ) ) {
$data = json_decode( $fetch['body'], true ); // use the content
}else{
$data['error'] = __pl('The response was malformed');
pagelayer_json_output($data);
}
}
// Upload the images if any in the shortcode
preg_match_all('/"'.preg_quote('{{pl_lib_images}}', '/').'([^"]*)"/is', $data['code'], $matches);
foreach($matches[0] as $k => $v){
$image_url = trim($v, '"\'');
$urls[$image_url] = $image_url;
}
foreach($urls as $k => $image_url){
$file = basename($image_url);
$id = 0;
// Upload this
if(!empty($data[$file])){
$id = pagelayer_upload_media($file, base64_decode($data[$file]));
if(!empty($id)){
$data['code'] = str_replace('"'.$image_url.'"', '"'.$id.'"', $data['code']);
}
}
}
if ( false !== strpos( $data['code'], '[pl_' ) ) {
// Load shortcodes
pagelayer_load_shortcodes();
// Load Parse Shortcodes
include_once(PAGELAYER_DIR.'/main/parse-shortcodes.php');
$data['code'] = pagelayer_do_shortcode_to_block($data['code']);
}
$data['code'] = pagelayer_add_tmp_atts($data['code']);
pagelayer_json_output($data);
}
// Get the Site Title
add_action('wp_ajax_pagelayer_fetch_site_title', 'pagelayer_fetch_site_title');
function pagelayer_fetch_site_title(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
echo get_bloginfo('name');
wp_die();
}
// Update the Site Title
add_action('wp_ajax_pagelayer_update_site_title', 'pagelayer_update_site_title');
function pagelayer_update_site_title(){
global $wpdb;
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$site_title = $_POST['site_title'];
if(!current_user_can('manage_options')){
$ret['error'][] = __pl('no_permission');
pagelayer_json_output($ret);
}
update_option('blogname', $site_title);
wp_die();
}
// Show the SideBars
add_action('wp_ajax_pagelayer_fetch_sidebar', 'pagelayer_fetch_sidebar');
function pagelayer_fetch_sidebar(){
global $wp_registered_sidebars;
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
// Create a list
$pagelayer_wp_widgets = array();
foreach($wp_registered_sidebars as $v){
$pagelayer_wp_widgets[$v['id']] = $v['name'];
}
$id = @$_REQUEST['sidebar'];
if(function_exists('dynamic_sidebar') && !empty($pagelayer_wp_widgets[$id])) {
ob_start();
dynamic_sidebar($id);
$result = ob_get_clean();
}else{
$result = __pl('no_widget_area');
}
echo $result;
wp_die();
}
// Show the primary menu !
add_action('wp_ajax_pagelayer_fetch_primary_menu', 'pagelayer_fetch_primary_menu');
function pagelayer_fetch_primary_menu(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
if(isset($_POST['nav_list'])){
$_POST['nav_list'] = (int) $_POST['nav_list'];
// Load Pagelayer nav menu walker
include_once(PAGELAYER_DIR.'/main/nav_walker.php');
$postID = (int) $_REQUEST['postID'];
// To on live mode
$GLOBALS['post'] = get_post($postID);
$GLOBALS['wp_query'] = new WP_Query([
'post_type' => $GLOBALS['post']->post_type,
'post__in' => array($postID),
]);
// Load short
pagelayer_load_shortcodes();
wp_nav_menu([
'menu' => wp_get_nav_menu_object($_POST['nav_list']),
'menu_id' => $_POST["nav_list"],
'menu_class' => 'pagelayer-wp_menu-ul',
'walker' => new Pagelayer_Walker_Nav_Menu(),
//'theme_location' => 'primary',
'echo' => true,
]);
}
wp_die();
}
// Save post revision
add_action('wp_ajax_pagelayer_create_post_autosave', 'pagelayer_create_post_autosave');
function pagelayer_create_post_autosave(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$ret = array();
$postID = (int) $_GET['postID'];
$content = $_REQUEST['pagelayer_post_content'];
// Decode base64 data
$content = base64_decode($content);
$content = wp_slash($content);
// Are you allowed to edit ?
if(!pagelayer_user_can_edit($postID)){
$ret['error'][] = __pl('no_permission');
pagelayer_json_output($ret);
}
if(empty($postID)){
$ret['error'] = __pl('invalid_post_id');
}else{
$post = array(
'post_ID' => $postID,
'post_content' => $content,
);
$ret['id'] = wp_create_post_autosave($post);
}
$ret['url'] = get_preview_post_link($postID);
pagelayer_json_output($ret);
}
// Get post revision
add_action('wp_ajax_pagelayer_get_revision', 'pagelayer_get_revision');
function pagelayer_get_revision(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$ret = array();
$postID = (int) $_GET['postID'];
// Are you allowed to edit ?
if(!pagelayer_user_can_edit($postID)){
$ret['error'][] = __pl('no_permission');
pagelayer_json_output($ret);
}
if(empty($postID)){
$ret['error'] = __pl('invalid_post_id');
}else{
$ret = pagelayer_get_post_revision_by_id($postID);
}
pagelayer_json_output($ret);
}
// Apply post revision
add_action('wp_ajax_pagelayer_apply_revision', 'pagelayer_apply_revision');
function pagelayer_apply_revision(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$revisionID = (int) $_REQUEST['revisionID'];
$parID = wp_get_post_parent_id($revisionID);
$ret = array();
if(empty($parID)){
$parID = $revisionID;
}
// Are you allowed to edit ?
if(!pagelayer_user_can_edit($parID)){
$ret['error'][] = __pl('no_permission');
pagelayer_json_output($ret);
}
if(empty($revisionID)){
$ret['error'] = __pl('invalid_post_id');
}else{
$post = get_post( $revisionID );
if ( empty( $post ) ) {
$ret['error'] = __pl('invalid_revision');
pagelayer_json_output($ret);
}
// Need to make the reviews post global
$GLOBALS['post'] = $post;
$GLOBALS['wp_query'] = new WP_Query([
'post_type' => $GLOBALS['post']->post_type,
'post__in' => array($parID),
]);
// Need to reload the shortcodes
pagelayer_load_shortcodes();
$ret['id'] = $revisionID;
$ret['content'] = pagelayer_the_content($post->post_content, true);
if(is_wp_error($post)) {
$ret['error'] = __pl('rev_load_error');
}else{
$ret['success'] = __pl('rev_load_success');
}
wp_reset_postdata();
}
pagelayer_json_output($ret);
}
// Get post revision
add_action('wp_ajax_pagelayer_delete_revision', 'pagelayer_delete_revision');
function pagelayer_delete_revision() {
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$revisionID = (int) $_REQUEST['revisionID'];
$parID = wp_get_post_parent_id($revisionID);
$ret = array();
// Are you allowed to edit ?
if(!pagelayer_user_can_edit($parID)){
$ret['error'][] = __pl('no_permission');
pagelayer_json_output($ret);
}
if(empty($revisionID)){
$ret['error'] = __pl('invalid_post_id');
}else{
$revision = get_post( $revisionID );
if ( empty( $revision ) ) {
$ret['error'] = __pl('invalid_revision');
}else{
if ( ! current_user_can( 'delete_post', $parID ) ) {
$ret['error'] = __pl('access_denied');
pagelayer_json_output($ret);
}
$deleted = wp_delete_post_revision( $revision->ID );
if ( ! $deleted || is_wp_error( $deleted ) ) {
$ret['error'] = __pl('delete_rev_error');
}else{
$ret['success'] = __pl('delete_rev_success');
}
}
}
pagelayer_json_output($ret);
}
// Get post navigation
add_action('wp_ajax_pagelayer_post_nav', 'pagelayer_post_nav');
function pagelayer_post_nav() {
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
if(!isset($_REQUEST['data']) || !isset($_REQUEST['postID'])){
return;
}
$el['atts'] = $_REQUEST['data'];
$post = get_post($_REQUEST['postID']);
// Need to make this post global
$GLOBALS['post'] = $post;
$in_same_term = false;
$taxonomies = 'category';
$title = '';
$arrows_list = $el['atts']['arrows_list'];
if($el['atts']['in_same_term']){
$in_same_term = true;
$taxonomies = $el['atts']['taxonomies'];
}
if($el['atts']['post_title']){
$title = '<span class="pagelayer-post-nav-title">%title</span>';
}
$next_label = '<span class="pagelayer-next-holder">
<span class="pagelayer-post-nav-link"> '.$el["atts"]["next_label"].'</span>'.$title.'
</span>
<span class="pagelayer-post-nav-icon fa fa-'.$arrows_list.'-right"></span>';
$prev_label = '<span class="pagelayer-post-nav-icon fa fa-'.$arrows_list.'-left"></span>
<span class="pagelayer-next-holder">
<span class="pagelayer-post-nav-link"> '.$el["atts"]["prev_label"].'</span>'.$title.'
</span>';
$el['atts']['next_link'] = get_next_post_link('%link', $next_label, $in_same_term, '', $taxonomies);
$el['atts']['prev_link'] = get_previous_post_link('%link', $prev_label, $in_same_term, '', $taxonomies );
pagelayer_json_output($el);
}
// Get post comment template
add_action('wp_ajax_pagelayer_post_comment', 'pagelayer_post_comment');
function pagelayer_post_comment() {
global $post;
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
if(!isset($_REQUEST['postID'])){
return true;
}
$GLOBALS['post'] = get_post($_REQUEST['postID']);
$GLOBALS['withcomments'] = true;
// Load shortcodes
pagelayer_load_shortcodes();
$el = [];
pagelayer_sc_post_comment($el);
echo $el['atts']['post_comment'];
wp_die();
}
// Get post comment template
add_action('wp_ajax_pagelayer_post_info', 'pagelayer_post_info');
function pagelayer_post_info() {
global $post;
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
if(!isset($_REQUEST['postID']) || !isset($_REQUEST['el'])){
return true;
}
$el['atts'] = $_REQUEST['el'];
$GLOBALS['post'] = get_post($_REQUEST['postID']);
// Load shortcodes
pagelayer_load_shortcodes();
pagelayer_sc_post_info_list($el);
pagelayer_json_output($el['atts']);
}
// Get the Featured Image
add_action('wp_ajax_pagelayer_fetch_featured_img', 'pagelayer_fetch_featured_img');
function pagelayer_fetch_featured_img(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$id = get_post_thumbnail_id( (int) $_POST['post_id'] );
$img = [];
if(empty($id)){
pagelayer_json_output($img);
}
$img = pagelayer_image($id);
pagelayer_json_output($img);
}
// Get the postfolio posts
add_action('wp_ajax_pagelayer_fetch_posts', 'pagelayer_fetch_posts');
function pagelayer_fetch_posts(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
// TODO : Allowed
echo pagelayer_widget_posts($_POST);
wp_die();
}
// Get the Posts
add_action('wp_ajax_pagelayer_posts_data', 'pagelayer_posts_data');
function pagelayer_posts_data(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
// Load shortcodes
pagelayer_load_shortcodes();
// TODO : Allowed
echo pagelayer_posts($_POST);
wp_die();
}
// Get the Posts
add_action('wp_ajax_pagelayer_archive_posts_data', 'pagelayer_archive_posts_data');
function pagelayer_archive_posts_data(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
// Set excerpt length
if(!empty($_POST['atts']['exc_length'])){
$exc_length = (int) $_POST['atts']['exc_length'];
add_filter( 'excerpt_length', function($length) use($exc_length){
return $exc_length;
}, 999 );
}
// Load shortcodes
pagelayer_load_shortcodes();
foreach($_POST['atts'] as $k => $v){
$v = pagelayer_maybe_implode($v);
$r[] = esc_html($k).'="'.pagelayer_escapeHTML($v).'"';
}
$string = implode(' ', $r);
if(preg_match('/\]/is', $string)){
die('Hacking Attempt');
}
$sc = '[pl_archive_posts '.$string.'][/pl_archive_posts]';
// TODO : Allowed
echo pagelayer_the_content($sc);
wp_die();
}
// Handle Contact Form Data
add_action('wp_ajax_pagelayer_contact_submit', 'pagelayer_contact_submit');
add_action('wp_ajax_nopriv_pagelayer_contact_submit', 'pagelayer_contact_submit' );
function pagelayer_contact_submit(){
// Some AJAX security
check_ajax_referer('pagelayer_global', 'pagelayer_nonce');
// A filter to short circuit this contact form
$continue = apply_filters('pagelayer_contact_submit_start', 1);
if(empty($continue)){
return false;
}
$formdata = $_POST;
// NOTE : NEVER add anything to $formdata except $_POST vars
if(isset($_POST['g-recaptcha-response']) ){
if(!pagelayer_captcha_verify()){
$wp['failed'] = get_option('pagelayer_recaptcha_failed', __pl('cap_ver_fail'));
pagelayer_json_output($wp);
}
unset($formdata['g-recaptcha-response']);
}
// Unset the nonce
unset($formdata['pagelayer_nonce']);
$to_mail = get_option('pagelayer_cf_to_email');
$from_mail = get_option('pagelayer_cf_from_email');
$subject = get_option('pagelayer_cf_subject');
$additional_headers = get_option('pagelayer_cf_headers');
$reply_to = '';
$body = '';
$headers = '';
$custom_templ = array();
$use_custom = false;
$use_html = false;
$pagelayer_id = sanitize_text_field($formdata['cfa-pagelayer-id']);
if(isset($formdata['cfa-custom-template']) && !empty($formdata['cfa-post-id'])){
$post_id = (int) $formdata['cfa-post-id'];
if(!empty($post_id)){
$contact_array = get_post_meta($post_id, 'pagelayer_contact_templates', true);
if(!empty($contact_array) && !empty($contact_array[$pagelayer_id])){
$custom_templ = $contact_array[$pagelayer_id];
$use_custom = true;
}
}
}
if($use_custom && !empty($custom_templ)){
if(!empty($custom_templ['to_email'])){
$to_mail = $custom_templ['to_email'];
}
if(!empty($custom_templ['from_email'])){
$from_mail = $custom_templ['from_email'];
}
if(!empty($custom_templ['cont_subject'])){
$subject = $custom_templ['cont_subject'];
}
if(!empty($custom_templ['cont_header'])){
$additional_headers = $custom_templ['cont_header'];
}
if(!empty($custom_templ['cont_body'])){
$body = $custom_templ['cont_body'];
}
if(!empty($custom_templ['cont_use_html'])){
$use_html = true;
$headers .= "Content-Type: text/html\n";
}
}
if(!empty($from_mail)){
$headers .= "From: $from_mail\n";
}
if ( !empty($additional_headers) ) {
$headers .= $additional_headers . "\n";
}
if ( empty($body) ) {
// Make the email content
foreach($formdata as $k => $i){
$not_allow = ['cfa-pagelayer-id', 'cfa-redirect', 'cfa-post-id', 'cfa-custom-template', 'pagelayer-contact-submit'];
if(in_array($k, $not_allow)){
continue;
}
if(is_array($i)){
$i = pagelayer_flat_join($i);
}
// Record a reply to if it is to be used
if(is_email(trim($i)) && empty($reply_to)){
$reply_to = trim($i);
}
$body .= $k."\t : \t $".$k."\n";
}
$body .= "\n\n --\n This e-mail was sent from a contact form (".get_home_url().")";
}
// Dow we have a reply to in the headers ?
if(!preg_match('/reply\-to/is', $headers) && !empty($reply_to)){
$headers .= "Reply-To: $reply_to\n";
}
// Add attachment
if(!empty($_FILES)){
add_action('phpmailer_init', 'pagelayer_cf_email_attachment', 10, 1);
}
// If we are using HTML, then we should escape html as well
if(!empty($use_html)){
foreach($formdata as $k => $i){
if(is_array($i)){
$i = pagelayer_flat_join($i);
}
$formdata[$k] = esc_html($i);
}
}
// Add Site Title as option in formdata
$formdata['site_title'] = get_bloginfo( 'name' );
// Do parse a variables
$to_mail = pagelayer_replace_vars($to_mail, $formdata, '$');
$from_mail = pagelayer_replace_vars($from_mail, $formdata, '$');
$subject = pagelayer_replace_vars($subject, $formdata, '$');
$headers = pagelayer_replace_vars($headers, $formdata, '$');
$body = pagelayer_replace_vars($body, $formdata, '$');
if ( $use_html && ! preg_match( '%<html[>\s].*</html>%is', $body ) ) {
$header = '<!doctype html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head><title>' . esc_html( $subject ) . '</title></head>
<body>';
$footer = '</body></html>';
$body = $header . wpautop( $body ) . $footer;
}
$to_mail = apply_filters('pagelayer_contact_send', $to_mail, $formdata);
// Send the email
if(!empty($to_mail)){
$r = wp_mail( $to_mail, $subject, $body, $headers );
}
if($r == TRUE){
$wp['success'] = pagelayer_get_option( 'pagelayer_cf_success' );
}else{
$wp['failed'] = pagelayer_get_option( 'pagelayer_cf_failed' );
}
pagelayer_json_output($wp);
}
// Handle Login Submit
add_action('wp_ajax_pagelayer_login_submit', 'pagelayer_login_submit');
add_action('wp_ajax_nopriv_pagelayer_login_submit', 'pagelayer_login_submit');
function pagelayer_login_submit(){
// Some AJAX security
check_ajax_referer('pagelayer_global', 'pagelayer_nonce');
$creds = array();
$creds['user_login'] = $_REQUEST['username'];
$creds['user_password'] = $_REQUEST['password'];
$creds['remember'] = $_REQUEST['remember_me'];
// Login the user
$user = wp_signon( $creds, false );
if ( is_wp_error($user) ){
$data['error'] = $user->get_error_message();
}else{
// If After logout URL, then save
if(!empty($_REQUEST['logout_url'])){
update_user_option($user->ID, 'pagelayer_logout_url', $_REQUEST['logout_url']);
}
$data['redirect'] = (empty($_REQUEST['login_url']) ? '' : $_REQUEST['login_url']);
$data['error'] = '';
}
pagelayer_json_output($data);
}
// Get Page List for SiteMap
add_action('wp_ajax_pagelayer_get_pages_list', 'pagelayer_get_pages_list');
function pagelayer_get_pages_list(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$args = array(
'post_type' => $_POST['type'],
'orderby' => $_POST['post_order'],
'order' => $_POST['order'],
'hierarchical' => (empty($_POST['hier']) || $_POST['hier'] == null ? '' : $_POST['hier']),
'number' => (empty($_POST['depth']) || $_POST['depth'] == null ? '' : $_POST['depth']),
'posts_per_page' => -1,
);
$option = '<ul>';
$pages = new WP_Query($args);
$posts = $pages->posts;
foreach ( $posts as $page ) {
$option .= '<li class="pagelayer-sitemap-list-item" data-postID="'.$page->ID.'"><a class="pagelayer-ele-link" href="'.$page->guid.'">'.$page->post_name.'</a></li>';
}
$option .= '</ul>';
echo $option;
wp_die();
}
// Get the data for template
add_action('wp_ajax_pagelayer_search_ids', 'pagelayer_search_ids');
function pagelayer_search_ids() {
// Some AJAX security
check_ajax_referer('pagelayer_builder', 'pagelayer_nonce');
if ( empty( $_POST['filter_type'] ) || empty( $_POST['search'] ) ) {
wp_die();
}
$sel_opt = '';
switch ( $_POST['filter_type'] ) {
case 'taxonomy':
$query_params = [
'taxonomy' => $_POST['object_type'],
'search' => $_POST['search'],
'hide_empty' => false,
];
$terms = get_terms( $query_params );
global $wp_taxonomies;
foreach ( $terms as $term ) {
$sel_opt .= '<span class="pagelayer-temp-search-sel-span" value="'. $term->term_taxonomy_id .'">'. $term->name .'</span>';
}
break;
case 'post':
$query_params = [
'post_type' => $_POST['object_type'], //$this->extract_post_type( $data ),
's' => $_POST['search'],
'posts_per_page' => -1,
];
if ( 'attachment' === $query_params['post_type'] ) {
$query_params['post_status'] = 'inherit';
}
$query = new \WP_Query( $query_params );
foreach ( $query->posts as $post ) {
$sel_opt .= '<span class="pagelayer-temp-search-sel-span" value="'. $post->ID .'">'. $post->post_title .'</span>';
}
break;
case 'author':
$query_params = [
'capability' => array( 'edit_posts' ),
'fields' => [
'ID',
'display_name',
],
'search' => '*' . $_POST["search"] . '*',
'search_columns' => [
'user_login',
'user_nicename',
],
];
// Capability queries were only introduced in WP 5.9.
if( version_compare( $GLOBALS['wp_version'], '5.9-alpha', '<' ) ){
$args['who'] = 'authors';
unset( $args['capability'] );
}
$user_query = new \WP_User_Query( $query_params );
foreach ( $user_query->get_results() as $author ) {
$sel_opt .= '<span class="pagelayer-temp-search-sel-span" value="'. $author->ID .'">'. $author->display_name .'</span>';
}
break;
/* case 'menu':
$menuItems = wp_get_nav_menu_items( (int)$_POST['object_type']);
foreach ( $menuItems as $item ) {
if($item -> menu_item_parent !=0 ){
continue;
}
$sel_opt .= '<span class="pagelayer-temp-search-sel-span" value="'. $item -> ID .'">'. $item -> title.'</span>';
}
break; */
default:
$sel_opt = 'Result Not Found';
}
if(!empty($sel_opt)){
echo $sel_opt;
}else{
echo 'Result Not Found';
}
wp_die();
}
// Save the post data from pagelayer setting page
add_action('wp_ajax_pagelayer_save_template', 'pagelayer_save_template');
function pagelayer_save_template() {
// Some AJAX security
check_ajax_referer('pagelayer_builder', 'pagelayer_nonce');
$done = [];
$post_id = (int) $_GET['postID'];
// Are you allowed to edit ?
if(!empty($post_id) && !pagelayer_user_can_edit($post_id)){
$done['error'][] = __pl('no_permission');
pagelayer_json_output($done);
}
// We need to create the post
if(empty($post_id)){
if (!current_user_can('edit_posts')) {
$done['error'] = __pl('access_denied');
pagelayer_json_output($done);
}
// Get the template type
if(empty($_POST['pagelayer_template_type'])){
$done['error'] = __pl('temp_error_type');
pagelayer_json_output($done);
}
$ret = wp_insert_post([
'post_title' => $_POST['pagelayer_lib_title'],
'post_type' => 'pagelayer-template',
'post_status' => 'publish',
'comment_status' => 'closed',
'ping_status' => 'closed'
]);
// An error occured
if(is_wp_error($ret)){
$done['error'] = __pl('temp_error').' : '.$ret->get_error_message();
pagelayer_json_output($done);
}
$post_id = $ret;
$done['id'] = $post_id;
// Save our template type
$ret = update_post_meta($post_id, 'pagelayer_template_type', $_POST['pagelayer_template_type']);
}
// The ID in consideration
$done['id'] = $post_id;
// Check if the post title in not empty
if(!empty($_POST['pagelayer_lib_title'])){
$post = array(
'ID' => $post_id,
'post_title' => $_POST['pagelayer_lib_title'],
);
// Update the post into the database
$ret = wp_update_post($post);
}
// Save template library display conditions
$condi_array = array();
$condi_len = count($_POST['pagelayer_condition_type']);
if($_POST['pagelayer_template_type'] != 'section'){
for( $i =0; $i < $condi_len; $i++ ){
$condi_array[$i] = array(
'type' => $_POST['pagelayer_condition_type'][$i],
'template' => $_POST['pagelayer_condition_name'][$i],
'sub_template' => $_POST['pagelayer_condition_sub_template'][$i],
'id' => $_POST['pagelayer_condition_id'][$i],
);
}
}
//print_r($condi_array);
$ret = update_post_meta($post_id, 'pagelayer_template_conditions', $condi_array);
if(is_wp_error($post_id)){
$done['error'] = __pl('temp_error').' : '.$ret->get_error_message();
}else{
$done['success'] = __pl('temp_update_success');
}
pagelayer_json_output($done);
}
// Products Categories Handler
add_action('wp_ajax_pagelayer_product_categories', 'pagelayer_product_categories');
function pagelayer_product_categories(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$attributes = '';
$attributes .= ' number="'. $_POST['atts']['number'] .'" ';
$attributes .= ' columns="'. $_POST['atts']['columns'] .'" ';
$attributes .= ' hide_empty="'. (!empty($_POST['atts']['hide_empty']) ? 1 : 0) .'" ';
$attributes .= ' orderby="'. $_POST['atts']['nuorderbymber'] .'" ';
$attributes .= ' order="'. $_POST['atts']['order'] .'" ';
if ( 'by_id' === $_POST['atts']['source'] ) {
$attributes .= ' ids="'. $_POST['atts']['by_id'] .'" ';
} elseif ( 'by_parent' === $_POST['atts']['source'] ) {
$attributes .= ' parent="'. $_POST['atts']['parent'] .'" ';
} elseif ( 'current_subcategories' === $_POST['atts']['source'] ) {
$attributes .= ' parent="'. get_queried_object_id() .'" ';
}
$shortcode = '[product_categories '. $attributes .']';
// do_shortcode the shortcode
echo pagelayer_the_content($shortcode);
wp_die();
}
// Products Categories Handler
add_action('wp_ajax_pagelayer_products_ajax', 'pagelayer_products_ajax');
function pagelayer_products_ajax(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
if ( WC()->session ) {
wc_print_notices();
}
$no_found = $_POST['atts']['no_found'];
$attributes = '';
$type = $_POST['atts']['source'];
$attributes .= ' columns="'. $_POST['atts']['columns'] .'" ';
$attributes .= ' rows="'. $_POST['atts']['rows'] .'" ';
$attributes .= ' paginate="'. (!empty($_POST['atts']['paginate']) ? true : false) .'" ';
$attributes .= ' orderby="'. $_POST['atts']['orderby'] .'" ';
$attributes .= ' order="'. $_POST['atts']['order'] .'" ';
$attributes .= ' cache="false" ';
// Hide the catalog order
if( empty($_POST['atts']['allow_order']) ){
remove_action( 'woocommerce_before_shop_loop', 'woocommerce_catalog_ordering', 30 );
}
// Hide the result count
if( empty($_POST['atts']['show_result']) ){
remove_action( 'woocommerce_before_shop_loop', 'woocommerce_result_count', 20 );
}
if( $type == 'by_id' ){
$type = 'products';
$attributes .= ' ids="'. (!empty($_POST['atts']['ids']) ? $_POST['atts']['ids'] : '') .'" ';
}elseif( $type == 'pagelayer_current_query' ){
$atts['paginate'] = (!empty($_POST['atts']['paginate']) ? true : false);
$atts['cache'] = false;
$type = 'pagelayer_current_query';
// Set the current query
add_action( 'woocommerce_shortcode_products_query', 'pagelayer_shortcode_current_query', 10, 10);
// If product not found
add_action( "woocommerce_shortcode_{$type}_loop_no_results", function ($attributes) use ($no_found){
echo '<div class="pagelayer-product-no-found">'.$no_found.'</div>';
} );
// Get the products list
$shortcode = new WC_Shortcode_Products( $atts, $type );
echo $shortcode->get_content();
return true;
}
$shortcode = '['.$type.' '. $attributes .']';
$content = pagelayer_the_content($shortcode);
// If product not found
if('<div class="woocommerce columns-'.$_POST['atts']['columns'] .' "></div>' == $content){
$content = '<div class="pagelayer-product-no-found">'. $no_found .'</div>';
}
echo $content;
wp_die();
}
// Get Taxamony List for SiteMap
add_action('wp_ajax_pagelayer_get_taxonomy_list', 'pagelayer_get_taxonomy_list');
function pagelayer_get_taxonomy_list(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$args = array(
'title_li' => 0,
'orderby' => $_POST['post_order'],
'order' => $_POST['order'],
'style' => '',
'hide_empty' => $_POST['empty'],
'echo' => false,
'hierarchical' => (empty($_POST['hier']) || $_POST['hier'] == null ? '' : $_POST['hier']),
'taxonomy' => $_POST['type'],
'depth' => (empty($_POST['depth']) || $_POST['depth'] == null ? '' : $_POST['depth']),
);
$taxonomies = get_categories( $args );
$option = '<ul>';
foreach ( $taxonomies as $taxonomy ) {
$option .= '<li class="pagelayer-sitemap-list-item" data-postID="'.$taxonomy->term_id.'"><a class="pagelayer-ele-link" href="'.get_term_link($taxonomy->term_id).'">'.$taxonomy->name.'</a></li>';
}
$option .= '</ul>';
echo $option;
wp_die();
}
// Export the template
add_action('wp_ajax_pagelayer_export_template', 'pagelayer_export_template');
function pagelayer_export_template(){
global $pagelayer;
// Some AJAX security
check_ajax_referer('pagelayer_builder', 'pagelayer_nonce');
$done = [];
if(!current_user_can('edit_theme_options')){
$done['error'][] = __pl('no_permission');
pagelayer_json_output($done);
}
// Load the templates
pagelayer_builder_load_templates();
if(empty($pagelayer->templates)){
$done['error'] = __pl('temp_export_empty');
pagelayer_json_output($done);
}
// Load Shortcodes
pagelayer_load_shortcodes();
// Get the active theme
$theme_dir = get_stylesheet_directory();
$conf = [];
$pagelayer->export_mode = 1;
// Write the files
foreach($pagelayer->templates as $k => $v){
// Are there specific templates to export
if(!empty($_POST['templates'])){
if(!isset($_POST['templates'][$v->ID])){
continue;
}
}
// Only blocks allowed
if(!has_blocks($v->post_content) && !empty($v->post_content)){
$done['error'] = 'The pagelayer template '.$v->ID.' has Shortcodes which is not allowed for export !';
pagelayer_json_output($done);
}
$v->post_name = (empty($v->post_name) && $v->post_status == 'draft') ? sanitize_title($v->post_title).'-draft' : $v->post_name;
// Write the content
file_put_contents($theme_dir.'/'.$v->post_name.'.pgl', pagelayer_export_content($v->post_content));
$conf[$v->post_name] = [
'type' => get_post_meta($v->ID, 'pagelayer_template_type', true),
'title' => $v->post_title,
'conditions' => get_post_meta($v->ID, 'pagelayer_template_conditions', true),
];
}
// Write the config
file_put_contents($theme_dir.'/pagelayer.conf', json_encode($conf, JSON_PRETTY_PRINT));
$conf = [];
// Load the other posts
foreach($pagelayer->settings['post_types'] as $type){
// Anything to export for users ?
if(!empty($_POST[$type]) && is_array($_POST[$type])){
mkdir($theme_dir.'/data/');
mkdir($theme_dir.'/data/'.$type);
$pids = [];
foreach($_POST[$type] as $k => $v){
$pids[] = (int) $k;
}
// Load the type
$_query = new WP_Query([
'post_type' => $type,
'status' => 'publish',
'post__in' => $pids,
'posts_per_page' => -1,
]);
$posts = $_query->posts;
// Write the files
foreach($posts as $k => $v){
// Only blocks allowed
if(!has_blocks($v->post_content) && !empty($v->post_content)){
$done['error'] = 'The '.$type.' '.$v->ID.' has Shortcodes which is not allowed for export !';
pagelayer_json_output($done);
}
$v->post_name = (empty($v->post_name) && $v->post_status == 'draft') ? sanitize_title($v->post_title).'-draft' : $v->post_name;
file_put_contents($theme_dir.'/data/'.$type.'/'.$v->post_name, pagelayer_export_content($v->post_content));
unset($v->post_content);
$meta = get_post_meta($v->ID);
$meta = array_combine(array_keys($meta), array_column($meta, 0));
// Export media
if(!empty($meta['_thumbnail_id'])){
$file = pagelayer_export_media_files($meta['_thumbnail_id'], $exp_img_url);
// Did it export ?
if(!empty($file)){
$meta['_thumbnail_id'] = $exp_img_url;
}
}
// Also put the meta
file_put_contents($theme_dir.'/data/'.$type.'/'.$v->post_name.'.meta', json_encode($meta, JSON_PRETTY_PRINT));
//Export taxonomies in post
$taxonomies = get_object_taxonomies( $v->post_type, 'objects' );
$post_taxonomies = wp_filter_object_list( $taxonomies, [
'public' => true,
'show_in_nav_menus' => true,
] );
foreach( $post_taxonomies as $slug => $object ){
if(empty($v->taxonomies) || !is_array($v->taxonomies)){
$v->taxonomies = array();
}
$tax_name = $object->name;
$the_terms = get_the_terms($v->ID, $tax_name);
$v->taxonomies[$tax_name] = '';
if(!empty($the_terms)){
$v->taxonomies[$tax_name] = implode(',', array_column($the_terms, 'term_id'));
}
}
$conf[$type][$v->post_name] = $v;
do_action('pagelayer_'.$type.'_exported', $v, $theme_dir);
}
ksort($conf[$type]);
}
}
// Export menus
if(!empty($pagelayer->export_menus) && is_array($pagelayer->export_menus)){
mkdir($theme_dir.'/data/menus');
foreach($pagelayer->export_menus as $k => $v){
$menu = (int) $k;
$menu = wp_get_nav_menu_object( $menu );
if(empty($menu)){
$done['error'] = 'Could not export menu ID - '.$k;
continue;
}
// Menu Items
$menu_items = wp_get_nav_menu_items( $menu->term_id );
$data = [];
if(is_array($menu_items) && !empty($menu_items)){
foreach($menu_items as $kk => $singlenav){
//$navmetas = get_post_meta($singlenav->ID);
//$navmetas = array_combine(array_keys($navmetas), array_column($navmetas, 0));
$data[$kk]['post'] = $singlenav;
$navmetas = array();
$pl_content = get_post_meta($singlenav->ID, '_pagelayer_content', true);
if(!empty($pl_content)){
$navmetas['_pagelayer_content'] = pagelayer_export_content($pl_content);
}
$data[$kk]['post_metas'] = $navmetas;
}
}
// Also put the meta
file_put_contents($theme_dir.'/data/menus/'.$menu->slug, json_encode($data, JSON_PRETTY_PRINT));
$conf['menus'][$menu->slug] = $menu;
do_action('pagelayer_menus_exported', $v, $theme_dir);
}
}
// Export the settings
$settings = ['pagelayer_content_width', 'pagelayer_body_font', 'pagelayer_tablet_breakpoint', 'pagelayer_mobile_breakpoint', 'pagelayer_header_code','pagelayer_body_open_code', 'pagelayer_footer_code', 'pagelayer_sidebar', 'page_for_posts', 'pagelayer_global_fonts', 'pagelayer_global_colors'];
foreach($settings as $v){
$vv = get_option($v);
if($vv){
$conf['conf'][$v] = $vv;
}
}
// Load CSS settings
foreach($pagelayer->css_settings as $k => $params){
foreach($pagelayer->screens as $sk => $sv){
$suffix = (!empty($sv) ? '_'.$sv : '');
$setting = empty($params['key']) ? 'pagelayer_'.$k.'_css' : $params['key'];
$tmp = get_option($setting.$suffix);
if(!empty($tmp)){
$conf['conf'][$setting.$suffix] = $tmp;
}
}
}
// Export all the taxonomies
$post_types = pagelayer_get_public_post_types();
// Export all the Post Type CSS Settings
foreach ( $post_types as $pt_slug => $type ) {
if ( $pt_slug == 'attachment' ) {
continue;
}
foreach($pagelayer->css_settings as $k => $params){
foreach($pagelayer->screens as $sk => $sv){
$suffix = (!empty($sv) ? '_'.$sv : '');
$setting = empty($params['key']) ? 'pagelayer_'.$k.'_css_'.$pt_slug : $params['key'].'_'.$pt_slug;
$tmp = get_option($setting.$suffix);
if(!empty($tmp)){
$conf['conf'][$setting.$suffix] = $tmp;
}
}
}
}
// Export all the taxonomies
foreach ( $post_types as $post_type => $label ) {
$type_taxonomies = get_object_taxonomies( $post_type, 'objects' );
$taxonomies = wp_filter_object_list( $type_taxonomies, [
'public' => true,
'show_in_nav_menus' => true,
] );
foreach( $taxonomies as $slug => $object ){
$query_params = [
'taxonomy' => $object->name,
'hide_empty' => false,
];
$terms = get_terms( $query_params );
foreach($terms as $term){
$conf['taxonomies'][$term->term_id] = $term;
}
}
}
// Write the config
if(!empty($conf)){
file_put_contents($theme_dir.'/pagelayer-data.conf', json_encode($conf, JSON_PRETTY_PRINT));
}
// Are we to export any media ?
if(!empty($pagelayer->media_to_export)){
// TODO
//$done['media'] = $pagelayer->media_to_export;
}
do_action('pagelayer_template_export_completed');
$done['success'] = __pl('temp_export_success');
// Output and die
pagelayer_json_output($done);
}
add_action('wp_ajax_pagelayer_get_cat_checkboxes', 'pagelayer_get_cat_checkboxes');
function pagelayer_get_cat_checkboxes(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$ret = [];
$cat_name = '';
if(!current_user_can('manage_categories')){
$ret['error'] = __pl('no_permission');
pagelayer_json_output($ret);
}
if(empty($_POST['postid']) || !is_numeric($_POST['postid'])){
$ret['error'] = __pl('invalid_post_id');
pagelayer_json_output($ret);
}
$post = (int) $_POST['postid'];
$post = get_post($post);
if(empty($post) || is_wp_error($post)){
$ret['error'] = __pl('invalid_post_id');
pagelayer_json_output($ret);
}
$cat_name = pagelayer_post_type_category($post->post_type);
if(!empty($_POST['new_cat'])){
parse_str($_POST['new_cat'], $formdata);
$ret['new_cat_id'] = wp_insert_category([
'taxonomy' => $cat_name,
'cat_name' => $formdata['category_name'],
'category_parent' => (($formdata['pagelayer_cat_parent'] == 0) ? '' : $formdata['pagelayer_cat_parent'])
]);
}
$ret += pagelayer_post_cats($post);
pagelayer_json_output($ret);
}
add_action('wp_ajax_pagelayer_get_post_tags', 'pagelayer_get_post_tags');
function pagelayer_get_post_tags(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$ret = [];
$tag_name = '';
if(!current_user_can('manage_categories')){
$ret['error'] = __pl('no_permission');
pagelayer_json_output($ret);
}
if(empty($_POST['postid']) || !is_numeric($_POST['postid']) ){
pagelayer_json_output($ret);
}
$post = (int) $_POST['postid'];
$post = get_post($post);
if(empty($post) || is_wp_error($post)){
$ret['error'] = __pl('invalid_post_id');
pagelayer_json_output($ret);
}
$tag_name = pagelayer_post_type_tag($post->post_type);
if(!empty($_POST['new_tag'])){
$ret['tag_id'] = wp_insert_term($_POST['new_tag'], $tag_name);
$ret['tag_id'] = $ret['tag_id']['term_id'];
}
$ret += pagelayer_post_tags($post);
pagelayer_json_output($ret);
}
add_action('wp_ajax_pagelayer_custom_font', 'pagelayer_custom_font');
function pagelayer_custom_font(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$ret = [];
if(empty($_POST['font_name'])){
pagelayer_json_output($ret);
}
$name = preg_replace('/_plf$/is', '', pagelayer_optREQ('font_name'));
//echo $name;
$args = [
'post_type' => PAGELAYER_FONT_POST_TYPE,
'status' => 'publish',
'posts_per_page' => 1,
'name' => $name
];
//var_dump($pagelayer->fonts);
$query = get_posts($args);
//var_dump($query);
if(empty($query)){
pagelayer_json_output($ret);
}
$post = $query[0];
$meta_box_value = get_post_meta( $post->ID, 'pagelayer_font_link', true);
if(empty($meta_box_value)){
pagelayer_json_output($ret);
}
$ret['style']= '<style id="'.$name.'_plf" >@font-face { font-family: "'.$name.'_plf"'.'; src: url("'.$meta_box_value.'"); font-weight: 100 200 300 400 500 600 700 800 900;}</style>';
pagelayer_json_output($ret);
}
add_action('wp_ajax_pagelayer_trash_post', 'pagelayer_trash_post');
function pagelayer_trash_post(){
// Some AJAX security
check_ajax_referer('pagelayer_ajax', 'pagelayer_nonce');
$ret = [];
if(empty($_POST['postid']) && !is_numeric($_POST['postid'])){
$ret = ['error' => __pl('invalid_post_id')];
pagelayer_json_output($ret);
}
if(!current_user_can( 'delete_post', $_POST['postid'] )){
$ret = ['error' => __pl('no_permission')];
pagelayer_json_output($ret);
}
$ret['url'] = admin_url('/edit.php?post_type=') .get_post_type($_POST['postid']);
wp_trash_post($_POST['postid']);
pagelayer_json_output($ret);
}
add_action('wp_ajax_pagelayer_infinite_posts', 'pagelayer_infinite_posts');
add_action('wp_ajax_nopriv_pagelayer_infinite_posts', 'pagelayer_infinite_posts');
function pagelayer_infinite_posts(){
// Some AJAX security
check_ajax_referer('pagelayer_global', 'pagelayer_nonce');
pagelayer_load_shortcodes();
$tag = 'pl_posts';
if(isset($_REQUEST['data']['tag']) && $_REQUEST['data']['tag'] == 'pl_archive_posts' ){
$tag = 'pl_archive_posts';
}
$content = get_comment_delimited_block_content( 'pagelayer/'.$tag, $_REQUEST['data']['atts'] , '');
$wp['posts'] = pagelayer_the_content($content);
pagelayer_json_output( $wp );
}
Zerion Mini Shell 1.0