mirror of
https://gh.wpcy.net/https://github.com/presscustomizr/hueman.git
synced 2026-04-28 15:40:42 +08:00
368 lines
8.4 KiB
PHP
368 lines
8.4 KiB
PHP
<?php
|
|
/**
|
|
* OptionTree Function.
|
|
*
|
|
* @package OptionTree
|
|
*/
|
|
|
|
if ( ! defined( 'OT_VERSION' ) ) {
|
|
exit( 'No direct script access allowed' );
|
|
}
|
|
|
|
if ( ! function_exists( 'ot_options_id' ) ) {
|
|
|
|
/**
|
|
* Theme Options ID
|
|
*
|
|
* @return string
|
|
*
|
|
* @access public
|
|
* @since 2.3.0
|
|
*/
|
|
function ot_options_id() {
|
|
|
|
return apply_filters( 'ot_options_id', 'option_tree' );
|
|
|
|
}
|
|
}
|
|
|
|
if ( ! function_exists( 'ot_settings_id' ) ) {
|
|
|
|
/**
|
|
* Theme Settings ID
|
|
*
|
|
* @return string
|
|
*
|
|
* @access public
|
|
* @since 2.3.0
|
|
*/
|
|
function ot_settings_id() {
|
|
|
|
return apply_filters( 'ot_settings_id', 'option_tree_settings' );
|
|
|
|
}
|
|
}
|
|
|
|
if ( ! function_exists( 'ot_layouts_id' ) ) {
|
|
|
|
/**
|
|
* Theme Layouts ID
|
|
*
|
|
* @return string
|
|
*
|
|
* @access public
|
|
* @since 2.3.0
|
|
*/
|
|
function ot_layouts_id() {
|
|
|
|
return apply_filters( 'ot_layouts_id', 'option_tree_layouts' );
|
|
|
|
}
|
|
}
|
|
|
|
if ( ! function_exists( 'ot_get_option' ) ) {
|
|
|
|
/**
|
|
* Get Option.
|
|
*
|
|
* Helper function to return the option value.
|
|
* If no value has been saved, it returns $default.
|
|
*
|
|
* @param string $option_id The option ID.
|
|
* @param string $default The default option value.
|
|
* @return mixed
|
|
*
|
|
* @access public
|
|
* @since 2.0
|
|
*/
|
|
function ot_get_option( $option_id, $default = '' ) {
|
|
|
|
// @hu_custom Temporary hack.
|
|
if ( ! apply_filters( 'use_option_tree' , true ) && class_exists( 'HU_utils' ) ) {
|
|
return HU_utils::$inst->hu_opt( $option_id );
|
|
}
|
|
|
|
// Get the saved options.
|
|
$options = get_option( ot_options_id() );
|
|
|
|
// Look for the saved value.
|
|
if ( isset( $options[ $option_id ] ) && '' !== $options[ $option_id ] ) {
|
|
|
|
return ot_wpml_filter( $options, $option_id );
|
|
|
|
}
|
|
|
|
return $default;
|
|
|
|
}
|
|
}
|
|
|
|
if ( ! function_exists( 'ot_echo_option' ) ) {
|
|
|
|
/**
|
|
* Echo Option.
|
|
*
|
|
* Helper function to echo the option value.
|
|
* If no value has been saved, it echos $default.
|
|
*
|
|
* @param string $option_id The option ID.
|
|
* @param string $default The default option value.
|
|
* @return mixed
|
|
*
|
|
* @access public
|
|
* @since 2.2.0
|
|
*/
|
|
function ot_echo_option( $option_id, $default = '' ) {
|
|
|
|
echo ot_get_option( $option_id, $default ); // phpcs:ignore
|
|
|
|
}
|
|
}
|
|
|
|
if ( ! function_exists( 'ot_wpml_filter' ) ) {
|
|
|
|
/**
|
|
* Filter the return values through WPML
|
|
*
|
|
* @param array $options The current options.
|
|
* @param string $option_id The option ID.
|
|
* @return mixed
|
|
*
|
|
* @access public
|
|
* @since 2.1
|
|
*/
|
|
function ot_wpml_filter( $options, $option_id ) {
|
|
|
|
// Return translated strings using WMPL.
|
|
if ( function_exists( 'icl_t' ) ) {
|
|
|
|
$settings = get_option( ot_settings_id() );
|
|
|
|
if ( isset( $settings['settings'] ) ) {
|
|
|
|
foreach ( $settings['settings'] as $setting ) {
|
|
|
|
// List Item & Slider.
|
|
if ( $option_id === $setting['id'] && in_array( $setting['type'], array( 'list-item', 'slider' ), true ) ) {
|
|
|
|
foreach ( $options[ $option_id ] as $key => $value ) {
|
|
|
|
foreach ( $value as $ckey => $cvalue ) {
|
|
|
|
$id = $option_id . '_' . $ckey . '_' . $key;
|
|
$_string = icl_t( 'Theme Options', $id, $cvalue );
|
|
|
|
if ( ! empty( $_string ) ) {
|
|
|
|
$options[ $option_id ][ $key ][ $ckey ] = $_string;
|
|
}
|
|
}
|
|
}
|
|
|
|
// List Item & Slider.
|
|
} elseif ( $option_id === $setting['id'] && 'social-links' === $setting['type'] ) {
|
|
|
|
foreach ( $options[ $option_id ] as $key => $value ) {
|
|
|
|
foreach ( $value as $ckey => $cvalue ) {
|
|
|
|
$id = $option_id . '_' . $ckey . '_' . $key;
|
|
$_string = icl_t( 'Theme Options', $id, $cvalue );
|
|
|
|
if ( ! empty( $_string ) ) {
|
|
|
|
$options[ $option_id ][ $key ][ $ckey ] = $_string;
|
|
}
|
|
}
|
|
}
|
|
|
|
// All other acceptable option types.
|
|
} elseif ( $option_id === $setting['id'] && in_array( $setting['type'], apply_filters( 'ot_wpml_option_types', array( 'text', 'textarea', 'textarea-simple' ) ), true ) ) {
|
|
|
|
$_string = icl_t( 'Theme Options', $option_id, $options[ $option_id ] );
|
|
|
|
if ( ! empty( $_string ) ) {
|
|
|
|
$options[ $option_id ] = $_string;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return $options[ $option_id ];
|
|
}
|
|
}
|
|
|
|
if ( ! function_exists( 'ot_load_dynamic_css' ) ) {
|
|
|
|
/**
|
|
* Enqueue the dynamic CSS.
|
|
*
|
|
* @access public
|
|
* @since 2.0
|
|
*/
|
|
function ot_load_dynamic_css() {
|
|
|
|
// Don't load in the admin.
|
|
if ( is_admin() ) {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Filter whether or not to enqueue a `dynamic.css` file at the theme level.
|
|
*
|
|
* By filtering this to `false` OptionTree will not attempt to enqueue any CSS files.
|
|
*
|
|
* Example: add_filter( 'ot_load_dynamic_css', '__return_false' );
|
|
*
|
|
* @since 2.5.5
|
|
*
|
|
* @param bool $load_dynamic_css Default is `true`.
|
|
* @return bool
|
|
*/
|
|
if ( false === (bool) apply_filters( 'ot_load_dynamic_css', true ) ) {
|
|
return;
|
|
}
|
|
|
|
// Grab a copy of the paths.
|
|
$ot_css_file_paths = get_option( 'ot_css_file_paths', array() );
|
|
if ( is_multisite() ) {
|
|
$ot_css_file_paths = get_blog_option( get_current_blog_id(), 'ot_css_file_paths', $ot_css_file_paths );
|
|
}
|
|
|
|
if ( ! empty( $ot_css_file_paths ) ) {
|
|
|
|
$last_css = '';
|
|
|
|
// Loop through paths.
|
|
foreach ( $ot_css_file_paths as $key => $path ) {
|
|
|
|
if ( '' !== $path && file_exists( $path ) ) {
|
|
|
|
$parts = explode( '/wp-content', $path );
|
|
|
|
if ( isset( $parts[1] ) ) {
|
|
|
|
$sub_parts = explode( '/', $parts[1] );
|
|
|
|
if ( isset( $sub_parts[1] ) && isset( $sub_parts[2] ) ) {
|
|
if ( 'themes' !== $sub_parts[1] && get_stylesheet() !== $sub_parts[2] ) {
|
|
continue;
|
|
}
|
|
}
|
|
|
|
$css = set_url_scheme( WP_CONTENT_URL ) . $parts[1];
|
|
|
|
if ( $last_css !== $css ) {
|
|
|
|
// Enqueue filtered file.
|
|
wp_enqueue_style( 'ot-dynamic-' . $key, $css, false, OT_VERSION );
|
|
|
|
$last_css = $css;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
if ( ! function_exists( 'ot_load_google_fonts_css' ) ) {
|
|
|
|
/**
|
|
* Enqueue the Google Fonts CSS.
|
|
*
|
|
* @access public
|
|
* @since 2.5.0
|
|
*/
|
|
function ot_load_google_fonts_css() {
|
|
|
|
/* don't load in the admin */
|
|
if ( is_admin() ) {
|
|
return;
|
|
}
|
|
|
|
$ot_google_fonts = get_theme_mod( 'ot_google_fonts', array() );
|
|
$ot_set_google_fonts = get_theme_mod( 'ot_set_google_fonts', array() );
|
|
$families = array();
|
|
$subsets = array();
|
|
$append = '';
|
|
|
|
if ( ! empty( $ot_set_google_fonts ) ) {
|
|
|
|
foreach ( $ot_set_google_fonts as $id => $fonts ) {
|
|
|
|
foreach ( $fonts as $font ) {
|
|
|
|
// Can't find the font, bail!
|
|
if ( ! isset( $ot_google_fonts[ $font['family'] ]['family'] ) ) {
|
|
continue;
|
|
}
|
|
|
|
// Set variants & subsets.
|
|
if ( ! empty( $font['variants'] ) && is_array( $font['variants'] ) ) {
|
|
|
|
// Variants string.
|
|
$variants = ':' . implode( ',', $font['variants'] );
|
|
|
|
// Add subsets to array.
|
|
if ( ! empty( $font['subsets'] ) && is_array( $font['subsets'] ) ) {
|
|
foreach ( $font['subsets'] as $subset ) {
|
|
$subsets[] = $subset;
|
|
}
|
|
}
|
|
}
|
|
|
|
// Add family & variants to array.
|
|
if ( isset( $variants ) ) {
|
|
$families[] = str_replace( ' ', '+', $ot_google_fonts[ $font['family'] ]['family'] ) . $variants;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if ( ! empty( $families ) ) {
|
|
|
|
$families = array_unique( $families );
|
|
|
|
// Append all subsets to the path, unless the only subset is latin.
|
|
if ( ! empty( $subsets ) ) {
|
|
$subsets = implode( ',', array_unique( $subsets ) );
|
|
if ( 'latin' !== $subsets ) {
|
|
$append = '&subset=' . $subsets;
|
|
}
|
|
}
|
|
|
|
wp_enqueue_style( 'ot-google-fonts', esc_url( '//fonts.googleapis.com/css?family=' . implode( '%7C', $families ) ) . $append, false, null ); // phpcs:ignore
|
|
}
|
|
}
|
|
}
|
|
|
|
if ( ! function_exists( 'ot_register_theme_options_admin_bar_menu' ) ) {
|
|
|
|
/**
|
|
* Registers the Theme Option page link for the admin bar.
|
|
*
|
|
* @access public
|
|
* @since 2.1
|
|
*
|
|
* @param object $wp_admin_bar The WP_Admin_Bar object.
|
|
*/
|
|
function ot_register_theme_options_admin_bar_menu( $wp_admin_bar ) {
|
|
|
|
if ( ! current_user_can( apply_filters( 'ot_theme_options_capability', 'edit_theme_options' ) ) || ! is_admin_bar_showing() ) {
|
|
return;
|
|
}
|
|
|
|
$wp_admin_bar->add_node(
|
|
array(
|
|
'parent' => 'appearance',
|
|
'id' => apply_filters( 'ot_theme_options_menu_slug', 'ot-theme-options' ),
|
|
'title' => apply_filters( 'ot_theme_options_page_title', __( 'Theme Options', 'hueman' ) ),
|
|
'href' => admin_url( apply_filters( 'ot_theme_options_parent_slug', 'themes.php' ) . '?page=' . apply_filters( 'ot_theme_options_menu_slug', 'ot-theme-options' ) ),
|
|
)
|
|
);
|
|
}
|
|
}
|