mirror of
https://github.com/WordPress/WordPress.git
synced 2025-02-26 17:08:38 +00:00
Let Gutenberg shine with this simple, fast, and powerful theme. Initial development occurred on GitHub. See: https://github.com/WordPress/twentynineteen Props allancole, karmatosed, kjellr, yingling017, mrasharirfan, milana_cap, fabiankaegy, westonruter, aaronjorbin, netweb, b-07, khleomix, blowery, dereksmart, jasmussen, audrasjb, nielslange, mmaumio, dimadin, joyously, anevins12, peterwilsoncc, dannycooper, icaleb, siriokun, technosiren, travel_girl, azchughtai, ianbelanger, nadim1992, ismailelkorchi, nativeinside, chetan200891, icaleb, grapplerulrich, ocean90, joshfeck, frankew, abdulwahab610, mendezcode, eliorivero, melchoyce, joen, laurelfulford, mdawaffe, kraftbj, dsmart. Built from https://develop.svn.wordpress.org/branches/5.0@43842 git-svn-id: http://core.svn.wordpress.org/branches/5.0@43671 1a063a9b-81f0-0310-95a4-ce76da25c4cd
242 lines
7.3 KiB
PHP
242 lines
7.3 KiB
PHP
<?php
|
|
/**
|
|
* Twenty Nineteen functions and definitions
|
|
*
|
|
* @link https://developer.wordpress.org/themes/basics/theme-functions/
|
|
*
|
|
* @package WordPress
|
|
* @subpackage Twenty_Nineteen
|
|
* @since 1.0.0
|
|
*/
|
|
|
|
if ( ! function_exists( 'twentynineteen_setup' ) ) :
|
|
/**
|
|
* Sets up theme defaults and registers support for various WordPress features.
|
|
*
|
|
* Note that this function is hooked into the after_setup_theme hook, which
|
|
* runs before the init hook. The init hook is too late for some features, such
|
|
* as indicating support for post thumbnails.
|
|
*/
|
|
function twentynineteen_setup() {
|
|
/*
|
|
* Make theme available for translation.
|
|
* Translations can be filed in the /languages/ directory.
|
|
* If you're building a theme based on Twenty Nineteen, use a find and replace
|
|
* to change 'twentynineteen' to the name of your theme in all the template files.
|
|
*/
|
|
load_theme_textdomain( 'twentynineteen', get_template_directory() . '/languages' );
|
|
|
|
// Add default posts and comments RSS feed links to head.
|
|
add_theme_support( 'automatic-feed-links' );
|
|
|
|
/*
|
|
* Let WordPress manage the document title.
|
|
* By adding theme support, we declare that this theme does not use a
|
|
* hard-coded <title> tag in the document head, and expect WordPress to
|
|
* provide it for us.
|
|
*/
|
|
add_theme_support( 'title-tag' );
|
|
|
|
/*
|
|
* 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( 1568, 9999 );
|
|
|
|
// This theme uses wp_nav_menu() in two locations.
|
|
register_nav_menus(
|
|
array(
|
|
'menu-1' => esc_html__( 'Primary', 'twentynineteen' ),
|
|
'social' => __( 'Social Links Menu', 'twentynineteen' ),
|
|
)
|
|
);
|
|
|
|
/*
|
|
* Switch default core 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',
|
|
)
|
|
);
|
|
|
|
/**
|
|
* Add support for core custom logo.
|
|
*
|
|
* @link https://codex.wordpress.org/Theme_Logo
|
|
*/
|
|
add_theme_support(
|
|
'custom-logo',
|
|
array(
|
|
'height' => 190,
|
|
'width' => 190,
|
|
'flex-width' => false,
|
|
'flex-height' => false,
|
|
)
|
|
);
|
|
|
|
// Add support for Block Styles
|
|
add_theme_support( 'wp-block-styles' );
|
|
|
|
// Add support for full and wide align images.
|
|
add_theme_support( 'align-wide' );
|
|
|
|
// Add support for editor styles
|
|
add_theme_support( 'editor-styles' );
|
|
|
|
// Enqueue editor styles
|
|
add_editor_style( 'style-editor.css' );
|
|
|
|
// Add custom color to the editor color palette
|
|
add_theme_support(
|
|
'editor-color-palette',
|
|
array(
|
|
array(
|
|
'name' => esc_html__( 'Primary Color', 'twentynineteen' ),
|
|
'slug' => 'primary',
|
|
'color' => twentynineteen_hsl_hex( absint( get_theme_mod( 'colorscheme_hue', 199 ) ), 100, 33 ),
|
|
),
|
|
)
|
|
);
|
|
|
|
}
|
|
endif;
|
|
add_action( 'after_setup_theme', 'twentynineteen_setup' );
|
|
|
|
/**
|
|
* Register widget area.
|
|
*
|
|
* @link https://developer.wordpress.org/themes/functionality/sidebars/#registering-a-sidebar
|
|
*/
|
|
function twentynineteen_widgets_init() {
|
|
|
|
register_sidebar(
|
|
array(
|
|
'name' => __( 'Footer 1', 'twentynineteen' ),
|
|
'id' => 'sidebar-1',
|
|
'description' => __( 'Add widgets here to appear in your footer.', 'twentynineteen' ),
|
|
'before_widget' => '<section id="%1$s" class="widget %2$s">',
|
|
'after_widget' => '</section>',
|
|
'before_title' => '<h2 class="widget-title">',
|
|
'after_title' => '</h2>',
|
|
)
|
|
);
|
|
|
|
}
|
|
add_action( 'widgets_init', 'twentynineteen_widgets_init' );
|
|
|
|
/**
|
|
* 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 twentynineteen_content_width() {
|
|
// This variable is intended to be overruled from themes.
|
|
// Open WPCS issue: {@link https://github.com/WordPress-Coding-Standards/WordPress-Coding-Standards/issues/1043}.
|
|
// phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedVariableFound
|
|
$GLOBALS['content_width'] = apply_filters( 'twentynineteen_content_width', 640 );
|
|
}
|
|
add_action( 'after_setup_theme', 'twentynineteen_content_width', 0 );
|
|
|
|
/**
|
|
* Enqueue scripts and styles.
|
|
*/
|
|
function twentynineteen_scripts() {
|
|
wp_enqueue_style( 'twentynineteen-style', get_stylesheet_uri() );
|
|
|
|
wp_style_add_data( 'twentynineteen-style', 'rtl', 'replace' );
|
|
|
|
wp_enqueue_script( 'twentynineteen-skip-link-focus-fix', get_template_directory_uri() . '/js/skip-link-focus-fix.js', array(), '20151215', true );
|
|
|
|
if ( has_nav_menu( 'menu-1' ) ) {
|
|
wp_enqueue_script( 'twentynineteen-touch-navigation', get_theme_file_uri( '/js/touch-navigation.js' ), array(), '1.0', true );
|
|
$twentynineteen_l10n['expand'] = __( 'Expand child menu', 'twentynineteen' );
|
|
$twentynineteen_l10n['collapse'] = __( 'Collapse child menu', 'twentynineteen' );
|
|
}
|
|
|
|
wp_localize_script( 'twentynineteen-skip-link-focus-fix', 'twentynineteenScreenReaderText', $twentynineteen_l10n );
|
|
|
|
wp_enqueue_style( 'twentynineteen-print-style', get_template_directory_uri() . '/print.css', array(), wp_get_theme()->get( 'Version' ), 'print' );
|
|
|
|
if ( is_singular() && twentynineteen_can_show_post_thumbnail() ) {
|
|
wp_add_inline_style( 'twentynineteen-style', twentynineteen_header_featured_image_css() );
|
|
}
|
|
|
|
if ( is_singular() && comments_open() && get_option( 'thread_comments' ) ) {
|
|
wp_enqueue_script( 'comment-reply' );
|
|
}
|
|
}
|
|
add_action( 'wp_enqueue_scripts', 'twentynineteen_scripts' );
|
|
|
|
/**
|
|
* Enqueue supplemental block editor styles
|
|
*/
|
|
function twentynineteen_editor_frame_styles() {
|
|
|
|
// Include color patterns
|
|
require_once( get_parent_theme_file_path( '/inc/color-patterns.php' ) );
|
|
|
|
wp_enqueue_style( 'twentynineteen-editor-frame-styles', get_theme_file_uri( '/style-editor-frame.css' ), false, '1.0', 'all' );
|
|
wp_add_inline_style( 'twentynineteen-editor-frame-styles', twentynineteen_custom_colors_css() );
|
|
}
|
|
add_action( 'enqueue_block_editor_assets', 'twentynineteen_editor_frame_styles' );
|
|
|
|
/**
|
|
* Display custom color CSS in customizer and on frontend.
|
|
*/
|
|
function twentynineteen_colors_css_wrap() {
|
|
if ( 'custom' !== get_theme_mod( 'colorscheme' ) && ! is_customize_preview() ) {
|
|
return;
|
|
}
|
|
|
|
require_once( get_parent_theme_file_path( '/inc/color-patterns.php' ) );
|
|
$hue = absint( get_theme_mod( 'colorscheme_hue', 250 ) );
|
|
?>
|
|
|
|
<style type="text/css" id="custom-theme-colors" <?php echo is_customize_preview() ? 'data-hue="' . $hue . '"' : ''; ?>>
|
|
<?php echo twentynineteen_custom_colors_css(); ?>
|
|
</style>
|
|
<?php
|
|
}
|
|
add_action( 'wp_head', 'twentynineteen_colors_css_wrap' );
|
|
|
|
/**
|
|
* SVG Icons class.
|
|
*/
|
|
require get_template_directory() . '/classes/class-twentynineteen-svg-icons.php';
|
|
|
|
/**
|
|
* Custom Comment Walker template.
|
|
*/
|
|
require get_template_directory() . '/classes/class-twentynineteen-walker-comment.php';
|
|
|
|
/**
|
|
* Enhance the theme by hooking into WordPress.
|
|
*/
|
|
require get_template_directory() . '/inc/template-functions.php';
|
|
|
|
/**
|
|
* SVG Icons related functions.
|
|
*/
|
|
require get_template_directory() . '/inc/icon-functions.php';
|
|
|
|
/**
|
|
* Custom template tags for the theme.
|
|
*/
|
|
require get_template_directory() . '/inc/template-tags.php';
|
|
|
|
/**
|
|
* Customizer additions.
|
|
*/
|
|
require get_template_directory() . '/inc/customizer.php';
|