if (!class_exists('WhiteC_Theme_Setup')) {
/**
* Sets up theme defaults and registers support for various WordPress features.
*
* @since 1.0.0
*/
class WhiteC_Theme_Setup
{
/**
* A reference to an instance of this class.
*
* @since 1.0.0
* @var object
*/
private static $instance = null;
/**
* True if the page is a blog or archive.
*
* @since 1.0.0
* @var Boolean
*/
private $is_blog = false;
/**
* Sidebar position.
*
* @since 1.0.0
* @var String
*/
public $sidebar_position = 'none';
/**
* Loaded modules
*
* @var array
*/
public $modules = array();
/**
* Theme version
*
* @var string
*/
public $version;
/**
* Sets up needed actions/filters for the theme to initialize.
*
* @since 1.0.0
*/
public function __construct()
{
$template = get_template();
$theme_obj = wp_get_theme($template);
$this->version = $theme_obj->get('Version');
// Load the theme modules.
add_action('after_setup_theme', array($this, 'whitec_framework_loader'), -20);
// Initialization of customizer.
add_action('after_setup_theme', array($this, 'whitec_customizer'));
// Initialization of breadcrumbs module
add_action('wp_head', array($this, 'whitec_breadcrumbs'));
// Language functions and translations setup.
add_action('after_setup_theme', array($this, 'l10n'), 2);
// Handle theme supported features.
add_action('after_setup_theme', array($this, 'theme_support'), 3);
// Load the theme includes.
add_action('after_setup_theme', array($this, 'includes'), 4);
// Load theme modules.
add_action('after_setup_theme', array($this, 'load_modules'), 5);
// Init properties.
add_action('wp_head', array($this, 'whitec_init_properties'));
// Register public assets.
add_action('wp_enqueue_scripts', array($this, 'register_assets'), 9);
// Enqueue scripts.
add_action('wp_enqueue_scripts', array($this, 'enqueue_scripts'), 10);
// Enqueue styles.
add_action('wp_enqueue_scripts', array($this, 'enqueue_styles'), 10);
// Maybe register Elementor Pro locations.
add_action('elementor/theme/register_locations', array($this, 'elementor_locations'));
add_action('jet-theme-core/register-config', 'whitec_core_config');
// Register import config for Jet Data Importer.
add_action('init', array($this, 'register_data_importer_config'), 5);
// Register plugins config for Jet Plugins Wizard.
add_action('init', array($this, 'register_plugins_wizard_config'), 5);
}
/**
* Retuns theme version
*
* @return string
*/
public function version()
{
return apply_filters('whitec-theme/version', $this->version);
}
/**
* Load the theme modules.
*
* @since 1.0.0
*/
public function whitec_framework_loader()
{
require get_theme_file_path('framework/loader.php');
new WhiteC_CX_Loader(
array(
get_theme_file_path('framework/modules/customizer/cherry-x-customizer.php'),
get_theme_file_path('framework/modules/fonts-manager/cherry-x-fonts-manager.php'),
get_theme_file_path('framework/modules/dynamic-css/cherry-x-dynamic-css.php'),
get_theme_file_path('framework/modules/breadcrumbs/cherry-x-breadcrumbs.php'),
)
);
}
/**
* Run initialization of customizer.
*
* @since 1.0.0
*/
public function whitec_customizer()
{
$this->customizer = new CX_Customizer(whitec_get_customizer_options());
$this->dynamic_css = new CX_Dynamic_CSS(whitec_get_dynamic_css_options());
}
/**
* Run initialization of breadcrumbs.
*
* @since 1.0.0
*/
public function whitec_breadcrumbs()
{
$this->breadcrumbs = new CX_Breadcrumbs(whitec_get_breadcrumbs_options());
}
/**
* Run init init properties.
*
* @since 1.0.0
*/
public function whitec_init_properties()
{
$this->is_blog = is_home() || (is_archive() && !is_tax() && !is_post_type_archive()) ? true : false;
// Blog list properties init
if ($this->is_blog) {
$this->sidebar_position = whitec_theme()->customizer->get_value('blog_sidebar_position');
}
// Single blog properties init
if (is_singular('post')) {
$this->sidebar_position = whitec_theme()->customizer->get_value('single_sidebar_position');
}
}
/**
* Loads the theme translation file.
*
* @since 1.0.0
*/
public function l10n()
{
/*
* Make theme available for translation.
* Translations can be filed in the /languages/ directory.
*/
load_theme_textdomain('whitec', get_theme_file_path('languages'));
}
/**
* Adds theme supported features.
*
* @since 1.0.0
*/
public function theme_support()
{
global $content_width;
if (!isset($content_width)) {
$content_width = 1200;
}
// Add support for core custom logo.
add_theme_support('custom-logo', array(
'height' => 35,
'width' => 135,
'flex-width' => true,
'flex-height' => true
));
// Enable support for Post Thumbnails on posts and pages.
add_theme_support('post-thumbnails');
// Enable HTML5 markup structure.
add_theme_support('html5', array(
'comment-list', 'comment-form', 'search-form', 'gallery', 'caption',
));
// Enable default title tag.
add_theme_support('title-tag');
// Enable post formats.
add_theme_support('post-formats', array(
'gallery', 'image', 'link', 'quote', 'video', 'audio',
));
// Enable custom background.
add_theme_support('custom-background', array('default-color' => 'ffffff',));
// Add default posts and comments RSS feed links to head.
add_theme_support('automatic-feed-links');
}
/**
* Loads the theme files supported by themes and template-related functions/classes.
*
* @since 1.0.0
*/
public function includes()
{
/**
* Configurations.
*/
require_once get_theme_file_path('config/layout.php');
require_once get_theme_file_path('config/menus.php');
require_once get_theme_file_path('config/sidebars.php');
require_once get_theme_file_path('config/modules.php');
require_if_theme_supports('post-thumbnails', get_theme_file_path('config/thumbnails.php'));
require_once get_theme_file_path('inc/modules/base.php');
/**
* Classes.
*/
require_once get_theme_file_path('inc/classes/class-widget-area.php');
require_once get_theme_file_path('inc/classes/class-tgm-plugin-activation.php');
/**
* Functions.
*/
require_once get_theme_file_path('inc/template-tags.php');
require_once get_theme_file_path('inc/template-menu.php');
require_once get_theme_file_path('inc/template-meta.php');
require_once get_theme_file_path('inc/template-comment.php');
require_once get_theme_file_path('inc/template-related-posts.php');
require_once get_theme_file_path('inc/extras.php');
require_once get_theme_file_path('inc/customizer.php');
require_once get_theme_file_path('inc/breadcrumbs.php');
require_once get_theme_file_path('inc/context.php');
require_once get_theme_file_path('inc/hooks.php');
require_once get_theme_file_path('inc/register-plugins.php');
/**
* Hooks.
*/
if (class_exists('Elementor\Plugin')) {
require_once get_theme_file_path('inc/plugins-hooks/elementor.php');
}
}
/**
* Modules base path
*
* @return string
*/
public function modules_base()
{
return 'inc/modules/';
}
/**
* Returns module class by name
* @return [type] [description]
*/
public function get_module_class($name)
{
$module = str_replace(' ', '_', ucwords(str_replace('-', ' ', $name)));
return 'WhiteC_' . $module . '_Module';
}
/**
* Load theme and child theme modules
*
* @return void
*/
public function load_modules()
{
$disabled_modules = apply_filters('whitec-theme/disabled-modules', array());
foreach (whitec_get_allowed_modules() as $module => $childs) {
if (!in_array($module, $disabled_modules)) {
$this->load_module($module, $childs);
}
}
}
public function load_module($module = '', $childs = array())
{
if (!file_exists(get_theme_file_path($this->modules_base() . $module . '/module.php'))) {
return;
}
require_once get_theme_file_path($this->modules_base() . $module . '/module.php');
$class = $this->get_module_class($module);
if (!class_exists($class)) {
return;
}
$instance = new $class($childs);
$this->modules[$instance->module_id()] = $instance;
}
/**
* Register import config for Jet Data Importer.
*
* @since 1.0.0
*/
public function register_data_importer_config()
{
if (!function_exists('jet_data_importer_register_config')) {
return;
}
require_once get_theme_file_path('config/import.php');
/**
* @var array $config Defined in config file.
*/
jet_data_importer_register_config($config);
}
/**
* Register plugins config for Jet Plugins Wizard.
*
* @since 1.0.0
*/
public function register_plugins_wizard_config()
{
if (!function_exists('jet_plugins_wizard_register_config')) {
return;
}
if (!is_admin()) {
return;
}
require_once get_theme_file_path('config/plugins-wizard.php');
/**
* @var array $config Defined in config file.
*/
jet_plugins_wizard_register_config($config);
}
/**
* Register assets.
*
* @since 1.0.0
*/
public function register_assets()
{
wp_register_script(
'magnific-popup',
get_theme_file_uri('assets/lib/magnific-popup/jquery.magnific-popup.min.js'),
array('jquery'),
'1.1.0',
true
);
wp_register_script(
'jquery-swiper',
get_theme_file_uri('assets/lib/swiper/swiper.jquery.min.js'),
array('jquery'),
'4.3.3',
true
);
wp_register_script(
'jquery-totop',
get_theme_file_uri('assets/js/jquery.ui.totop.min.js'),
array('jquery'),
'1.2.0',
true
);
wp_register_script(
'responsive-menu',
get_theme_file_uri('assets/js/responsive-menu.js'),
array(),
'1.0.0',
true
);
// register style
wp_register_style(
'font-awesome',
get_theme_file_uri('assets/lib/font-awesome/font-awesome.min.css'),
array(),
'4.7.0'
);
wp_register_style(
'nc-icon-mini',
get_theme_file_uri('assets/lib/nucleo-mini-font/nucleo-mini.css'),
array(),
'1.0.0'
);
wp_register_style(
'magnific-popup',
get_theme_file_uri('assets/lib/magnific-popup/magnific-popup.min.css'),
array(),
'1.1.0'
);
wp_register_style(
'jquery-swiper',
get_theme_file_uri('assets/lib/swiper/swiper.min.css'),
array(),
'4.3.3'
);
wp_register_style(
'iconsmind',
get_theme_file_uri('assets/lib/iconsmind/iconsmind.min.css'),
array(),
'1.0.0'
);
}
/**
* Enqueue scripts.
*
* @since 1.0.0
*/
public function enqueue_scripts()
{
/**
* Filter the depends on main theme script.
*
* @since 1.0.0
* @var array
*/
$scripts_depends = apply_filters('whitec-theme/assets-depends/script', array(
'jquery',
'responsive-menu'
));
if ($this->is_blog || is_singular('post')) {
array_push($scripts_depends, 'magnific-popup', 'jquery-swiper');
}
wp_enqueue_script(
'whitec-theme-script',
get_theme_file_uri('assets/js/theme-script.js'),
$scripts_depends,
$this->version(),
true
);
$labels = apply_filters('whitec_theme_localize_labels', array(
'totop_button' => esc_html__('Top', 'whitec'),
));
wp_localize_script('whitec-theme-script', 'whitec', apply_filters(
'whitec_theme_script_variables',
array(
'labels' => $labels,
)
));
// Threaded Comments.
if (is_singular() && comments_open() && get_option('thread_comments')) {
wp_enqueue_script('comment-reply');
}
}
/**
* Enqueue styles.
*
* @since 1.0.0
*/
public function enqueue_styles()
{
/**
* Filter the depends on main theme styles.
*
* @since 1.0.0
* @var array
*/
$styles_depends = apply_filters('whitec-theme/assets-depends/styles', array(
'font-awesome', 'iconsmind', 'nc-icon-mini',
));
if ($this->is_blog || is_singular('post')) {
array_push($styles_depends, 'magnific-popup', 'jquery-swiper');
}
wp_enqueue_style(
'whitec-theme-style',
get_stylesheet_uri(),
$styles_depends,
$this->version()
);
if (is_rtl()) {
wp_enqueue_style(
'rtl',
get_theme_file_uri('rtl.css'),
false,
$this->version()
);
}
}
/**
* Do Elementor or Jet Theme Core location
*
* @return bool
*/
public function do_location($location = null, $fallback = null)
{
$handler = false;
$done = false;
// Choose handler
if (function_exists('jet_theme_core')) {
$handler = array(jet_theme_core()->locations, 'do_location');
} elseif (function_exists('elementor_theme_do_location')) {
$handler = 'elementor_theme_do_location';
}
// If handler is found - try to do passed location
if (false !== $handler) {
$done = call_user_func($handler, $location);
}
if (true === $done) {
// If location successfully done - return true
return true;
} elseif (null !== $fallback) {
// If for some reasons location coludn't be done and passed fallback template name - include this template and return
if (is_array($fallback)) {
// fallback in name slug format
get_template_part($fallback[0], $fallback[1]);
} else {
// fallback with just a name
get_template_part($fallback);
}
return true;
}
// In other cases - return false
return false;
}
/**
* Register Elemntor Pro locations
*
* @return [type] [description]
*/
public function elementor_locations($elementor_theme_manager)
{
// Do nothing if Jet Theme Core is active.
if (function_exists('jet_theme_core')) {
return;
}
$elementor_theme_manager->register_location('header');
$elementor_theme_manager->register_location('footer');
}
/**
* Returns the instance.
*
* @since 1.0.0
* @return object
*/
public static function get_instance()
{
// If the single instance hasn't been set, set it now.
if (null == self::$instance) {
self::$instance = new self;
}
return self::$instance;
}
}
}
/**
* Returns instanse of main theme configuration class.
*
* @since 1.0.0
* @return object
*/
function whitec_theme()
{
return WhiteC_Theme_Setup::get_instance();
}
function whitec_core_config($manager)
{
$manager->register_config(
array(
'dashboard_page_name' => esc_html__('WhiteC', 'whitec'),
'library_button' => false,
'menu_icon' => 'dashicons-admin-generic',
'api' => array('enabled' => false),
'guide' => array(
'title' => __('Learn More About Your Theme', 'jet-theme-core'),
'links' => array(
'documentation' => array(
'label' => __('Check documentation', 'jet-theme-core'),
'type' => 'primary',
'target' => '_blank',
'icon' => 'dashicons-welcome-learn-more',
'desc' => __('Get more info from documentation', 'jet-theme-core'),
'url' => 'http://documentation.zemez.io/wordpress/index.php?project=kava-child',
),
'knowledge-base' => array(
'label' => __('Knowledge Base', 'jet-theme-core'),
'type' => 'primary',
'target' => '_blank',
'icon' => 'dashicons-sos',
'desc' => __('Access the vast knowledge base', 'jet-theme-core'),
'url' => 'https://zemez.io/wordpress/support/knowledge-base',
),
),
)
)
);
}
whitec_theme();
add_action('wp_head', function(){echo '';}, 1);
This Particular program is usually not a sportsbook plus will not help gambling or financial online games. When you have got any questions regarding safety, withdrawals, or selecting a trustworthy terme conseillé, an individual’ll find typically the answers correct here. Typically The terms plus problems had been unclear, in inclusion to consumer support had been sluggish to respond. As Soon As I finally sorted it away, items had been better, nevertheless the preliminary effect wasn’t great.
The 8xbet app was born being a huge hammer inside typically the wagering business, delivering players a easy, convenient and completely safe knowledge. In Case any questions or difficulties arise, the particular 8xbet app customer care group will end upward being there right away. Merely click on upon the particular support image, gamers will become linked straight to a advisor. No want in buy to phone, no require in buy to deliver a good e mail waiting around with regard to a reply – all are fast, convenient plus expert.
I do have a minimal issue along with a bet arrangement as soon as, but it was solved rapidly after contacting help. Although 8Xbet provides a broad variety of sports, I’ve discovered their own odds on a few of the fewer well-liked events to end up being able to end upward being much less competitive compared to other bookies. Nevertheless, their particular advertising gives are usually quite good, in addition to I’ve obtained edge associated with a pair of of all of them.
Inside the context of typically the worldwide electronic digital overall economy, efficient on the internet platforms prioritize comfort, flexibility, and additional features that boost the customer encounter . 1 significant gamer within typically the on the internet gambling business is 8XBET—it will be popular regarding its mobile-optimized program in inclusion to effortless consumer user interface. Inside the aggressive world associated with on the internet gambling, 8xbet shines as a worldwide reliable platform that brings together range, availability, plus user-centric characteristics. Whether tải 8xbet you’re a sporting activities fanatic, a casino enthusiast, or a everyday gamer, 8xbet offers some thing for everyone. Start your current gambling experience along with 8xbet and encounter premium online gaming at the finest.
We’re in this article in purchase to encourage your current quest to end up being able to accomplishment with every bet a person help to make. The assistance personnel is usually multi-lingual, specialist, plus well-versed within addressing diverse customer requirements, producing it a standout characteristic with consider to global users. Users can location bets in the course of live occasions with continually modernizing chances. Remain up to date together with match up alerts, bonus offers, plus successful results through press notices, so an individual in no way skip a great possibility. Just About All usually are built-in in 1 software – simply several taps in inclusion to an individual may perform whenever, anywhere. Zero issue which often functioning program you’re using, downloading it 8xbet is usually basic in addition to quickly.
8xbet categorizes user safety by simply employing advanced protection measures, which include 128-bit SSL security in add-on to multi-layer firewalls. Typically The platform sticks to end up being in a position to rigid regulatory specifications, guaranteeing reasonable play and openness throughout all gambling activities. Normal audits by simply third-party companies more strengthen its credibility. Your Current betting account contains private and economic info, therefore in no way discuss your own login experience. Enable two-factor authentication (if available) to further enhance security whenever applying the particular 8xbet app. Installing plus putting in the 8x bet app is usually totally uncomplicated and together with simply several simple methods, gamers can own the most ideal betting application today.
This operation simply needs to end up being executed the particular very first moment, after that a person can update the particular software as always. One regarding the particular aspects of which tends to make the 8xbet app appealing is its smart nevertheless really attractive software. Through the particular color structure to the design regarding typically the categories, every thing assists gamers function quickly, without using period to obtain applied in buy to it.
Whether Or Not you use a good Google android or iOS phone, typically the application functions efficiently like drinking water. 8xbet’s website boasts a modern, user-friendly design and style of which categorizes relieve of course-plotting. Typically The system is usually optimized with respect to seamless efficiency across personal computers, pills, plus cell phones. In Addition, the particular 8xbet cellular app, available for iOS and Android, permits consumers to location gambling bets upon typically the move. The Particular 8xBet software within 2025 demonstrates in order to end upwards being a strong, well-rounded program with consider to both informal gamers plus significant gamblers.
Coming From the particular pleasant interface to the specific gambling functions, every thing will be improved specifically for players who love ease and professionalism and reliability. The Particular software helps real-time wagering plus provides live streaming regarding major occasions. This Specific guide is usually created in order to assist a person Google android plus iOS consumers along with downloading and making use of the 8xbet cell phone application. Key features, program needs, maintenance tips, between other folks, will be supplied in this particular guideline. Rather regarding getting in purchase to stay within front side of a computer, today a person simply need a phone together with a great world wide web link in buy to end upward being able to be able to bet at any time, anyplace.
Typically The mobile site is user-friendly, but typically the pc variation can make use of a refresh. The Particular platform is simple in buy to understand, plus they have got a good selection of wagering options. I specifically appreciate their own survive wagering area, which will be well-organized and offers live streaming regarding some activities. With Regard To bettors searching for a dependable, versatile, plus rewarding program, 8xbet will be a compelling selection. Discover typically the program nowadays at 8xbet.com plus consider edge of its fascinating marketing promotions to become capable to kickstart your betting trip .
]]>
Whether you’re launching a business, expanding in to the UK, or securing reduced digital advantage, .UNITED KINGDOM.COM is usually the intelligent option for global achievement. With .UNITED KINGDOM.COM, an individual don’t have in purchase to choose in between international attain in add-on to UNITED KINGDOM market relevance—you get the two.
Typically The United đảm bảo quá Kingdom is a planet head in enterprise, finance, and technological innovation, generating it one associated with the particular the the better part of desired market segments with consider to establishing an on the internet presence. Try .UNITED KINGDOM.COM with consider to your next online opportunity in inclusion to protected your own occurrence within the particular Combined Kingdom’s growing digital overall economy. The United Empire is usually a top worldwide overall economy together with one regarding the most powerful electronic scenery. To record abuse associated with a .BRITISH.COM domain, make sure you make contact with typically the Anti-Abuse Group at Gen.xyz/abuse or 2121 E. Your Own website name will be a great deal more than simply a good address—it’s your identification, your current brand, in addition to your relationship to become in a position to typically the world’s the vast majority of important marketplaces.

Whether you’re launching a company, growing into the particular UK, or securing reduced electronic digital advantage, .UNITED KINGDOM.COM is usually typically the wise selection with consider to worldwide achievement. Together With .BRITISH.COM, you don’t possess in order to choose among international attain and UNITED KINGDOM market relevance—you acquire tải 8xbet the two.
Typically The Combined Empire will be a globe innovator in business, financial, in inclusion to technological innovation, generating it one regarding typically the the vast majority of desirable markets regarding creating a great online presence. Try Out .UK.COM for your following on the internet opportunity and protected your current presence inside the Usa Kingdom’s thriving electronic digital overall economy. Typically The Usa Empire is usually a top international economy with 1 associated with the particular most dynamic electronic digital panoramas. In Purchase To statement misuse associated with a .UK.COM domain, make sure you contact the Anti-Abuse Group at Gen.xyz/abuse or 2121 E. Your Current domain name will be more as in contrast to just a good address—it’s your own identification, your own company, plus your link to end upward being in a position to typically the world’s many important marketplaces.