tag in the document head, and expect WordPress to
* provide it for us.
*/
add_theme_support('title-tag');
// Enable support for footer widgets.
add_theme_support('footer-widgets', 4);
// Load Footer Widget Support.
require_if_theme_supports('footer-widgets', get_template_directory() . '/inc/footer-widgets.php');
/*
* Enable support for Post Thumbnails on posts and pages.
*
* @link https://developer.wordpress.org/themes/functionality/featured-images-post-thumbnails/
*/
add_theme_support('post-thumbnails');
set_post_thumbnail_size(600, 450, true);
// Set the default content width.
$GLOBALS['content_width'] = 525;
// This theme uses wp_nav_menu() in one location.
register_nav_menus(array(
'primary' => esc_html__('Primary', 'busyness'),
'social' => esc_html__('Social', 'busyness'),
));
/*
* Switch default core markup for search form, comment form, and comments
* to output valid HTML5.
*/
add_theme_support('html5', array(
'comment-form',
'comment-list',
'gallery',
'caption',
));
// Set up the WordPress core custom background feature.
add_theme_support('custom-background', apply_filters('busyness_custom_background_args', array(
'default-color' => 'ffffff',
'default-image' => '',
)));
// This setup supports logo, site-title & site-description
add_theme_support('custom-logo', array(
'height' => 70,
'width' => 120,
'flex-height' => true,
'flex-width' => true,
'header-text' => array('site-title', 'site-description'),
));
// Add theme support for selective refresh for widgets.
add_theme_support('customize-selective-refresh-widgets');
/*
* This theme styles the visual editor to resemble the theme style,
* specifically font, colors, icons, and column width.
*/
add_editor_style(array('/assets/css/editor-style' . busyness_min() . '.css', busyness_fonts_url()));
// Gutenberg support
add_theme_support('editor-color-palette', array(
array(
'name' => esc_html__('Blue', 'busyness'),
'slug' => 'blue',
'color' => '#2c7dfa',
),
array(
'name' => esc_html__('Green', 'busyness'),
'slug' => 'green',
'color' => '#07d79c',
),
array(
'name' => esc_html__('Orange', 'busyness'),
'slug' => 'orange',
'color' => '#ff8737',
),
array(
'name' => esc_html__('Black', 'busyness'),
'slug' => 'black',
'color' => '#2f3633',
),
array(
'name' => esc_html__('Grey', 'busyness'),
'slug' => 'grey',
'color' => '#82868b',
),
));
add_theme_support('align-wide');
add_theme_support('editor-font-sizes', array(
array(
'name' => esc_html__('small', 'busyness'),
'shortName' => esc_html__('S', 'busyness'),
'size' => 12,
'slug' => 'small'
),
array(
'name' => esc_html__('regular', 'busyness'),
'shortName' => esc_html__('M', 'busyness'),
'size' => 16,
'slug' => 'regular'
),
array(
'name' => esc_html__('larger', 'busyness'),
'shortName' => esc_html__('L', 'busyness'),
'size' => 36,
'slug' => 'larger'
),
array(
'name' => esc_html__('huge', 'busyness'),
'shortName' => esc_html__('XL', 'busyness'),
'size' => 48,
'slug' => 'huge'
)
));
add_theme_support('editor-styles');
add_theme_support('wp-block-styles');
}
endif;
add_action('after_setup_theme', 'busyness_setup');
/**
* Set the content width in pixels, based on the theme's design and stylesheet.
*
* Priority 0 to make it available to lower priority callbacks.
*
* @global int $content_width
*/
function busyness_content_width()
{
$content_width = $GLOBALS['content_width'];
$sidebar_position = busyness_layout();
switch ($sidebar_position) {
case 'no-sidebar':
$content_width = 1170;
break;
case 'left-sidebar':
case 'right-sidebar':
$content_width = 819;
break;
default:
break;
}
if (! is_active_sidebar('sidebar-1')) {
$content_width = 1170;
}
/**
* Filter Busyness content width of the theme.
*
* @since Busyness 1.0.0
*
* @param int $content_width Content width in pixels.
*/
$GLOBALS['content_width'] = apply_filters('busyness_content_width', $content_width);
}
add_action('template_redirect', 'busyness_content_width', 0);
/**
* Register widget area.
*
* @link https://developer.wordpress.org/themes/functionality/sidebars/#registering-a-sidebar
*/
function busyness_widgets_init()
{
register_sidebar(array(
'name' => esc_html__('Sidebar', 'busyness'),
'id' => 'sidebar-1',
'description' => esc_html__('Add widgets here.', 'busyness'),
'before_widget' => '',
'before_title' => '
',
));
register_sidebars(4, array(
'name' => esc_html__('Optional Sidebar %d', 'busyness'),
'id' => 'optional-sidebar',
'description' => esc_html__('Add widgets here.', 'busyness'),
'before_widget' => '',
'before_title' => '',
));
}
add_action('widgets_init', 'busyness_widgets_init');
if (! function_exists('busyness_fonts_url')) :
/**
* Register Google fonts
*
* @return string Google fonts URL for the theme.
*/
function busyness_fonts_url()
{
$fonts_url = '';
$fonts = array();
$subsets = 'latin,latin-ext';
/* translators: If there are characters in your language that are not supported by Open+Sans, translate this to 'off'. Do not translate into your own language. */
if ('off' !== _x('on', 'Open Sans font: on or off', 'busyness')) {
$fonts[] = 'Open Sans:400,700';
}
/* translators: If there are characters in your language that are not supported by Lato, translate this to 'off'. Do not translate into your own language. */
if ('off' !== _x('on', 'Lato font: on or off', 'busyness')) {
$fonts[] = 'Lato:300,400,600,700,900';
}
$query_args = array(
'family' => urlencode(implode('|', $fonts)),
'subset' => urlencode($subsets),
);
if ($fonts) {
$fonts_url = add_query_arg($query_args, 'https://fonts.googleapis.com/css');
}
require_once get_theme_file_path('inc/wptt-webfont-loader.php');
$fonts_url = wptt_get_webfont_url($fonts_url);
return esc_url_raw($fonts_url);
}
endif;
/**
* Add preconnect for Google Fonts.
*
* @since Busyness 1.0.0
*
* @param array $urls URLs to print for resource hints.
* @param string $relation_type The relation type the URLs are printed.
* @return array $urls URLs to print for resource hints.
*/
function busyness_resource_hints($urls, $relation_type)
{
if (wp_style_is('busyness-fonts', 'queue') && 'preconnect' === $relation_type) {
$urls[] = array(
'href' => 'https://fonts.gstatic.com',
'crossorigin',
);
}
return $urls;
}
add_filter('wp_resource_hints', 'busyness_resource_hints', 10, 2);
/**
* Enqueue scripts and styles.
*/
function busyness_scripts()
{
$options = busyness_get_theme_options();
// Add custom fonts, used in the main stylesheet.
wp_enqueue_style('busyness-fonts', busyness_fonts_url(), array(), null);
// font-awesome
wp_enqueue_style('font-awesome', get_template_directory_uri() . '/assets/css/font-awesome' . busyness_min() . '.css');
// slick
wp_enqueue_style('slick', get_template_directory_uri() . '/assets/css/slick' . busyness_min() . '.css');
// slick theme
wp_enqueue_style('slick-theme', get_template_directory_uri() . '/assets/css/slick-theme' . busyness_min() . '.css');
// blocks
wp_enqueue_style('busyness-blocks', get_template_directory_uri() . '/assets/css/blocks' . busyness_min() . '.css');
wp_enqueue_style('busyness-style', get_stylesheet_uri(), null, date('Ymd-Gis', filemtime(get_template_directory() . '/style.css')));
// Load the colorscheme.
$color_scheme = $options['colorscheme'];
if (! in_array($color_scheme, array('default', 'custom'))) {
wp_enqueue_style('busyness-colors', get_template_directory_uri() . '/assets/css/' . esc_attr($color_scheme) . busyness_min() . '.css', array('busyness-style'), '1.0');
}
wp_enqueue_script('busyness-skip-link-focus-fix', get_template_directory_uri() . '/assets/js/skip-link-focus-fix' . busyness_min() . '.js', array(), '20160412', true);
wp_enqueue_script('busyness-navigation', get_template_directory_uri() . '/assets/js/navigation' . busyness_min() . '.js', array(), '20151215', true);
$busyness_l10n = array(
'quote' => busyness_get_svg(array('icon' => 'quote-right')),
'expand' => esc_html__('Expand child menu', 'busyness'),
'collapse' => esc_html__('Collapse child menu', 'busyness'),
'icon' => busyness_get_svg(array('icon' => 'down', 'fallback' => true)),
);
wp_localize_script('busyness-navigation', 'busyness_l10n', $busyness_l10n);
if (is_singular() && comments_open() && get_option('thread_comments')) {
wp_enqueue_script('comment-reply');
}
wp_enqueue_script('jquery-slick', get_template_directory_uri() . '/assets/js/slick' . busyness_min() . '.js', array('jquery'), '', true);
wp_enqueue_script('jquery-matchHeight', get_template_directory_uri() . '/assets/js/jquery.matchHeight' . busyness_min() . '.js', array('jquery'), '', true);
wp_enqueue_script('isotope-pkgd', get_template_directory_uri() . '/assets/js/isotope.pkgd' . busyness_min() . '.js', array('jquery'), '', true);
wp_enqueue_script('jquery-magnific-popup', get_template_directory_uri() . '/assets/js/jquery.magnific-popup' . busyness_min() . '.js', array('jquery'), '', true);
wp_enqueue_script('packery-pkgd', get_template_directory_uri() . '/assets/js/packery.pkgd' . busyness_min() . '.js', array('jquery'), '', true);
wp_enqueue_script('busyness-custom', get_template_directory_uri() . '/assets/js/custom' . busyness_min() . '.js', array('jquery'), '20151215', true);
if ('infinite' == $options['pagination_type']) {
// infinite scroll js
wp_enqueue_script('busyness-infinite-scroll', get_template_directory_uri() . '/assets/js/infinite-scroll' . busyness_min() . '.js', array('jquery'), '', true);
}
}
add_action('wp_enqueue_scripts', 'busyness_scripts');
/**
* Enqueue editor styles for Gutenberg
*
* @since Busyness 1.0.0
*/
function busyness_block_editor_styles()
{
// Block styles.
wp_enqueue_style('busyness-block-editor-style', get_theme_file_uri('/assets/css/editor-blocks' . busyness_min() . '.css'));
// Add custom fonts.
wp_enqueue_style('busyness-fonts', busyness_fonts_url(), array(), null);
}
add_action('enqueue_block_editor_assets', 'busyness_block_editor_styles');
/**
* Implement the Custom Header feature.
*/
require get_template_directory() . '/inc/custom-header.php';
/**
* Custom template tags for this theme.
*/
require get_template_directory() . '/inc/template-tags.php';
/**
* Custom functions that act independently of the theme templates.
*/
require get_template_directory() . '/inc/extras.php';
/**
* Load core file
*/
require get_template_directory() . '/inc/core.php';