fictioneer/includes/functions/_setup-theme.php

2184 lines
72 KiB
PHP
Raw Normal View History

2023-01-21 01:31:34 +01:00
<?php
2023-08-11 22:33:41 +02:00
// =============================================================================
// LEGACY CLEANUP
// =============================================================================
2023-08-11 23:51:30 +02:00
/**
* Clean up obsolete database entries
*
* @since 5.6.0
*/
2023-08-11 22:33:41 +02:00
function fictioneer_bring_out_legacy_trash() {
// Setup
$options = wp_cache_get( 'alloptions', 'options' );
2024-06-04 02:54:07 +02:00
$obsolete = ['fictioneer_disable_html_in_comments', 'fictioneer_block_subscribers_from_admin', 'fictioneer_admin_restrict_menus', 'fictioneer_admin_restrict_private_data', 'fictioneer_admin_reduce_subscriber_profile', 'fictioneer_enable_subscriber_self_delete', 'fictioneer_strip_shortcodes_for_non_administrators', 'fictioneer_restrict_media_access', 'fictioneer_subscription_enabled', 'fictioneer_patreon_badge_map', 'fictioneer_patreon_tier_as_badge', 'fictioneer_patreon_campaign_ids', 'fictioneer_patreon_campaign_id', 'fictioneer_mount_wpdiscuz_theme_styles', 'fictioneer_base_site_width', 'fictioneer_featherlight_enabled', 'fictioneer_tts_enabled', 'fictioneer_log', 'fictioneer_enable_ajax_nonce', 'fictioneer_flush_object_cache', 'fictioneer_enable_all_block_styles', 'fictioneer_light_mode_as_default', 'fictioneer_remove_wp_svg_filters', 'fictioneer_update_check_timestamp', 'fictioneer_latest_version', 'fictioneer_update_notice_timestamp', 'fictioneer_theme_status'];
2023-08-11 22:33:41 +02:00
2023-08-19 13:33:25 +02:00
// Check for most recent obsolete option...
2024-06-04 02:54:07 +02:00
if ( isset( $options['fictioneer_theme_status'] ) ) {
2023-08-19 13:33:25 +02:00
// Looping everything is not great but it only happens once!
2023-08-11 22:37:53 +02:00
foreach ( $obsolete as $trash ) {
delete_option( $trash );
}
}
2023-08-11 22:33:41 +02:00
}
2023-08-19 13:33:25 +02:00
add_action( 'admin_init', 'fictioneer_bring_out_legacy_trash' );
2023-08-11 22:33:41 +02:00
2023-01-21 01:31:34 +01:00
// =============================================================================
// THEME SETUP
// =============================================================================
/**
2023-08-11 23:51:30 +02:00
* Sets up theme defaults and registers support for various WordPress features
2023-01-21 01:31:34 +01:00
*
* @since 1.0.0
2023-01-21 01:31:34 +01:00
*/
function fictioneer_theme_setup() {
// Load translations (if any)
load_theme_textdomain( 'fictioneer', get_template_directory() . '/languages' );
// Let WordPress handle the title tag
add_theme_support( 'title-tag' );
// Activate support for featured images (thumbnails)
add_theme_support(
'post-thumbnails',
array(
'post',
'page',
'fcn_story',
'fcn_chapter',
'fcn_recommendation',
'fcn_collection'
)
);
// Register navigation menus
2024-06-12 23:47:29 +02:00
register_nav_menu( 'nav_menu', __( 'Navigation', 'fictioneer' ) );
register_nav_menu( 'footer_menu', __( 'Footer Menu', 'fictioneer' ) );
2023-01-21 01:31:34 +01:00
// Switch core markup to valid HTML5 (except 'comment-form' because WP adds novalidate for some reason)
add_theme_support(
'html5',
array(
'comment-list',
'search-form',
'gallery',
'caption',
'style',
'script'
)
);
// Add support for custom backgrounds (with custom callback)
2023-08-19 13:33:25 +02:00
add_theme_support( 'custom-background', array( 'wp-head-callback' => 'fictioneer_custom_background' ) );
2023-01-21 01:31:34 +01:00
// Add support for custom header images
add_theme_support(
'custom-header',
array(
'flex-width' => true,
'flex-height' => true,
'height' => get_theme_mod( 'header_image_height_max', 480 )
)
);
// Add support for editor styles
add_theme_support( 'editor-styles' );
add_editor_style( '/css/editor.css' );
2023-01-21 01:31:34 +01:00
// Add support for custom logo
add_theme_support(
'custom-logo',
array(
'flex-width' => true,
'width' => (int) get_theme_mod( 'header_image_height_max', 210 ) * 1.5,
'flex-height' => true,
'height' => get_theme_mod( 'header_image_height_max', 210 ),
2023-08-19 13:33:25 +02:00
'header-text' => ['site-title', 'site-description'],
2023-01-21 01:31:34 +01:00
)
);
2023-08-15 18:14:24 +02:00
// Remove block patterns
remove_theme_support( 'core-block-patterns' );
2023-08-19 13:33:25 +02:00
// Disable template editor (automatically added due to theme.json!)
remove_theme_support( 'block-templates' );
2023-08-15 18:24:14 +02:00
// Remove widget support...
if ( get_option( 'fictioneer_disable_all_widgets' ) ) {
remove_theme_support( 'widgets' );
remove_theme_support( 'widgets-block-editor' );
}
2023-01-21 01:31:34 +01:00
// Add new size for cover images used on story pages
add_image_size( 'cover', 400 );
// Add new size for cover snippets used in cards
add_image_size( 'snippet', 0, 200 );
// After update actions
2024-06-04 02:54:07 +02:00
$theme_info = fictioneer_get_theme_info();
2024-06-04 02:54:07 +02:00
if ( ( $theme_info['version'] ?? 0 ) !== FICTIONEER_VERSION ) {
$previous_version = $theme_info['version'];
$theme_info['version'] = FICTIONEER_VERSION;
2024-06-04 02:54:07 +02:00
update_option( 'fictioneer_theme_info', $theme_info, 'yes' );
2024-06-04 02:54:07 +02:00
do_action( 'fictioneer_after_update', $theme_info['version'], $previous_version );
}
2023-01-21 01:31:34 +01:00
}
add_action( 'after_setup_theme', 'fictioneer_theme_setup' );
2024-06-04 02:54:07 +02:00
/**
* Get basic theme info
*
* @since 5.19.1
*
* @return array Associative array with theme info.
*/
function fictioneer_get_theme_info() {
// Setup
$info = get_option( 'fictioneer_theme_info' ) ?: [];
// Set up if missing
if ( ! $info || ! is_array( $info ) ) {
$info = array(
'last_update_check' => current_time( 'mysql', 1 ),
'last_update_version' => '',
'last_update_nag' => current_time( 'mysql', 1 ),
'last_update_notes' => '',
'last_version_download_url' => '',
2024-06-30 04:04:47 +02:00
'setup' => 0,
2024-06-04 02:54:07 +02:00
'version' => FICTIONEER_VERSION
);
update_option( 'fictioneer_theme_info', $info, 'yes' );
}
// Merge with defaults (in case of incomplete data)
$info = array_merge(
array(
'last_update_check' => current_time( 'mysql', 1 ),
'last_update_version' => '',
'last_update_nag' => '',
'last_update_notes' => '',
'last_version_download_url' => '',
2024-06-30 04:04:47 +02:00
'setup' => 0,
2024-06-04 02:54:07 +02:00
'version' => FICTIONEER_VERSION
),
$info
);
// Return info
return $info;
}
2024-08-03 17:09:53 +02:00
// =============================================================================
// SIDEBAR
// =============================================================================
2024-06-13 00:16:16 +02:00
/**
* Registers sidebar
2024-06-13 00:16:16 +02:00
*
* @since 5.20.0
*/
function fictioneer_register_sidebar() {
register_sidebar(
array(
'name' => __( 'Fictioneer Sidebar', 'fictioneer' ),
'id' => 'fictioneer-sidebar',
2024-08-04 23:48:09 +02:00
'description' => __( 'To render this sidebar, enable it in the Customizer or insert it with the <code>[fictioneer_sidebar]</code> shortcode. It can also be rendered with the Elementor plugin.', 'fictioneer' ),
'before_widget' => '<div id="%1$s" class="widget %2$s">',
'after_widget' => '</div>',
2024-06-13 00:16:16 +02:00
'before_title' => '<h2 class="widgettitle">',
'after_title' => '</h2>'
)
);
}
if ( ! get_option( 'fictioneer_disable_all_widgets' ) ) {
add_action( 'widgets_init', 'fictioneer_register_sidebar' );
}
2024-08-04 23:48:09 +02:00
/**
* Renders sidebar
*
* @since 5.22.0
*
* @param string $context Render context (story, chapter, etc.) of the sidebar.
*/
function fictioneer_sidebar( $context ) {
// Do not render sidebar if...
if ( get_theme_mod( 'sidebar_style', 'none' ) === 'none' || ! is_active_sidebar( 'fictioneer-sidebar' ) ) {
return;
}
// Setup
2024-08-04 23:48:09 +02:00
$post = get_post();
$sidebar_disabled = array(
'fcn_story' => get_theme_mod( 'sidebar_disable_in_stories' ),
'fcn_chapter' => get_theme_mod( 'sidebar_disable_in_chapters' ),
'fcn_collection' => get_theme_mod( 'sidebar_disable_in_collections' ),
'fcn_recommendation' => get_theme_mod( 'sidebar_disable_in_recommendations' )
);
2024-08-11 12:51:10 +02:00
// If not archive or search and post exists...
if ( $post && ! is_archive() && ! is_search() ) {
// .. check specific escape conditions
if (
( $sidebar_disabled[ $post->post_type ] ?? 0 ) ||
get_post_meta( $post->ID, 'fictioneer_disable_sidebar', true )
) {
return;
}
2024-08-04 23:48:09 +02:00
}
// Classes
$classes = [];
if ( get_theme_mod( 'sidebar_hide_on_mobile' ) ) {
$classes[] = '_hide-on-mobile';
}
2024-08-09 09:53:21 +02:00
// Remove filters
remove_filter( 'excerpt_more', 'fictioneer_excerpt_ellipsis' );
remove_filter( 'excerpt_length', 'fictioneer_custom_excerpt_length' );
2024-08-04 23:48:09 +02:00
// Start HTML ---> ?>
<aside class="fictioneer-sidebar _layout <?php echo implode( ' ', $classes ); ?>">
2024-08-12 02:42:45 +02:00
<div class="fictioneer-sidebar__wrapper _layout"><?php dynamic_sidebar( 'fictioneer-sidebar' ); ?></div>
2024-08-04 23:48:09 +02:00
</aside>
<?php // <--- End HTML
2024-08-09 09:53:21 +02:00
// Restore filters
add_filter( 'excerpt_more', 'fictioneer_excerpt_ellipsis' );
add_filter( 'excerpt_length', 'fictioneer_custom_excerpt_length' );
2024-08-04 23:48:09 +02:00
}
if ( ! get_option( 'fictioneer_disable_all_widgets' ) ) {
2024-08-04 23:48:09 +02:00
add_action( 'fictioneer_main', 'fictioneer_sidebar' );
}
// =============================================================================
// AFTER UPDATE
// =============================================================================
/**
* Purges selected caches and Transients after update
*
* @since 5.12.2
*/
function fictioneer_purge_caches_after_update() {
// Transients
fictioneer_delete_transients_like( 'fictioneer_' );
2024-04-10 13:12:35 +02:00
// Cache busting string
fictioneer_regenerate_cache_bust();
// Delete cached files
$cache_dir = WP_CONTENT_DIR . '/themes/fictioneer/cache/';
$files = glob( $cache_dir . '*' );
foreach ( $files as $file ) {
if ( is_file( $file ) ) {
unlink( $file );
}
}
2024-05-17 18:49:25 +02:00
2024-05-19 14:30:44 +02:00
fictioneer_clear_all_cached_partials();
}
add_action( 'fictioneer_after_update', 'fictioneer_purge_caches_after_update' );
2023-01-21 01:31:34 +01:00
// =============================================================================
2023-11-20 16:14:37 +01:00
// PROTECT META FIELDS
2023-11-20 14:16:05 +01:00
// =============================================================================
/**
* Removes default custom fields meta box
*
* @since 5.8.0
*
* @param string $post_type Post type of the post on Edit Post screen, 'link'
* on Edit Link screen, 'dashboard' on Dashboard screen.
* @param string $context Meta box context. Possible values include 'normal',
* 'advanced', 'side'.
*/
2023-11-20 16:14:37 +01:00
function fictioneer_remove_custom_fields_meta_boxes( $post_type, $context ) {
2023-11-20 14:16:05 +01:00
remove_meta_box( 'postcustom', $post_type, $context );
}
if ( ! get_option( 'fictioneer_enable_custom_fields' ) ) {
add_action( 'do_meta_boxes', 'fictioneer_remove_custom_fields_meta_boxes', 1, 2 );
}
2023-11-20 16:14:37 +01:00
/**
* Removes 'custom-fields' support for all posts
*
* Note: Disable this if you need the feature support.
2023-11-20 16:14:37 +01:00
*
* @since 5.8.0
* @since 5.21.1 - Added all post types.
2023-11-20 16:14:37 +01:00
*/
function fictioneer_remove_custom_fields_supports() {
remove_post_type_support( 'post', 'custom-fields' );
remove_post_type_support( 'page', 'custom-fields' );
remove_post_type_support( 'fcn_story', 'custom-fields' );
remove_post_type_support( 'fcn_chapter', 'custom-fields' );
remove_post_type_support( 'fcn_collection', 'custom-fields' );
remove_post_type_support( 'fcn_recommendation', 'custom-fields' );
2023-11-20 16:14:37 +01:00
}
if ( ! get_option( 'fictioneer_enable_custom_fields' ) ) {
add_action( 'init', 'fictioneer_remove_custom_fields_supports' );
}
2023-11-20 16:14:37 +01:00
/**
* Makes theme meta fields protected
*
* @since 5.8.0
*
* @param bool $protected Whether the meta key is considered protected.
* @param string $meta_key The meta key to check.
*
* @return bool True if the meta key is protected, false otherwise.
*/
function fictioneer_make_theme_meta_protected( $protected, $meta_key ) {
if ( strpos( $meta_key, 'fictioneer_' ) === 0 ) {
return true;
}
return $protected;
}
add_filter( 'is_protected_meta', 'fictioneer_make_theme_meta_protected', 10, 2 );
2023-11-20 14:16:05 +01:00
// =============================================================================
2023-11-21 17:59:02 +01:00
// PROTECT PERMALINKS
// =============================================================================
/**
* Prevents reserved slugs from being used in permalinks
*
* @since 5.8.0
*
* @param string $slug The prospective slug.
*
* @return string The filtered slug.
*/
function fictioneer_protect_reserved_post_slugs( $slug ) {
2024-01-13 02:59:24 +01:00
$protected = [FICTIONEER_OAUTH_ENDPOINT, FICTIONEER_EPUB_ENDPOINT, FICTIONEER_LOGOUT_ENDPOINT, 'fictioneer_sitemap'];
2023-11-21 17:59:02 +01:00
// Prevent slugs from being applied to posts
if ( in_array( $slug, $protected ) ) {
return $slug . '-2';
}
// Continue filter
return $slug;
}
add_filter( 'wp_unique_post_slug', 'fictioneer_protect_reserved_post_slugs' );
// =============================================================================
2023-01-21 01:31:34 +01:00
// CUSTOM BACKGROUND CALLBACK
// =============================================================================
/**
* Fictioneer version of _custom_background_cb() for custom backgrounds
*
* @since 4.7.0
2023-01-21 01:31:34 +01:00
* @link https://developer.wordpress.org/reference/functions/_custom_background_cb/
*/
function fictioneer_custom_background() {
// Get background image
$background = set_url_scheme( get_background_image() );
// Abort if no background image
if ( ! $background ) {
echo '';
return;
}
// Assign background image to property
$image = 'background-image: url("' . esc_url_raw( $background ) . '");';
// Background position
$position_x = get_theme_mod( 'background_position_x' );
$position_y = get_theme_mod( 'background_position_y' );
2023-08-19 13:33:25 +02:00
if ( ! in_array( $position_x, ['left', 'center', 'right'], true ) ) {
$position_x = 'left';
}
if ( ! in_array( $position_y, ['top', 'center', 'bottom'], true ) ) {
$position_y = 'top';
}
$position = "background-position: {$position_x} {$position_y};";
2023-01-21 01:31:34 +01:00
// Background size
$size = get_theme_mod( 'background_size' );
2023-08-19 13:33:25 +02:00
if ( ! in_array( $size, ['auto', 'contain', 'cover'], true ) ) {
$size = 'auto';
}
$size = "background-size: {$size};";
2023-01-21 01:31:34 +01:00
// Background repeat
$repeat = get_theme_mod( 'background_repeat' );
2023-08-19 13:33:25 +02:00
if ( ! in_array( $repeat, ['repeat-x', 'repeat-y', 'repeat', 'no-repeat'], true ) ) {
$repeat = 'repeat';
}
$repeat = "background-repeat: {$repeat};";
2023-01-21 01:31:34 +01:00
// Background scroll
$attachment = get_theme_mod( 'background_attachment' );
2023-08-19 13:33:25 +02:00
if ( $attachment !== 'fixed' ) {
2023-08-19 13:33:25 +02:00
$attachment = 'scroll';
}
$attachment = "background-attachment: {$attachment};";
2023-01-21 01:31:34 +01:00
// Build
$style = $image . $position . $size . $repeat . $attachment;
// Output
echo '<style id="custom-background-css" type="text/css">.custom-background {' . trim( $style ) . '}</style>';
2023-01-21 01:31:34 +01:00
}
// =============================================================================
// MODIFY ALLOWED TAGS
// =============================================================================
/**
* Update list of allowed tags
*
* @since 4.7.0
2023-01-21 01:31:34 +01:00
*
2023-08-11 22:23:54 +02:00
* @global array $allowedtags Array of allowed tags.
2023-01-21 01:31:34 +01:00
*/
function fictioneer_modify_allowed_tags() {
global $allowedtags;
$allowedtags['ins'] = array(
'datetime' => []
);
2023-08-19 13:33:25 +02:00
$allowedtags['p'] = [];
$allowedtags['span'] = [];
$allowedtags['br'] = [];
2023-01-21 01:31:34 +01:00
}
add_action( 'init', 'fictioneer_modify_allowed_tags', 20 );
// =============================================================================
// HTML ROOT INJECTION
// =============================================================================
/**
* Injects attributes and classes into the <html> root
*
* @since 4.7.0
2023-01-21 01:31:34 +01:00
*/
function fictioneer_root_attributes() {
global $post;
// Setup
$post_author_id = ( $post instanceof WP_Post ) ? $post->post_author : 0;
2023-01-21 01:31:34 +01:00
$output = [];
2024-08-09 16:41:00 +02:00
$classes = ['no-js'];
2023-01-21 01:31:34 +01:00
if ( is_archive() || is_search() || is_404() ) {
$post_author_id = 0;
}
// Header inset
2023-08-19 13:33:25 +02:00
if ( get_theme_mod( 'inset_header_image', false ) ) {
2024-02-16 15:59:22 +01:00
$classes[] = 'inset-header-image';
2023-08-19 13:33:25 +02:00
}
2023-01-21 01:31:34 +01:00
// Header style
2024-02-16 15:59:22 +01:00
$classes[] = 'header-style-' . get_theme_mod( 'header_style', 'default' );
// Header image style
if ( get_theme_mod( 'header_image_style', 'default' ) !== 'default' ) {
2024-02-16 15:59:22 +01:00
$classes[] = 'header-image-style-' . get_theme_mod( 'header_image_style' );
}
2024-02-14 00:22:13 +01:00
// Page style
2024-02-16 15:59:22 +01:00
$page_style = get_theme_mod( 'page_style', 'default' );
if ( $page_style !== 'default' ) {
if ( $page_style === 'polygon-mask-image-battered-ringbook' ) {
$classes[] = 'page-style-polygon-battered';
$classes[] = 'page-style-mask-image-ringbook';
2024-02-14 23:42:22 +01:00
} else {
2024-02-16 15:59:22 +01:00
$classes[] = 'page-style-' . $page_style;
2024-02-14 23:42:22 +01:00
}
2024-02-14 22:20:37 +01:00
2024-02-16 15:59:22 +01:00
if ( strpos( $page_style, 'polygon-' ) !== false || strpos( $page_style, 'mask-image-' ) !== false ) {
$classes[] = 'has-polygon-or-mask';
2024-02-14 22:20:37 +01:00
}
2024-02-14 00:22:13 +01:00
}
// Page shadow
2024-02-18 15:45:01 +01:00
if ( ! get_theme_mod( 'page_shadow', true ) ) {
2024-02-16 15:59:22 +01:00
$classes[] = 'no-page-shadow';
}
2023-01-21 01:31:34 +01:00
// Prepare
2024-02-16 15:59:22 +01:00
$output['class'] = implode( ' ', $classes );
$output['data-mode-default'] = get_option( 'fictioneer_dark_mode_as_default', false ) ? 'dark' : 'light';
2023-08-19 13:33:25 +02:00
$output['data-site-width-default'] = get_theme_mod( 'site_width', 960 );
2023-01-21 01:31:34 +01:00
$output['data-theme'] = 'default';
$output['data-mode'] = $output['data-mode-default'];
2023-01-21 01:31:34 +01:00
$output['data-font-weight'] = 'default';
$output['data-primary-font'] = FICTIONEER_PRIMARY_FONT_CSS;
2023-08-19 13:33:25 +02:00
if ( get_post_type( $post ) === 'fcn_chapter' ) {
// Also set on the frontend, this is only for customization.
$formatting = array(
// 'font-saturation' => 0,
// 'font-size' => 100,
// 'letter-spacing' => 0,
// 'line-height' => 1.7,
// 'paragraph-spacing' => 1.5,
'indent' => get_option( 'fictioneer_disable_default_formatting_indent', 0 ) ? false : true,
// 'show-sensitive-content' => true,
// 'show-chapter-notes' => true,
// 'justify' => false,
// 'show-comments' => true,
// 'show-paragraph-tools' => true
);
$formatting = apply_filters( 'fictioneer_filter_chapter_default_formatting', $formatting );
if ( ! empty( $formatting ) ) {
$output['data-default-formatting'] = json_encode( $formatting );
}
}
2023-08-19 13:33:25 +02:00
$conditions = array(
'data-age-confirmation' => get_option( 'fictioneer_enable_site_age_confirmation' ),
'data-caching-active' => fictioneer_caching_active( 'root_attribute' ),
2023-08-19 13:33:25 +02:00
'data-ajax-submit' => get_option( 'fictioneer_enable_ajax_comment_submit', false ),
'data-force-child-theme' => ! FICTIONEER_THEME_SWITCH,
'data-public-caching' => get_option( 'fictioneer_enable_public_cache_compatibility', false ),
'data-ajax-auth' => get_option( 'fictioneer_enable_ajax_authentication', false ),
'data-edit-time' => get_option( 'fictioneer_enable_user_comment_editing', false ) ?
get_option( 'fictioneer_user_comment_edit_time', 15 ) : false,
);
// Iterate conditions and add the truthy to the output
foreach ( $conditions as $key => $condition ) {
if ( $condition ) {
$output[ $key ] = is_bool( $condition ) ? '1' : $condition;
}
}
2023-01-21 01:31:34 +01:00
// Fingerprint
if ( $post_author_id ) {
$output['data-author-fingerprint'] = fictioneer_get_user_fingerprint( $post_author_id );
}
2023-01-21 01:31:34 +01:00
// Filter output
$output = apply_filters( 'fictioneer_filter_root_attributes', $output );
// Output
foreach ( $output as $key => $value ) {
2024-02-14 11:53:56 +01:00
echo "{$key}='" . esc_attr( $value ) . "' ";
2023-01-21 01:31:34 +01:00
}
}
2024-01-11 12:14:16 +01:00
// =============================================================================
// ADD BODY CLASSES
// =============================================================================
/**
* Add additional classes to the frontend <body>
*
* @since 5.0.0
2024-01-11 12:14:16 +01:00
*
* @param array $classes Current body classes.
*
* @return array The updated body classes.
*/
function fictioneer_add_classes_to_body( $classes ) {
// Setup
2024-08-04 23:48:09 +02:00
$post = get_post();
2024-01-11 12:14:16 +01:00
$user = wp_get_current_user();
$template = get_page_template_slug();
2024-01-11 12:14:16 +01:00
$includes = [];
// Mobile menu
if ( get_theme_mod( 'mobile_menu_style', 'minimize_to_right' ) === 'minimize_to_right' ) {
$classes[] = 'advanced-mobile-menu';
}
2024-01-11 12:14:16 +01:00
// Roles
if ( $user->ID > 0 && ! get_option( 'fictioneer_enable_public_cache_compatibility' ) ) {
$includes['is-admin'] = fictioneer_is_admin( $user->ID );
$includes['is-moderator'] = fictioneer_is_moderator( $user->ID );
$includes['is-author'] = fictioneer_is_author( $user->ID );
$includes['is-editor'] = fictioneer_is_editor( $user->ID );
}
// Browsers
2024-08-11 13:27:44 +02:00
if ( ! fictioneer_caching_active( 'device_body_classes' ) ) {
2024-01-11 12:14:16 +01:00
$includes['is-iphone'] = $GLOBALS['is_iphone'];
$includes['is-chrome'] = $GLOBALS['is_chrome'];
$includes['is-safari'] = $GLOBALS['is_safari'];
$includes['is-opera'] = $GLOBALS['is_opera'];
$includes['is-gecko'] = $GLOBALS['is_gecko'];
$includes['is-lynx'] = $GLOBALS['is_lynx'];
$includes['is-ie'] = $GLOBALS['is_IE'];
$includes['is-edge'] = $GLOBALS['is_edge'];
}
// Add classes to defaults
foreach ( $includes as $class => $test ) {
if ( $test ) {
2024-01-11 12:14:16 +01:00
$classes[ $class ] = $class;
}
}
2024-01-11 12:14:16 +01:00
// Customizations and settings
if ( get_theme_mod( 'content_list_style', 'default' ) !== 'default' ) {
$classes[] = 'content-list-style-' . get_theme_mod( 'content_list_style' );
}
2024-08-04 23:48:09 +02:00
// Sidebar
$sidebar_style = get_theme_mod( 'sidebar_style', 'none' );
if (
$sidebar_style !== 'none' &&
is_active_sidebar( 'fictioneer-sidebar' ) &&
! get_option( 'fictioneer_disable_all_widgets' )
2024-08-04 23:48:09 +02:00
) {
$sidebar_disabled = array(
'fcn_story' => get_theme_mod( 'sidebar_disable_in_stories' ),
'fcn_chapter' => get_theme_mod( 'sidebar_disable_in_chapters' ),
'fcn_collection' => get_theme_mod( 'sidebar_disable_in_collections' ),
'fcn_recommendation' => get_theme_mod( 'sidebar_disable_in_recommendations' )
);
$is_sidebar_disabled = false;
2024-08-11 12:51:10 +02:00
// If not archive or search and post exists...
if ( $post && ! is_archive() && ! is_search() ) {
// .. check specific escape conditions
if (
( $sidebar_disabled[ $post->post_type ] ?? 0 ) ||
get_post_meta( $post->ID, 'fictioneer_disable_sidebar', true ) ||
in_array( $template, ['singular-canvas-main.php', 'singular-canvas-site.php'] )
2024-08-11 12:51:10 +02:00
) {
$is_sidebar_disabled = true;
}
}
if ( ! $is_sidebar_disabled ) {
$classes[] = 'has-sidebar';
2024-08-04 23:48:09 +02:00
if ( $sidebar_style === 'right' ) {
$classes[] = 'has-sidebar-right';
2024-08-12 02:42:45 +02:00
} else {
$classes[] = 'has-sidebar-left';
}
2024-08-04 23:48:09 +02:00
}
}
// Page padding
if ( $post && get_post_meta( $post->ID, 'fictioneer_disable_page_padding', true ) ) {
$classes[] = 'no-page-padding';
}
2024-01-11 12:14:16 +01:00
// Continue filter
return $classes;
}
if ( ! is_admin() ) {
add_filter( 'body_class', 'fictioneer_add_classes_to_body' );
}
/**
* Add additional classes to the admin <body>
*
* @since 5.0.0
2024-01-11 12:14:16 +01:00
*
* @param string $classes Current body classes separated by whitespace.
2024-01-11 12:14:16 +01:00
*
* @return string The updated body classes.
2024-01-11 12:14:16 +01:00
*/
function fictioneer_add_classes_to_admin_body( $classes ) {
// Setup
$user = wp_get_current_user();
$includes = [];
// Classes
$includes['is-admin'] = fictioneer_is_admin( $user->ID );
$includes['is-moderator'] = fictioneer_is_moderator( $user->ID );
$includes['is-author'] = fictioneer_is_author( $user->ID );
$includes['is-editor'] = fictioneer_is_editor( $user->ID );
// Add classes to defaults
if ( array_intersect( ['subscriber'], $user->roles ) ) {
$classes .= ' is-subscriber';
} else {
foreach ( $includes as $class => $test ) {
if ( $test ) {
$classes .= " $class";
}
}
}
// Continue filter
return $classes;
}
add_filter( 'admin_body_class', 'fictioneer_add_classes_to_admin_body' );
2024-04-10 13:12:35 +02:00
// =============================================================================
// CACHE BUSTING
// =============================================================================
/**
* Returns saved random cache busting string
*
* @since 5.12.5
*
* @return string Cache busting string.
*/
function fictioneer_get_cache_bust() {
$cache_bust = get_option( 'fictioneer_cache_bust' );
if ( empty( $cache_bust ) ) {
$cache_bust = fictioneer_regenerate_cache_bust();
}
return $cache_bust;
}
/**
* Regenerate cache busting string
*
* @since 5.12.5
*/
function fictioneer_regenerate_cache_bust() {
$cache_bust = time();
update_option( 'fictioneer_cache_bust', $cache_bust, '', true );
return $cache_bust;
}
add_action( 'customize_save_after', 'fictioneer_regenerate_cache_bust' );
2023-01-21 01:31:34 +01:00
// =============================================================================
// ENQUEUE STYLESHEETS
// =============================================================================
/**
* Enqueues stylesheets
*
* @since 1.0.0
* @since 4.7.0 - Split stylesheets into separate concerns.
2023-01-21 01:31:34 +01:00
*/
function fictioneer_style_queue() {
2024-04-10 13:12:35 +02:00
// Setup
$cache_bust = fictioneer_get_cache_bust();
2023-01-21 01:31:34 +01:00
// Either load separate small style files on demand or the complete one
if ( ! get_option( 'fictioneer_bundle_stylesheets' ) ) {
// Setup
$post_type = get_post_type();
2024-02-25 12:50:41 +01:00
$template_slug = get_page_template_slug();
2023-01-21 01:31:34 +01:00
$application_dependencies = [];
// Properties
if ( ! get_option( 'fictioneer_disable_properties' ) ) {
wp_enqueue_style(
'fictioneer-properties',
get_template_directory_uri() . '/css/properties.css',
[],
2024-04-10 13:12:35 +02:00
$cache_bust
2023-01-21 01:31:34 +01:00
);
$application_dependencies[] = 'fictioneer-properties';
}
// Application
wp_enqueue_style(
'fictioneer-application',
get_template_directory_uri() . '/css/application.css',
$application_dependencies,
2024-04-10 13:12:35 +02:00
$cache_bust
2023-01-21 01:31:34 +01:00
);
// If NOT an archive or search page...
if ( ! is_search() && ! is_archive() ) {
// Collections
if ( is_page_template( 'stories.php' ) || $post_type == 'fcn_collection' ) {
wp_enqueue_style(
'fictioneer-collections',
get_template_directory_uri() . '/css/collections.css',
['fictioneer-application'],
2024-04-10 13:12:35 +02:00
$cache_bust
2023-01-21 01:31:34 +01:00
);
}
// Chapter
if ( $post_type == 'fcn_chapter' ) {
wp_enqueue_style(
'fictioneer-chapter',
get_template_directory_uri() . '/css/chapter.css',
['fictioneer-application'],
2024-04-10 13:12:35 +02:00
$cache_bust
2023-01-21 01:31:34 +01:00
);
}
// Story
2024-04-14 12:47:39 +02:00
if ( $post_type == 'fcn_story' || is_page_template( 'singular-story.php' ) ) {
2023-01-21 01:31:34 +01:00
wp_enqueue_style(
'fictioneer-story',
get_template_directory_uri() . '/css/story.css',
['fictioneer-application'],
2024-04-10 13:12:35 +02:00
$cache_bust
2023-01-21 01:31:34 +01:00
);
}
// Recommendation
if ( $post_type == 'fcn_recommendation' ) {
wp_enqueue_style(
'fictioneer-recommendation',
get_template_directory_uri() . '/css/recommendation.css',
['fictioneer-application'],
2024-04-10 13:12:35 +02:00
$cache_bust
2023-01-21 01:31:34 +01:00
);
}
// Comments
2024-04-16 11:50:11 +02:00
if (
$post_type == 'fcn_story' ||
$template_slug === 'user-profile.php' ||
comments_open() ||
is_page_template( 'singular-story.php' )
) {
2023-01-21 01:31:34 +01:00
wp_enqueue_style(
'fictioneer-comments',
get_template_directory_uri() . '/css/comments.css',
['fictioneer-application'],
2024-04-10 13:12:35 +02:00
$cache_bust
2023-01-21 01:31:34 +01:00
);
}
}
// Archive
if ( is_archive() ) {
wp_enqueue_style(
'fictioneer-archive',
get_template_directory_uri() . '/css/taxonomies.css',
['fictioneer-application'],
2024-04-10 13:12:35 +02:00
$cache_bust
2023-01-21 01:31:34 +01:00
);
}
} else {
// Complete
wp_enqueue_style(
'fictioneer-complete',
get_template_directory_uri() . '/css/complete.css',
[],
2024-04-10 13:12:35 +02:00
$cache_bust
2023-01-21 01:31:34 +01:00
);
}
}
add_action( 'wp_enqueue_scripts', 'fictioneer_style_queue' );
2024-02-15 17:54:04 +01:00
// =============================================================================
// ENQUEUE CUSTOMIZE CSS
// =============================================================================
/**
* Enqueues customize stylesheets <head> meta
*
* @since 5.11.0
*/
function fictioneer_output_customize_css() {
// Setup
$file_path = WP_CONTENT_DIR . '/themes/fictioneer/cache/customize.css';
// Create file if it does not exist
if ( ! file_exists( $file_path ) ) {
fictioneer_build_customize_css();
}
// Output customize stylesheet...
if ( file_exists( $file_path ) ) {
wp_enqueue_style(
'fictioneer-customize',
2024-05-25 19:26:38 +02:00
get_template_directory_uri() . "/cache/customize.css",
2024-05-03 19:51:16 +02:00
get_option( 'fictioneer_bundle_stylesheets' ) ? ['fictioneer-complete'] : ['fictioneer-application'],
2024-04-10 13:12:35 +02:00
fictioneer_get_cache_bust()
2024-02-15 17:54:04 +01:00
);
}
}
if ( ! is_customize_preview() ) {
add_action( 'wp_enqueue_scripts', 'fictioneer_output_customize_css', 9999 );
}
/**
* Enqueues preview customize stylesheets <head> meta
*
* @since 5.11.0
*/
function fictioneer_output_customize_preview_css() {
// Setup
$file_path = WP_CONTENT_DIR . '/themes/fictioneer/cache/customize-preview.css';
// Create file if it does not exist
fictioneer_build_customize_css( 'preview' );
// Output customize stylesheet...
if ( file_exists( $file_path ) ) {
wp_enqueue_style(
'fictioneer-customize',
2024-05-25 19:26:38 +02:00
get_template_directory_uri() . "/cache/customize-preview.css",
2024-02-15 17:54:04 +01:00
['fictioneer-application'],
2024-05-25 19:26:38 +02:00
time() // Prevents caching in preview
2024-02-15 17:54:04 +01:00
);
}
}
if ( is_customize_preview() ) {
add_action( 'wp_enqueue_scripts', 'fictioneer_output_customize_preview_css', 9999 );
}
2023-01-21 01:31:34 +01:00
// =============================================================================
2023-11-10 17:22:35 +01:00
// FONT AWESOME
2023-01-21 01:31:34 +01:00
// =============================================================================
2023-11-10 17:22:35 +01:00
if ( ! function_exists( 'fictioneer_add_font_awesome_integrity' ) ) {
/**
2023-11-10 17:22:35 +01:00
* Enqueue Font Awesome
*
2023-11-10 17:22:35 +01:00
* @since 5.7.6
* @link https://fontawesome.com/docs/web/use-with/wordpress/install-manually
2023-11-10 17:22:35 +01:00
*
* @param string $tag The link tag for the enqueued style.
* @param string $handle The style's registered handle.
*
* @return string The modified link tag.
*/
2023-11-10 17:22:35 +01:00
function fictioneer_add_font_awesome_integrity( $tag, $handle ) {
// Abort conditions...
if ( empty( FICTIONEER_FA_INTEGRITY ) ) {
return $tag;
}
// Modify HTML
if ( $handle === 'font-awesome-cdn-webfont-fictioneer' ) {
$tag = preg_replace( '/\/>$/', 'integrity="' . FICTIONEER_FA_INTEGRITY . '" crossorigin="anonymous" />', $tag, 1 );
}
2023-01-21 01:31:34 +01:00
2023-11-10 17:22:35 +01:00
// Continue filter
return $tag;
}
}
if ( ! function_exists( 'fictioneer_add_font_awesome' ) ) {
/**
* Enqueue Font Awesome
*
* @since 5.7.6
* @link https://fontawesome.com/docs/web/use-with/wordpress/install-manually
*/
function fictioneer_add_font_awesome() {
// Abort conditions...
if ( empty( FICTIONEER_FA_CDN ) ) {
return;
}
// Setup
$actions = ['wp_enqueue_scripts', 'admin_enqueue_scripts', 'login_enqueue_scripts'];
// Actions
foreach ( $actions as $action ) {
2023-01-21 01:31:34 +01:00
add_action(
$action,
2023-11-10 20:23:23 +01:00
function() {
2023-11-10 17:22:35 +01:00
wp_enqueue_style( 'font-awesome-cdn-webfont-fictioneer', FICTIONEER_FA_CDN, [], null );
2023-01-21 01:31:34 +01:00
}
);
}
2023-11-10 17:22:35 +01:00
// Filters
add_filter( 'style_loader_tag', 'fictioneer_add_font_awesome_integrity', 10, 2 );
2023-01-21 01:31:34 +01:00
}
2023-11-10 17:22:35 +01:00
// Initialize
if ( ! get_option( 'fictioneer_disable_font_awesome' ) ) {
fictioneer_add_font_awesome();
}
2023-01-21 01:31:34 +01:00
}
// =============================================================================
// ENQUEUE SCRIPTS
// =============================================================================
/**
* Build dynamic script file
*
* @since 5.12.2
*/
function fictioneer_build_dynamic_scripts() {
// --- Setup -----------------------------------------------------------------
$file_path = WP_CONTENT_DIR . '/themes/fictioneer/cache/dynamic-scripts.js';
$last_version = get_transient( 'fictioneer_dynamic_scripts_version' );
$scripts = '';
// Rebuild necessary?
if ( file_exists( $file_path ) && $last_version === FICTIONEER_VERSION ) {
return;
}
// Make sure directory exists
if ( ! file_exists( dirname( $file_path ) ) ) {
mkdir( dirname( $file_path ), 0755, true );
}
// --- AJAX Settings ---------------------------------------------------------
$scripts .= "var fictioneer_ajax = " . json_encode( array(
'ajax_url' => admin_url( 'admin-ajax.php' ),
'rest_url' => get_rest_url( null, 'fictioneer/v1/' ),
'ttl' => FICTIONEER_AJAX_TTL,
'login_ttl' => FICTIONEER_AJAX_LOGIN_TTL,
'post_debounce_rate' => FICTIONEER_AJAX_POST_DEBOUNCE_RATE
)) . ";";
// --- Removable query args --------------------------------------------------
$removable_query_args = ['success', 'failure', 'fictioneer_nonce', 'fictioneer-notice'];
$removable_query_args = apply_filters( 'fictioneer_filter_removable_query_args', $removable_query_args );
$scripts .=
"function fcn_removeQueryArgs(){history.replaceState && history.replaceState(null, '', location.pathname + location.search.replace(/[?&](" . implode( '|', $removable_query_args ) . ")=[^&]+/g, '').replace(/^[?&]/, '?') + location.hash);}";
// --- Fonts -----------------------------------------------------------------
$scripts .= "var fictioneer_fonts = " . json_encode( fictioneer_get_fonts() ) . ";";
// --- Colors ----------------------------------------------------------------
$scripts .= "var fictioneer_font_colors = " . json_encode( fictioneer_get_font_colors() ) . ";";
// --- Comments --------------------------------------------------------------
$scripts .= "var fictioneer_comments = " . json_encode( array(
'form_selector' => get_option( 'fictioneer_comment_form_selector', '#comment' ) ?: '#comment'
)) . ";";
// --- Save ------------------------------------------------------------------
set_transient( 'fictioneer_dynamic_scripts_version', FICTIONEER_VERSION );
file_put_contents( $file_path, $scripts );
}
2023-01-21 01:31:34 +01:00
/**
* Enqueue scripts
*
* @since 1.0.0
* @since 4.7.0 - Split scripts and made enqueuing depending on options.
* @since 5.12.2 - Added defer loading strategy; added dynamic script file.
2023-01-21 01:31:34 +01:00
*/
function fictioneer_add_custom_scripts() {
// Setup
$post_type = get_post_type();
2024-04-10 13:12:35 +02:00
$cache_bust = fictioneer_get_cache_bust();
$password_required = post_password_required();
2024-03-07 00:19:40 +01:00
$strategy = fictioneer_compare_wp_version( '6.3' ) && FICTIONEER_DEFER_SCRIPTS
? array( 'strategy' => 'defer' ) : true; // Defer or load in footer
2023-01-21 01:31:34 +01:00
// Dynamic scripts
fictioneer_build_dynamic_scripts();
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-dynamic-scripts', get_template_directory_uri() . '/cache/dynamic-scripts.js', [], $cache_bust, $strategy );
2024-03-09 19:51:06 +01:00
// Register and enqueue single scripts or complete script
if ( ! get_option( 'fictioneer_bundle_scripts' ) ) {
// Utility
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-utility-scripts', get_template_directory_uri() . '/js/utility.min.js', ['fictioneer-dynamic-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Application
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-application-scripts', get_template_directory_uri() . '/js/application.min.js', [ 'fictioneer-utility-scripts', 'fictioneer-dynamic-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Lightbox
if ( get_option( 'fictioneer_enable_lightbox' ) ) {
2024-04-10 13:12:35 +02:00
wp_enqueue_script( 'fictioneer-lightbox', get_template_directory_uri() . '/js/lightbox.min.js', ['fictioneer-application-scripts'], $cache_bust, $strategy );
2024-03-09 19:51:06 +01:00
}
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Mobile menu
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-mobile-menu-scripts', get_template_directory_uri() . '/js/mobile-menu.min.js', [ 'fictioneer-application-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Consent
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-consent-scripts', get_template_directory_uri() . '/js/laws.min.js', [ 'fictioneer-application-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Chapter
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-chapter-scripts', get_template_directory_uri() . '/js/chapter.min.js', [ 'fictioneer-application-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Diff-Match-Patch
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-dmp', get_template_directory_uri() . '/js/diff-match-patch.js', [ 'fictioneer-chapter-scripts'], $cache_bust, $strategy );
2024-03-09 19:51:06 +01:00
// Suggestions
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-suggestion-scripts', get_template_directory_uri() . '/js/suggestion.min.js', [ 'fictioneer-chapter-scripts', 'fictioneer-dmp'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Text-To-Speech
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-tts-scripts', get_template_directory_uri() . '/js/tts.min.js', [ 'fictioneer-chapter-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Story
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-story-scripts', get_template_directory_uri() . '/js/story.min.js', [ 'fictioneer-application-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// User
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-user-scripts', get_template_directory_uri() . '/js/user.min.js', [ 'fictioneer-application-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// User Profile
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-user-profile-scripts', get_template_directory_uri() . '/js/user-profile.min.js', [ 'fictioneer-application-scripts', 'fictioneer-user-scripts'], $cache_bust, $strategy );
2023-08-27 17:14:56 +02:00
2024-03-09 19:51:06 +01:00
// Bookmarks
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-bookmarks-scripts', get_template_directory_uri() . '/js/bookmarks.min.js', [ 'fictioneer-application-scripts', 'fictioneer-user-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Follows
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-follows-scripts', get_template_directory_uri() . '/js/follows.min.js', [ 'fictioneer-application-scripts', 'fictioneer-user-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Checkmarks
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-checkmarks-scripts', get_template_directory_uri() . '/js/checkmarks.min.js', [ 'fictioneer-application-scripts', 'fictioneer-user-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Reminders
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-reminders-scripts', get_template_directory_uri() . '/js/reminders.min.js', [ 'fictioneer-application-scripts', 'fictioneer-user-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Comments
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-comments-scripts', get_template_directory_uri() . '/js/comments.min.js', [ 'fictioneer-application-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// AJAX Comments
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-ajax-comments-scripts', get_template_directory_uri() . '/js/ajax-comments.min.js', [ 'fictioneer-comments-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// AJAX Bookshelf
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-ajax-bookshelf-scripts', get_template_directory_uri() . '/js/ajax-bookshelf.min.js', [ 'fictioneer-application-scripts'], $cache_bust, $strategy );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Enqueue utility
wp_enqueue_script( 'fictioneer-utility-scripts' );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Enqueue application
wp_enqueue_script( 'fictioneer-application-scripts' );
2023-02-23 17:03:41 +01:00
2024-03-09 19:51:06 +01:00
// Enqueue mobile menu
wp_enqueue_script( 'fictioneer-mobile-menu-scripts' );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Enqueue consent
if ( get_option( 'fictioneer_cookie_banner' ) ) {
wp_enqueue_script( 'fictioneer-consent-scripts' );
}
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Enqueue chapter
if ( $post_type == 'fcn_chapter' && ! is_archive() && ! is_search() ) {
wp_enqueue_script( 'fictioneer-chapter-scripts' );
}
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Enqueue Diff-Match-Patch + suggestions
if (
$post_type == 'fcn_chapter' &&
get_option( 'fictioneer_enable_suggestions' ) &&
! is_archive() &&
! is_search() &&
! $password_required &&
2024-03-09 19:51:06 +01:00
! get_post_meta( get_the_ID(), 'fictioneer_disable_commenting', true ) &&
comments_open()
) {
wp_enqueue_script( 'fictioneer-dmp' );
wp_enqueue_script( 'fictioneer-suggestion-scripts' );
}
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Enqueue TTS
if (
$post_type == 'fcn_chapter' &&
get_option( 'fictioneer_enable_tts' ) &&
! is_archive() &&
! is_search() &&
! $password_required
2024-03-09 19:51:06 +01:00
) {
wp_enqueue_script( 'fictioneer-tts-scripts' );
}
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Enqueue story
2024-04-14 12:47:39 +02:00
if ( ( $post_type == 'fcn_story' || is_page_template( 'singular-story.php' ) ) && ! is_archive() && ! is_search() ) {
2024-03-09 19:51:06 +01:00
wp_enqueue_script( 'fictioneer-story-scripts' );
}
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
// Enqueue users + user profile + follows + checkmarks + reminders
if ( is_user_logged_in() || get_option( 'fictioneer_enable_ajax_authentication' ) ) {
wp_enqueue_script( 'fictioneer-user-scripts' );
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
if ( get_option( 'fictioneer_enable_checkmarks' ) ) {
wp_enqueue_script( 'fictioneer-checkmarks-scripts' );
}
2023-01-21 01:31:34 +01:00
2024-03-09 19:51:06 +01:00
if ( get_option( 'fictioneer_enable_reminders' ) ) {
wp_enqueue_script( 'fictioneer-reminders-scripts' );
}
if ( get_option( 'fictioneer_enable_follows' ) ) {
wp_enqueue_script( 'fictioneer-follows-scripts' );
}
if ( is_page_template( 'user-profile.php' ) ) {
wp_enqueue_script( 'fictioneer-user-profile-scripts' );
}
2023-01-21 01:31:34 +01:00
}
2024-03-09 19:51:06 +01:00
// Enqueue bookmarks
if ( get_option( 'fictioneer_enable_bookmarks' ) ) {
wp_enqueue_script( 'fictioneer-bookmarks-scripts' );
2023-01-21 01:31:34 +01:00
}
2024-03-09 19:51:06 +01:00
// Enqueue comments
if ( is_singular() && comments_open() ) {
wp_enqueue_script( 'fictioneer-comments-scripts' );
if ( get_option( 'fictioneer_enable_ajax_comments' ) ) {
wp_enqueue_script( 'fictioneer-ajax-comments-scripts' );
}
2023-01-21 01:31:34 +01:00
}
2024-03-09 19:51:06 +01:00
// Enqueue bookshelf
if ( is_page_template( 'singular-bookshelf-ajax.php' ) ) {
wp_enqueue_script( 'fictioneer-ajax-bookshelf-scripts' );
}
} else {
// Complete
2024-04-10 13:12:35 +02:00
wp_enqueue_script( 'fictioneer-complete-scripts', get_template_directory_uri() . '/js/complete.min.js', ['fictioneer-dynamic-scripts'], $cache_bust, $strategy );
2023-08-27 17:14:56 +02:00
}
2023-01-21 01:31:34 +01:00
// Enqueue WordPress comment-reply
if ( is_singular() && comments_open() && get_option( 'thread_comments' ) ) {
wp_enqueue_script( 'comment-reply' );
}
// DEV Utilities
if ( defined( 'WP_DEBUG' ) && WP_DEBUG ) {
2024-04-10 13:12:35 +02:00
wp_register_script( 'fictioneer-dev-scripts', get_template_directory_uri() . '/js/dev-tools.min.js', [], $cache_bust, $strategy );
wp_enqueue_script( 'fictioneer-dev-scripts' );
}
2023-01-21 01:31:34 +01:00
}
add_action( 'wp_enqueue_scripts', 'fictioneer_add_custom_scripts' );
2023-08-14 23:40:52 +02:00
/**
* Enqueue block editor scripts
*
* @since 5.6.0
*/
function fictioneer_enqueue_block_editor_scripts() {
// Setup
$current_screen = get_current_screen();
if ( $current_screen->base === 'post' ) {
$current_user = wp_get_current_user();
2023-08-14 23:40:52 +02:00
wp_register_script(
'fictioneer-block-editor-scripts',
get_template_directory_uri() . '/js/block-editor.min.js',
['wp-dom-ready', 'wp-edit-post', 'wp-blocks', 'wp-element', 'wp-components', 'wp-editor', 'wp-data', 'jquery'],
fictioneer_get_cache_bust(),
true
);
wp_enqueue_script( 'fictioneer-block-editor-scripts' );
2023-08-14 23:40:52 +02:00
wp_localize_script( 'fictioneer-block-editor-scripts', 'fictioneerData', array(
'userCapabilities' => $current_user->allcaps
));
}
2023-08-14 23:40:52 +02:00
}
add_action( 'enqueue_block_editor_assets', 'fictioneer_enqueue_block_editor_scripts' );
2024-03-02 23:36:12 +01:00
/**
* Enqueue customizer scripts
*
* @since 5.12.0
*/
function fictioneer_enqueue_customizer_scripts() {
wp_enqueue_script(
'fictioneer-customizer-scripts',
get_template_directory_uri() . '/js/customizer.min.js',
['jquery', 'customize-preview'],
2024-04-10 13:12:35 +02:00
fictioneer_get_cache_bust(),
2024-03-02 23:36:12 +01:00
true
);
wp_localize_script( 'fictioneer-customizer-scripts', 'fictioneerData', array(
'confirmationDialog' => __( 'Are you sure?', 'fictioneer' )
));
}
add_action( 'customize_controls_enqueue_scripts', 'fictioneer_enqueue_customizer_scripts' );
/**
* Add nonce for Customizer actions
*
* @since 5.12.0
*
* @param array $nonces Array of refreshed nonces for save and preview actions.
*
* @return array Updated array of nonces.
*/
function fictioneer_add_customizer_refresh_nonces( $nonces ) {
$nonces['fictioneer-reset-colors'] = wp_create_nonce( 'fictioneer-reset-colors' );
return $nonces;
}
add_filter( 'customize_refresh_nonces', 'fictioneer_add_customizer_refresh_nonces' );
// =============================================================================
// ADD SCRIPTS TO LOGIN HEAD
// =============================================================================
/**
* Print scripts to the wp-login-php
*
* @since 5.7.3
*/
function fictioneer_wp_login_scripts() {
// Clear web storage in preparation of login
echo "<script type='text/javascript' data-no-optimize='1' data-no-defer='1' data-no-minify='1'>localStorage.removeItem('fcnUserData'); localStorage.removeItem('fcnAuth');</script>";
}
add_action( 'login_head', 'fictioneer_wp_login_scripts' );
2023-01-21 01:31:34 +01:00
// =============================================================================
// DISABLE JQUERY MIGRATE
// =============================================================================
/**
* Removed the jQuery migrate script
*
* @since 5.0.0
2023-01-21 01:31:34 +01:00
*
* @param object $scripts The loaded scripts.
2023-01-21 01:31:34 +01:00
*/
function fictioneer_remove_jquery_migrate( $scripts ) {
// Abort if...
2023-08-28 10:43:04 +02:00
if ( ! isset( $scripts->registered['jquery'] ) ) {
return;
}
2023-01-21 01:31:34 +01:00
// Setup
$script = $scripts->registered['jquery'];
// Remove migrate script
if ( $script->deps ) {
$script->deps = array_diff( $script->deps, array( 'jquery-migrate' ) );
}
}
if ( ! is_admin() && ! get_option( 'fictioneer_enable_jquery_migrate' ) ) {
add_action( 'wp_default_scripts', 'fictioneer_remove_jquery_migrate' );
}
// =============================================================================
// AUTOPTIMIZE CONFIGURATION
// =============================================================================
/**
* Exclude stylesheets from Autoptimize (if installed)
*
* @since 4.0.0
2023-01-21 01:31:34 +01:00
* @link https://github.com/wp-plugins/autoptimize
*
2024-02-05 15:37:36 +01:00
* @param string $exclude List of current excludes.
*
* @return string The updated exclusion string.
2023-01-21 01:31:34 +01:00
*/
function fictioneer_ao_exclude_css( $exclude ) {
2024-02-07 03:05:05 +01:00
return $exclude . ', fonts-base.css, fonts-full.css, bundled-fonts.css';
2023-01-21 01:31:34 +01:00
}
add_filter( 'autoptimize_filter_css_exclude', 'fictioneer_ao_exclude_css', 10, 1 );
/**
* Turn off script optimization for admins and editors
*
* @since 5.20.0
* @link https://developer.wordpress.org/reference/hooks/pre_option_option/
*
* @param mixed $pre_option The value to return instead of the option value
* @param string $option Option name.
*
* @return mixed The updated or original option value.
*/
function fictioneer_override_autoptimize_optimize_logged_option( $value, $option ) {
if ( $option === 'autoptimize_optimize_logged' ) {
return '';
}
return $value;
}
add_filter( 'pre_option_autoptimize_optimize_logged', 'fictioneer_override_autoptimize_optimize_logged_option', 10, 2 );
2023-01-21 01:31:34 +01:00
// =============================================================================
// OUTPUT HEAD FONTS
// =============================================================================
2024-02-07 02:22:59 +01:00
if ( ! function_exists( 'fictioneer_output_critical_fonts' ) ) {
2023-01-21 01:31:34 +01:00
/**
2024-02-07 02:22:59 +01:00
* Output critical path fonts in <head>
2023-01-21 01:31:34 +01:00
*
* Critical fonts that need to be loaded as fast as possible and are
* therefore inlined in the <head>.
*
* @since 5.0.0
2023-01-21 01:31:34 +01:00
*/
2024-02-07 02:22:59 +01:00
function fictioneer_output_critical_fonts() {
2023-01-21 01:31:34 +01:00
// Setup
2024-02-08 00:26:13 +01:00
$primary_font = get_theme_mod( 'primary_font_family_value', 'Open Sans' );
2023-01-21 01:31:34 +01:00
$uri = get_template_directory_uri() . '/fonts/';
2024-02-08 00:26:13 +01:00
// Currently, only Open Sans is supported
if ( $primary_font !== 'Open Sans' ) {
return;
}
2023-01-21 01:31:34 +01:00
// Start HTML ---> ?>
<style id="inline-fonts" type="text/css" data-no-optimize="1" data-no-defer="1" data-no-minify="1">@font-face{font-display:swap;font-family:"Open Sans";font-style:normal;font-weight:300;src:local("OpenSans-Light"),url("<?php echo $uri; ?>open-sans/open-sans-v40-300.woff2") format("woff2")}@font-face{font-display:swap;font-family:"Open Sans";font-style:italic;font-weight:300;src:local("OpenSans-LightItalic"),url("<?php echo $uri; ?>open-sans/open-sans-v40-300italic.woff2") format("woff2")}@font-face{font-display:swap;font-family:"Open Sans";font-style:normal;font-weight:400;src:local("OpenSans-Regular"),url("<?php echo $uri; ?>open-sans/open-sans-v40-regular.woff2") format("woff2")}@font-face{font-display:swap;font-family:"Open Sans";font-style:italic;font-weight:400;src:local("OpenSans-Italic"),url("<?php echo $uri; ?>open-sans/open-sans-v40-italic.woff2") format("woff2")}@font-face{font-display:swap;font-family:"Open Sans";font-style:normal;font-weight:500;src:local("OpenSans-Medium"),url("<?php echo $uri; ?>open-sans/open-sans-v40-500.woff2") format("woff2")}@font-face{font-display:swap;font-family:"Open Sans";font-style:italic;font-weight:500;src:local("OpenSans-MediumItalic"),url("<?php echo $uri; ?>open-sans/open-sans-v40-500italic.woff2") format("woff2")}@font-face{font-display:swap;font-family:"Open Sans";font-style:normal;font-weight:600;src:local("OpenSans-SemiBold"),url("<?php echo $uri; ?>open-sans/open-sans-v40-600.woff2") format("woff2")}@font-face{font-display:swap;font-family:"Open Sans";font-style:italic;font-weight:600;src:local("OpenSans-SemiBoldItalic"),url("<?php echo $uri; ?>open-sans/open-sans-v40-600italic.woff2") format("woff2")}@font-face{font-display:swap;font-family:"Open Sans";font-style:normal;font-weight:700;src:local("OpenSans-Bold"),url("<?php echo $uri; ?>open-sans/open-sans-v40-700.woff2") format("woff2")}@font-face{font-display:swap;font-family:"Open Sans";font-style:italic;font-weight:700;src:local("OpenSans-BoldItalic"),url("<?php echo $uri; ?>open-sans/open-sans-v40-700italic.woff2") format("woff2")}</style>
2023-01-21 01:31:34 +01:00
<?php // <--- End HTML
}
}
// =============================================================================
// OUTPUT HEAD META
// =============================================================================
/**
* Output HTML <head> meta
*
* @since 5.0.0
* @since 5.10.0 - Split up for font manager.
* @since 5.18.1 - No longer pluggable, hooked into wp_head
*/
2023-01-21 01:31:34 +01:00
function fictioneer_output_head_meta() {
// Start HTML ---> ?>
<meta charset="<?php echo get_bloginfo( 'charset' ); ?>">
<meta name="viewport" content="width=device-width, minimum-scale=1.0, maximum-scale=5.0, viewport-fit=cover">
<meta name="format-detection" content="telephone=no">
<meta name="theme-color" content="<?php echo '#' . get_background_color(); ?>">
<meta name="referrer" content="strict-origin-when-cross-origin">
<?php // <--- End HTML
2024-02-07 23:24:46 +01:00
}
add_action( 'wp_head', 'fictioneer_output_head_meta', 1 );
2024-02-07 02:22:59 +01:00
2024-02-07 23:24:46 +01:00
// =============================================================================
// OUTPUT HEAD FONTS
// =============================================================================
2024-02-07 02:22:59 +01:00
2024-02-10 13:21:10 +01:00
if ( ! function_exists( 'fictioneer_output_head_fonts' ) ) {
/**
* Outputs font stylesheets in the <head>
2024-02-10 13:21:10 +01:00
*
* Note: This function should be kept pluggable due to legacy reasons.
*
* @since 5.10.0
*/
2024-02-07 23:24:46 +01:00
2024-02-10 13:21:10 +01:00
function fictioneer_output_head_fonts() {
// Critical path fonts
fictioneer_output_critical_fonts();
2024-02-07 23:24:46 +01:00
// Setup
2024-02-10 13:21:10 +01:00
$bundled_fonts = WP_CONTENT_DIR . '/themes/fictioneer/cache/bundled-fonts.css';
2024-02-11 14:49:39 +01:00
$last_built_timestamp = get_option( 'fictioneer_bundled_fonts_timestamp', '123456789' );
$cache_bust = "?timestamp={$last_built_timestamp}";
$loading_pattern = fictioneer_get_async_css_loading_pattern();
2024-02-07 23:24:46 +01:00
2024-02-10 13:21:10 +01:00
// Create file if it does not exist
if ( ! file_exists( $bundled_fonts ) ) {
fictioneer_build_bundled_fonts();
}
2024-02-07 23:24:46 +01:00
2024-02-10 13:21:10 +01:00
// Output font stylesheets...
if ( file_exists( $bundled_fonts ) ) {
// ... base and custom
2024-02-11 14:49:39 +01:00
$custom_fonts_href = get_template_directory_uri() . '/cache/bundled-fonts.css' . $cache_bust;
2024-02-10 13:21:10 +01:00
// Start HTML ---> ?>
<link rel="stylesheet" id="fictioneer-bundled-fonts-stylesheet" href="<?php echo $custom_fonts_href; ?>" data-no-optimize="1" data-no-minify="1" <?php echo $loading_pattern; ?>>
2024-02-10 13:21:10 +01:00
<noscript><link rel="stylesheet" href="<?php echo $custom_fonts_href; ?>"></noscript>
<?php // <--- End HTML
} else {
// ... all theme fonts if something goes wrong
2024-02-11 14:49:39 +01:00
$full_fonts_href = get_template_directory_uri() . '/css/fonts-full.css' . $cache_bust;
2024-02-10 13:21:10 +01:00
// Start HTML ---> ?>
<link rel="stylesheet" href="<?php echo $full_fonts_href; ?>" data-no-optimize="1" data-no-minify="1" <?php echo $loading_pattern; ?>>
2024-02-10 13:21:10 +01:00
<noscript><link rel="stylesheet" href="<?php echo $full_fonts_href; ?>"></noscript>
<?php // <--- End HTML
}
2024-02-08 16:03:35 +01:00
2024-02-10 13:21:10 +01:00
// Output Google Fonts links (if any)
$google_fonts_links = get_option( 'fictioneer_google_fonts_links' );
2024-02-08 16:03:35 +01:00
2024-02-10 13:21:10 +01:00
if ( ! empty( $google_fonts_links ) ) {
$google_fonts_links = explode( "\n", $google_fonts_links );
2024-02-08 16:48:26 +01:00
2024-02-10 13:21:10 +01:00
// Start HTML ---> ?>
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<?php // <--- End HTML
2024-02-08 16:03:35 +01:00
2024-02-10 13:21:10 +01:00
foreach ( $google_fonts_links as $link ) {
printf( '<link href="%s" rel="stylesheet">', $link );
}
2024-02-08 16:03:35 +01:00
}
}
2023-01-21 01:31:34 +01:00
}
2024-02-07 23:24:46 +01:00
add_action( 'wp_head', 'fictioneer_output_head_fonts', 5 );
2024-02-08 20:57:39 +01:00
add_action( 'admin_head', 'fictioneer_output_head_fonts', 5 );
add_action( 'elementor/editor/after_enqueue_scripts', 'fictioneer_output_head_fonts', 5 );
2023-01-21 01:31:34 +01:00
// =============================================================================
// OUTPUT HEAD NOSCRIPT
// =============================================================================
/**
* Outputs script to prevent flickering of layout on page load
*
* @since 5.22.1
*/
function fictioneer_output_head_anti_flicker() {
// Start HTML ---> ?>
2024-08-09 16:41:00 +02:00
<style>:root:not(.no-js) body{visibility: hidden;}</style>
<noscript>
<style>body {visibility: visible !important;}</style>
</noscript>
2024-08-09 10:19:58 +02:00
<script>document.addEventListener('readystatechange', () => {if (document.readyState === "interactive") document.body.style.visibility = "visible";});</script>
<?php // <--- End HTML
}
2024-08-09 10:19:58 +02:00
if ( ! get_option( 'fictioneer_disable_anti_flicker' ) ) {
add_action( 'wp_head', 'fictioneer_output_head_anti_flicker' );
}
2023-01-21 01:31:34 +01:00
// =============================================================================
// OUTPUT HEAD CRITICAL SCRIPTS
// =============================================================================
/**
* Outputs critical path scripts in the <head>
*
* Critical path scripts executed in the <head> before the rest of the DOM
* is loaded. This is necessary for the light/dark switch and site settings
* to work without causing color flickering or layout shifts. This is achieved
* by adding configuration classes directly into the <html> root node, which
* is the only one available at this point.
*
* @since 5.0.0
* @since 5.18.1 - No longer pluggable, hooked into wp_head
*/
2023-01-21 01:31:34 +01:00
function fictioneer_output_head_critical_scripts() {
// Start HTML ---> ?>
2024-08-09 16:41:00 +02:00
<script id="fictioneer-critical-scripts" data-no-optimize="1" data-no-defer="1" data-no-minify="1">!function(){if("undefined"!=typeof localStorage){const e=localStorage.getItem("fcnLightmode"),t=document.documentElement;let a,o=localStorage.getItem("fcnSiteSettings");if(o&&(o=JSON.parse(o))&&null!==o&&"object"==typeof o){Object.entries(o).forEach((([e,s])=>{switch(e){case"minimal":t.classList.toggle("minimal",s);break;case"darken":a=s>=0?1+s**2:1-s**2,t.style.setProperty("--darken",`(${a} + var(--lightness-offset))`);break;case"saturation":case"font-lightness":case"font-saturation":a=s>=0?1+s**2:1-s**2,t.style.setProperty(`--${e}`,`(${a} + var(--${e}-offset))`);break;case"hue-rotate":a=Number.isInteger(o["hue-rotate"])?o["hue-rotate"]:0,t.style.setProperty("--hue-rotate",`(${a}deg + var(--hue-offset))`);break;default:t.classList.toggle(`no-${e}`,!s)}})),t.dataset.fontWeight=o["font-weight"]?o["font-weight"]:"default",t.dataset.theme=o["site-theme"]&&!t.dataset.forceChildTheme?o["site-theme"]:"default";let e=getComputedStyle(document.documentElement).getPropertyValue("--theme-color-base").trim().split(" ");const s=o.darken?o.darken:0,r=o.saturation?o.saturation:0,n=o["hue-rotate"]?o["hue-rotate"]:0,l=s>=0?1+s**2:1-s**2;o=r>=0?1+r**2:1-r**2,e=`hsl(${(parseInt(e[0])+n)%360}deg ${(parseInt(e[1])*o).toFixed(2)}% ${(parseInt(e[2])*l).toFixed(2)}%)`,document.querySelector("meta[name=theme-color]").setAttribute("content",e)}e&&(t.dataset.mode="true"==e?"light":"dark")}}(),document.documentElement.classList.remove("no-js");</script>
<?php // <--- End HTML
2023-01-21 01:31:34 +01:00
}
add_action( 'wp_head', 'fictioneer_output_head_critical_scripts', 9999 );
2023-01-21 01:31:34 +01:00
2023-01-31 08:09:02 +01:00
// =============================================================================
// ADD EXCERPTS TO PAGES
// =============================================================================
add_post_type_support( 'page', 'excerpt' );
// =============================================================================
// PAGINATION
// =============================================================================
/**
* Modifies the pagination links output for the theme
*
* @since 5.4.0
* @link https://developer.wordpress.org/reference/functions/paginate_links/
*
* @param array $args Optional. Array of arguments for generating the pagination links.
*
* @return string Modified pagination links HTML.
*/
function fictioneer_paginate_links( $args = [] ) {
$args['end_size'] = 1;
$args['mid_size'] = 1;
$pagination = paginate_links( $args );
if ( ! $pagination ) {
return '';
}
return str_replace(
'class="page-numbers dots"',
'class="page-numbers dots" tabindex="0"',
$pagination
);
}
// =============================================================================
// MODIFY ADMINBAR
// =============================================================================
/**
* Adds 'Add Chapter' link to adminbar with pre-assigned chapter story
*
* @since 5.9.3
*
* @param WP_Admin_Bar $wp_admin_bar The WP_Admin_Bar instance, passed by reference.
*/
function fictioneer_adminbar_add_chapter_link( $wp_admin_bar ) {
if ( ( is_single() && get_post_type() === 'fcn_story' ) || ( is_admin() && get_current_screen()->id === 'fcn_story' ) ) {
$story_id = get_the_ID();
$story_post = get_post( $story_id );
if ( $story_id && $story_post->post_author == get_current_user_id() ) {
$wp_admin_bar->add_node(
array(
'id' => 'fictioneer-add-chapter',
'title' => '<span class="ab-icon dashicons dashicons-text-page" style="top: 4px; font-size: 16px;"></span> ' . __( 'Add Chapter', 'fictioneer' ),
'href' => admin_url( 'post-new.php?post_type=fcn_chapter&story_id=' . $story_id ),
'meta' => array( 'class' => 'adminbar-add-chapter' )
)
);
}
}
}
add_action( 'admin_bar_menu', 'fictioneer_adminbar_add_chapter_link', 99 );
2024-03-04 02:27:07 +01:00
// =============================================================================
// CUSTOMIZATION
// =============================================================================
/**
* Adds '--this-flip' (0|1) to card style attribute
*
* @since 5.12.1
*
* @param array $attributes Card attributes to be rendered.
*
* @return array Updated attributes.
*/
function fictioneer_add_flip_property_to_cards( $attributes ) {
$attributes['style'] = isset( $attributes['style'] ) ? $attributes['style'] : '';
$attributes['style'] .= ' --this-flip: ' . rand( 0, 1 ) * 2 - 1 . ';';
return $attributes;
}
if ( get_theme_mod( 'card_frame', 'default' ) === 'stacked_random' ) {
add_filter( 'fictioneer_filter_card_attributes', 'fictioneer_add_flip_property_to_cards' );
}
// =============================================================================
// SCRIPT TRANSLATIONS
// =============================================================================
/**
* Returns array with translations to be used as JSON
*
* @since 5.12.2
*
* @return array Updated attributes.
*/
function fictioneer_get_js_translations() {
return array(
'notification' => array(
'enterPageNumber' => _x( 'Enter page number:', 'Pagination jump prompt.', 'fictioneer' ),
'slowDown' => _x( 'Slow down.', 'Rate limit reached notification.', 'fictioneer' ),
'error' => _x( 'Error', 'Generic error notification.', 'fictioneer' ),
'checkmarksResynchronized' => __( 'Checkmarks re-synchronized.', 'fictioneer' ),
'remindersResynchronized' => __( 'Reminders re-synchronized.', 'fictioneer' ),
'followsResynchronized' => __( 'Follows re-synchronized.', 'fictioneer' ),
'suggestionAppendedToComment' => __( 'Suggestion appended to comment!<br><a style="font-weight: 700;" href="#comments">Go to comment section.</a>', 'fictioneer' ),
'quoteAppendedToComment' => __( 'Quote appended to comment!<br><a style="font-weight: 700;" href="#comments">Go to comment section.</a>', 'fictioneer' ),
'linkCopiedToClipboard' => __( 'Link copied to clipboard!', 'fictioneer' ),
'copiedToClipboard' => __( 'Copied to clipboard!', 'fictioneer' ),
'oauthEmailTaken' => __( 'The associated email address is already taken. You can link additional accounts in your profile.', 'fictioneer' ),
'oauthAccountAlreadyLinked' => __( 'Account already linked to another profile.', 'fictioneer' ),
'oauthNew' => __( 'Your account has been successfully linked. <strong>Hint:</strong> You can change your display name in your profile and link additional accounts.', 'fictioneer' ),
'oauthAccountLinked' => __( 'Account has been successfully linked.', 'fictioneer' )
)
);
}
/**
* Outputs JSON with translation into the <head>
*
* @since 5.12.2
*/
function fictioneer_output_head_translations() {
echo "<script id='fictioneer-translations' type='text/javascript' data-no-optimize='1' data-no-defer='1' data-no-minify='1'>const fictioneer_tl = " . json_encode( fictioneer_get_js_translations() ) . ";</script>";
}
add_action( 'wp_head', 'fictioneer_output_head_translations' );
2024-04-14 22:56:40 +02:00
// =============================================================================
// STORY REDIRECT
// =============================================================================
/**
* Directs story if a redirect link is set
*
* @since 5.14.0
*/
function fictioneer_redirect_story() {
global $post;
// Abort if...
if ( ! is_single() || get_post_type( $post ) !== 'fcn_story' ) {
return;
}
// Setup
$redirect = get_post_meta( $post->ID ?? 0, 'fictioneer_story_redirect_link', true );
if ( $redirect ) {
wp_redirect( $redirect, 301 );
exit;
}
}
add_action( 'template_redirect', 'fictioneer_redirect_story' );
2024-05-16 15:17:45 +02:00
// =============================================================================
// WP-SIGNUP AND WP-ACTIVATE
2024-05-16 15:17:45 +02:00
// =============================================================================
/**
* Remove default styles of wp-signup.php and wp-activate.php
2024-05-16 15:17:45 +02:00
*
* @since 5.18.1
*/
function fictioneer_remove_mu_registration_styles() {
2024-05-16 15:17:45 +02:00
remove_action( 'wp_head', 'wpmu_signup_stylesheet' );
remove_action( 'wp_head', 'wpmu_activate_stylesheet' );
2024-05-16 15:17:45 +02:00
}
/**
* Output styles for wp-signup.php and wp-activate.php
2024-05-16 15:17:45 +02:00
*
* @since 5.18.1
*/
function fictioneer_output_mu_registration_style() {
2024-05-16 15:17:45 +02:00
// Start HTML ---> ?>
<style type="text/css">
:is(.wp-signup-container, .wp-activate-container) label[for] {
2024-05-16 15:17:45 +02:00
display: block;
color: var(--fg-500);
font-size: var(--fs-xs);
font-weight: var(--font-weight-medium);
padding: 0 0 2px;
}
:is(.wp-signup-container, .wp-activate-container) :where(input[type="text"], input[type="email"], input[type="password"], input[type="tel"]) {
2024-05-16 15:17:45 +02:00
display: block;
width: 100%;
}
:is(.wp-signup-container, .wp-activate-container) p {
margin-bottom: 1.5rem;
}
:is(.wp-signup-container, .wp-activate-container) p[id*="-description"] {
2024-05-16 15:17:45 +02:00
color: var(--fg-900);
font-size: var(--fs-xxs);
line-height: 1.3;
padding: .5rem 2px 0;
}
:is(.wp-signup-container, .wp-activate-container) p[id*="-error"] {
2024-05-16 15:17:45 +02:00
display: flex;
align-items: flex-start;
gap: .5rem;
background: var(--notice-warning-background);
color: var(--notice-warning-color);
font-size: var(--fs-xs);
font-weight: 400;
line-height: 1.3;
letter-spacing: 0;
padding: .5rem;
margin: .5rem 0 1rem;
border-radius: var(--layout-border-radius-small);
}
</style>
<?php // <--- End HTML
}
if ( FICTIONEER_MU_REGISTRATION ) {
add_action( 'wp_head', 'fictioneer_remove_mu_registration_styles', 1 );
add_action( 'wp_head', 'fictioneer_output_mu_registration_style' );
2024-05-16 15:17:45 +02:00
}
2024-06-10 01:54:40 +02:00
// =============================================================================
// ADD LINK TO THEME SETTINGS IN ADMIN BAR
// =============================================================================
/**
* Add theme settings link to admin bar
*
* @since 5.19.1
*
* @param WP_Admin_Bar $wp_admin_bar The WP_Admin_Bar instance, passed by reference.
*/
function fictioneer_adminbar_add_theme_settings_link( $wp_admin_bar ) {
if ( ! current_user_can( 'manage_options' ) || is_admin() ) {
2024-06-10 02:27:09 +02:00
return;
}
2024-06-10 01:54:40 +02:00
$args = array(
'id' => 'fictioneer_theme_settings',
'parent' => 'site-name',
2024-06-10 10:15:44 +02:00
'title' => __( 'Fictioneer', 'fictioneer' ),
2024-06-10 01:54:40 +02:00
'href' => esc_url( admin_url( 'admin.php?page=fictioneer' ) ),
'meta' => array(
2024-06-10 01:55:47 +02:00
'title' => __( 'Fictioneer Theme Settings', 'fictioneer' )
2024-06-10 01:54:40 +02:00
)
);
$wp_admin_bar->add_node( $args );
}
add_action( 'admin_bar_menu', 'fictioneer_adminbar_add_theme_settings_link', 999 );
2024-06-11 21:34:36 +02:00
// =============================================================================
// ELEMENTOR (IF YOU ABSOLUTELY HAVE TO)
// =============================================================================
/**
* Register Elementor locations
*
* @since 5.20.0
*
* @param object $elementor_theme_manager The Elementor manager object.
*/
function fictioneer_elementor_register_locations( $elementor_theme_manager ) {
$elementor_theme_manager->register_location( 'header' );
$elementor_theme_manager->register_location( 'footer' );
$elementor_theme_manager->register_location(
'nav_bar',
array(
'label' => esc_html__( 'Navigation Bar', 'fictioneer' ),
'multiple' => false,
'edit_in_content' => true
)
);
$elementor_theme_manager->register_location(
'nav_menu',
array(
'label' => esc_html__( 'Navigation Menu', 'fictioneer' ),
'multiple' => false,
'edit_in_content' => true
)
);
$elementor_theme_manager->register_location(
'mobile_nav_menu',
array(
'label' => esc_html__( 'Mobile Navigation Menu', 'fictioneer' ),
'multiple' => false,
'edit_in_content' => true
)
);
$elementor_theme_manager->register_location(
'story_header',
array(
'label' => esc_html__( 'Story Header', 'fictioneer' ),
'multiple' => false,
'edit_in_content' => true
)
);
2024-06-14 12:30:50 +02:00
$elementor_theme_manager->register_location(
'page_background',
array(
'label' => esc_html__( 'Page Background', 'fictioneer' ),
'multiple' => false,
'edit_in_content' => false
)
);
2024-06-11 21:34:36 +02:00
}
/**
* Adds override frontend styles for Elementor
*
* @since 5.20.0
*/
function fictioneer_elementor_override_styles() {
2024-06-11 21:34:36 +02:00
// Dummy style
wp_register_style( 'fictioneer-elementor-override', false );
wp_enqueue_style( 'fictioneer-elementor-override', false );
// Setup
$kit_id = get_option( 'elementor_active_kit' );
$css = "body.elementor-kit-{$kit_id} {
2024-06-11 21:34:36 +02:00
--e-global-color-primary: var(--primary-500);
--e-global-color-secondary: var(--fg-300);
--e-global-color-text: var(--fg-500);
--e-global-color-accent: var(--fg-700);
2024-08-07 21:04:23 +02:00
--swiper-pagination-color: var(--fg-700);
--swiper-pagination-bullet-inactive-opacity: .25;
2024-06-11 21:34:36 +02:00
}";
// Output
wp_add_inline_style( 'fictioneer-elementor-override', fictioneer_minify_css( $css ) );
}
add_action(
'wp',
function() {
2024-06-19 22:55:12 +02:00
if ( fictioneer_is_plugin_active( 'elementor/elementor.php' ) ) {
add_action( 'elementor/theme/register_locations', 'fictioneer_elementor_register_locations' );
add_action( 'wp_enqueue_scripts', 'fictioneer_elementor_override_styles', 9999 );
2024-06-11 21:34:36 +02:00
}
}
);
/**
* Adds override editor styles for Elementor
*
* @since 5.20.0
*/
2024-06-11 21:34:36 +02:00
function fictioneer_override_elementor_editor_styles() {
// Dummy style
wp_register_style( 'fictioneer-elementor-editor-override', false );
wp_enqueue_style( 'fictioneer-elementor-editor-override', false );
// Setup
$css = '
body {
--primary-500: ' . fictioneer_get_theme_color( 'light_primary_500' ) . ';
--fg-300: ' . fictioneer_get_theme_color( 'light_fg_300' ) . ';
--fg-500: ' . fictioneer_get_theme_color( 'light_fg_500' ) . ';
--fg-700: ' . fictioneer_get_theme_color( 'light_fg_700' ) . ';
}
.e-global__color[data-global-id="primary"] .e-global__color-preview-color {
background-color: var(--primary-500) !important;
}
.e-global__color[data-global-id="primary"] .e-global__color-title::after {
content: " ' . _x( '(--primary-500)', 'Elementor color override hint.', 'fictioneer' ) . '";
}
.e-global__popover-toggle--active + .pickr .pcr-button[style="--pcr-color: rgba(110, 193, 228, 1);"]::after {
background: var(--primary-500) !important;
}
.e-global__color[data-global-id="secondary"] .e-global__color-preview-color {
background-color: var(--fg-300) !important;
}
.e-global__color[data-global-id="secondary"] .e-global__color-title::after {
content: " ' . _x( '(--fg-300)', 'Elementor color override hint.', 'fictioneer' ) . '";
}
.e-global__popover-toggle--active + .pickr .pcr-button[style="--pcr-color: rgba(84, 89, 95, 1);"]::after {
background: var(--fg-300) !important;
}
.e-global__color[data-global-id="text"] .e-global__color-preview-color {
background-color: var(--fg-500) !important;
}
.e-global__color[data-global-id="text"] .e-global__color-title::after {
content: " ' . _x( '(--fg-500)', 'Elementor color override hint.', 'fictioneer' ) . '";
}
.e-global__popover-toggle--active + .pickr .pcr-button[style="--pcr-color: rgba(122, 122, 122, 1);"]::after {
background: var(--fg-500) !important;
}
.e-global__color[data-global-id="accent"] .e-global__color-preview-color {
background-color: var(--fg-700) !important;
}
.e-global__color[data-global-id="accent"] .e-global__color-title::after {
content: " ' . _x( '(--fg-700)', 'Elementor color override hint.', 'fictioneer' ) . '";
}
.e-global__popover-toggle--active + .pickr .pcr-button[style="--pcr-color: rgba(97, 206, 112, 1);"]::after {
background: var(--fg-700) !important;
}
.e-global__color .e-global__color-hex {
display: none;
}
';
// Output
wp_add_inline_style( 'fictioneer-elementor-editor-override', fictioneer_minify_css( $css ) );
}
add_action( 'elementor/editor/after_enqueue_styles', 'fictioneer_override_elementor_editor_styles', 9999 );
/**
* Adds Fictioneer font group
*
* @since 5.20.0
*
* @param array $groups Array of font groups.
*
* @return array Updated font groups.
*/
function fictioneer_elementor_add_font_group( $groups ) {
$new_groups = array(
'fictioneer' => __( 'Fictioneer', 'fictioneer' )
);
return array_merge( $new_groups, $groups );
}
add_filter( 'elementor/fonts/groups', 'fictioneer_elementor_add_font_group' );
/**
* Adds Fictioneer fonts to font group
*
* @since 5.20.0
*
* @param array $fonts Array of fonts.
*
* @return array Updated fonts.
*/
function fictioneer_elementor_add_additional_fonts( $fonts ) {
$theme_fonts = fictioneer_get_font_data();
foreach ( $theme_fonts as $font ) {
if ( $font['family'] ?? 0 ) {
$fonts[ $font['family'] ] = 'fictioneer';
}
}
return $fonts;
}
add_filter( 'elementor/fonts/additional_fonts', 'fictioneer_elementor_add_additional_fonts' );
// =============================================================================
// GET COLORS JSON
// =============================================================================
/**
* Returns associative array of theme colors
*
* Notes: Considers both parent and child theme.
*
* @since 5.21.2
*
* @return array Associative array of theme colors.
*/
function fictioneer_get_theme_colors_array() {
2024-08-01 19:58:41 +02:00
static $fictioneer_colors = null;
if ( $fictioneer_colors !== null ) {
return $fictioneer_colors;
}
// Setup
$parent_colors = [];
$child_colors = [];
// Get parent theme colors
$parent_colors_file = get_template_directory() . '/includes/colors.json';
if ( file_exists( $parent_colors_file ) ) {
$parent_colors_content = file_get_contents( $parent_colors_file );
$parent_colors = json_decode( $parent_colors_content, true );
if ( ! is_array( $parent_colors ) ) {
$parent_colors = [];
}
}
// Get child theme colors
$child_colors_file = get_stylesheet_directory() . '/includes/colors.json';
if ( file_exists( $child_colors_file ) ) {
$child_colors_content = file_get_contents( $child_colors_file );
$child_colors = json_decode( $child_colors_content, true );
if ( ! is_array( $child_colors ) ) {
$child_colors = [];
}
}
2024-08-01 19:58:41 +02:00
// Update static cache
$fictioneer_colors = array_merge($parent_colors, $child_colors);
// Merge and return colors, child overriding parent
2024-08-01 19:58:41 +02:00
return $fictioneer_colors;
}
2024-08-04 17:43:12 +02:00
// =============================================================================
// CALENDAR BLOCK
// =============================================================================
/**
* Changes the navigation icons of the calendar block
*
* @since 5.22.0
*
* @param string $calendar_output HTML of the calendar block.
*
* @return array Updated HTML of the calendar block.
*/
function fictioneer_modify_calender_nav( $calendar_output ) {
// Replace previous icon
$calendar_output = str_replace( '>&laquo;', '><i class="fa-solid fa-caret-left"></i>', $calendar_output );
// Replace next icon
$calendar_output = str_replace( '&raquo;<', '<i class="fa-solid fa-caret-right"></i><', $calendar_output );
return $calendar_output;
}
add_filter( 'get_calendar', 'fictioneer_modify_calender_nav' );