Commit realizado el 12:13:52 08-04-2024
This commit is contained in:
747
wp-content/plugins/web-stories/includes/Admin/Customizer.php
Normal file
747
wp-content/plugins/web-stories/includes/Admin/Customizer.php
Normal file
@@ -0,0 +1,747 @@
|
||||
<?php
|
||||
/**
|
||||
* Class Customizer
|
||||
*
|
||||
* @link https://github.com/googleforcreators/web-stories-wp
|
||||
*
|
||||
* @copyright 2020 Google LLC
|
||||
* @license https://www.apache.org/licenses/LICENSE-2.0 Apache License 2.0
|
||||
*/
|
||||
|
||||
/**
|
||||
* Copyright 2020 Google LLC
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* https://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
declare(strict_types = 1);
|
||||
|
||||
namespace Google\Web_Stories\Admin;
|
||||
|
||||
use Google\Web_Stories\Infrastructure\Conditional;
|
||||
use Google\Web_Stories\Service_Base;
|
||||
use Google\Web_Stories\Settings;
|
||||
use Google\Web_Stories\Stories_Script_Data;
|
||||
use Google\Web_Stories\Story_Post_Type;
|
||||
use Google\Web_Stories\Story_Query;
|
||||
use WP_Customize_Manager;
|
||||
use WP_Customize_Setting;
|
||||
use WP_Error;
|
||||
|
||||
/**
|
||||
* Class customizer settings.
|
||||
*
|
||||
* @SuppressWarnings(PHPMD.ExcessiveClassComplexity)
|
||||
*
|
||||
* @phpstan-type ThemeSupport array{
|
||||
* customizer: array{
|
||||
* view_type: array{default: string, enabled: string[]},
|
||||
* title: array{default: bool, enabled: bool},
|
||||
* excerpt: array{default: bool, enabled: bool},
|
||||
* author: array{default: bool, enabled: bool},
|
||||
* date: array{default: bool, enabled: bool},
|
||||
* show_archive_link: array{default: bool, enabled: bool},
|
||||
* archive_link: array{default: bool|string, enabled: bool|string, label: string},
|
||||
* sharp_corners: array{default: bool, enabled: bool},
|
||||
* order: array{default: string},
|
||||
* orderby: array{default: string},
|
||||
* circle_size: array{default: int},
|
||||
* number_of_stories: array{default: int},
|
||||
* number_of_columns: array{default: int},
|
||||
* image_alignment: array{default: string}
|
||||
* }
|
||||
* }
|
||||
*
|
||||
* @phpstan-type StoryAttributes array{
|
||||
* view_type?: string,
|
||||
* number_of_columns?: int,
|
||||
* show_title?: bool,
|
||||
* show_author?: bool,
|
||||
* show_date?: bool,
|
||||
* show_archive_link?: bool|string,
|
||||
* show_excerpt?: bool,
|
||||
* image_alignment?: string,
|
||||
* class?: string,
|
||||
* show_stories?: bool|string,
|
||||
* archive_link_label?: string,
|
||||
* circle_size?: int,
|
||||
* sharp_corners?: bool,
|
||||
* order?: string,
|
||||
* orderby?: string,
|
||||
* number_of_stories?: int
|
||||
* }
|
||||
*/
|
||||
class Customizer extends Service_Base implements Conditional {
|
||||
|
||||
/**
|
||||
* Customizer section slug.
|
||||
*
|
||||
* @since 1.5.0
|
||||
*/
|
||||
public const SECTION_SLUG = 'web_story_options';
|
||||
|
||||
/**
|
||||
* Customizer web stories options key.
|
||||
*
|
||||
* @since 1.5.0
|
||||
*/
|
||||
public const STORY_OPTION = 'web_stories_customizer_settings';
|
||||
|
||||
/**
|
||||
* WP_Customize_Manager instance.
|
||||
*
|
||||
* @since 1.5.0
|
||||
*
|
||||
* @var WP_Customize_Manager $wp_customize WP_Customize_Manager instance.
|
||||
*/
|
||||
private WP_Customize_Manager $wp_customize;
|
||||
|
||||
/**
|
||||
* Settings instance.
|
||||
*
|
||||
* @var Settings Settings instance.
|
||||
*/
|
||||
private Settings $settings;
|
||||
|
||||
/**
|
||||
* Story_Post_Type instance.
|
||||
*
|
||||
* @var Story_Post_Type Story_Post_Type instance.
|
||||
*/
|
||||
private Story_Post_Type $story_post_type;
|
||||
|
||||
/**
|
||||
* Stories_Script_Data instance.
|
||||
*
|
||||
* @var Stories_Script_Data Stories_Script_Data instance.
|
||||
*/
|
||||
protected Stories_Script_Data $stories_script_data;
|
||||
|
||||
/**
|
||||
* Analytics constructor.
|
||||
*
|
||||
* @since 1.12.0
|
||||
*
|
||||
* @param Settings $settings Settings instance.
|
||||
* @param Story_Post_Type $story_post_type Story_Post_Type instance.
|
||||
* @param Stories_Script_Data $stories_script_data Stories_Script_Data instance.
|
||||
* @return void
|
||||
*/
|
||||
public function __construct(
|
||||
Settings $settings,
|
||||
Story_Post_Type $story_post_type,
|
||||
Stories_Script_Data $stories_script_data
|
||||
) {
|
||||
$this->settings = $settings;
|
||||
$this->story_post_type = $story_post_type;
|
||||
$this->stories_script_data = $stories_script_data;
|
||||
}
|
||||
|
||||
/**
|
||||
* Initializes the customizer logic.
|
||||
*
|
||||
* @since 1.5.0
|
||||
*/
|
||||
public function register(): void {
|
||||
add_action( 'customize_register', [ $this, 'register_customizer_settings' ] );
|
||||
}
|
||||
|
||||
/**
|
||||
* Check whether the conditional object is currently needed.
|
||||
*
|
||||
* @since 1.16.0
|
||||
*
|
||||
* @return bool Whether the conditional object is needed.
|
||||
*/
|
||||
public static function is_needed(): bool {
|
||||
return ! \function_exists( 'wp_is_block_theme' ) || ! wp_is_block_theme();
|
||||
}
|
||||
|
||||
/**
|
||||
* Registers web stories customizer settings.
|
||||
*
|
||||
* @SuppressWarnings(PHPMD.ExcessiveMethodLength)
|
||||
* @SuppressWarnings(PHPMD.NPathComplexity)
|
||||
* @SuppressWarnings(PHPMD.CyclomaticComplexity)
|
||||
*
|
||||
* @since 1.5.0
|
||||
*
|
||||
* @param WP_Customize_Manager $wp_customize WP_Customize_Manager instance.
|
||||
*/
|
||||
public function register_customizer_settings( WP_Customize_Manager $wp_customize ): void {
|
||||
$this->wp_customize = $wp_customize;
|
||||
|
||||
$theme_support = $this->get_stories_theme_support()['customizer'];
|
||||
|
||||
$active_callback = fn() => $this->is_option_enabled( 'show_stories' );
|
||||
|
||||
$wp_customize->add_section(
|
||||
self::SECTION_SLUG,
|
||||
[
|
||||
'title' => esc_html__( 'Web Stories', 'web-stories' ),
|
||||
'theme_supports' => 'web-stories',
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[show_stories]',
|
||||
[
|
||||
'default' => false,
|
||||
'type' => 'option',
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[show_stories]',
|
||||
[
|
||||
'type' => 'checkbox',
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Display stories', 'web-stories' ),
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[view_type]',
|
||||
[
|
||||
'default' => $theme_support['view_type']['default'],
|
||||
'type' => 'option',
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[view_type]',
|
||||
[
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => _x( 'View Type', 'noun', 'web-stories' ),
|
||||
'type' => 'select',
|
||||
'choices' => $this->get_view_type_choices( $theme_support['view_type']['enabled'] ),
|
||||
'active_callback' => $active_callback,
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[number_of_stories]',
|
||||
[
|
||||
'default' => $theme_support['number_of_stories']['default'],
|
||||
'type' => 'option',
|
||||
'validate_callback' => [ $this, 'validate_number_of_stories' ],
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[number_of_stories]',
|
||||
[
|
||||
'type' => 'number',
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Number of Stories', 'web-stories' ),
|
||||
'input_attrs' => [
|
||||
'min' => 1,
|
||||
'max' => 20,
|
||||
],
|
||||
'active_callback' => $active_callback,
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[number_of_columns]',
|
||||
[
|
||||
'default' => $theme_support['number_of_columns']['default'],
|
||||
'type' => 'option',
|
||||
'validate_callback' => [ $this, 'validate_number_of_columns' ],
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[number_of_columns]',
|
||||
[
|
||||
'type' => 'number',
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Number of Columns', 'web-stories' ),
|
||||
'input_attrs' => [
|
||||
'min' => 1,
|
||||
'max' => 4,
|
||||
],
|
||||
'active_callback' => fn() => ( $this->is_option_enabled( 'show_stories' ) && $this->is_view_type( 'grid' ) ),
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[orderby]',
|
||||
[
|
||||
'default' => $theme_support['orderby']['default'],
|
||||
'type' => 'option',
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[orderby]',
|
||||
[
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Order By', 'web-stories' ),
|
||||
'type' => 'select',
|
||||
'choices' => [
|
||||
'post_title' => __( 'Title', 'web-stories' ),
|
||||
'post_date' => __( 'Date', 'web-stories' ),
|
||||
],
|
||||
'active_callback' => $active_callback,
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[order]',
|
||||
[
|
||||
'default' => $theme_support['order']['default'],
|
||||
'type' => 'option',
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[order]',
|
||||
[
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Order', 'web-stories' ),
|
||||
'type' => 'select',
|
||||
'choices' => [
|
||||
'ASC' => __( 'Ascending', 'web-stories' ),
|
||||
'DESC' => __( 'Descending', 'web-stories' ),
|
||||
],
|
||||
'active_callback' => $active_callback,
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[circle_size]',
|
||||
[
|
||||
'default' => $theme_support['circle_size']['default'],
|
||||
'type' => 'option',
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[circle_size]',
|
||||
[
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Circle Size', 'web-stories' ),
|
||||
'type' => 'number',
|
||||
'input_attrs' => [
|
||||
'min' => 80,
|
||||
'max' => 200,
|
||||
'step' => 5,
|
||||
],
|
||||
'active_callback' => fn() => $this->is_option_enabled( 'show_stories' ) && $this->is_view_type( 'circles' ),
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[image_alignment]',
|
||||
[
|
||||
'type' => 'option',
|
||||
'default' => $theme_support['image_alignment']['default'],
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[image_alignment]',
|
||||
[
|
||||
'type' => 'radio',
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Image Alignment', 'web-stories' ),
|
||||
'choices' => [
|
||||
'left' => __( 'Left', 'web-stories' ),
|
||||
'right' => __( 'Right', 'web-stories' ),
|
||||
],
|
||||
'active_callback' => fn() => ( $this->is_option_enabled( 'show_stories' ) && $this->is_view_type( 'list' ) ),
|
||||
]
|
||||
);
|
||||
|
||||
if ( $theme_support['title']['enabled'] ) {
|
||||
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[show_title]',
|
||||
[
|
||||
'default' => $theme_support['title']['default'],
|
||||
'type' => 'option',
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[show_title]',
|
||||
[
|
||||
'type' => 'checkbox',
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Display Title', 'web-stories' ),
|
||||
'active_callback' => $active_callback,
|
||||
]
|
||||
);
|
||||
}
|
||||
|
||||
if ( $theme_support['excerpt']['enabled'] ) {
|
||||
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[show_excerpt]',
|
||||
[
|
||||
'default' => $theme_support['excerpt']['default'],
|
||||
'type' => 'option',
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[show_excerpt]',
|
||||
[
|
||||
'type' => 'checkbox',
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Display Excerpt', 'web-stories' ),
|
||||
'active_callback' => fn() => $this->is_option_enabled( 'show_stories' ) && $this->is_view_type( 'list' ),
|
||||
]
|
||||
);
|
||||
}
|
||||
|
||||
if ( $theme_support['author']['enabled'] ) {
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[show_author]',
|
||||
[
|
||||
'default' => $theme_support['author']['default'],
|
||||
'type' => 'option',
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[show_author]',
|
||||
[
|
||||
'type' => 'checkbox',
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Display Author', 'web-stories' ),
|
||||
'active_callback' => fn() => ( $this->is_option_enabled( 'show_stories' ) && ! $this->is_view_type( 'circles' ) ),
|
||||
]
|
||||
);
|
||||
}
|
||||
|
||||
if ( $theme_support['date']['enabled'] ) {
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[show_date]',
|
||||
[
|
||||
'default' => $theme_support['date']['default'],
|
||||
'type' => 'option',
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[show_date]',
|
||||
[
|
||||
'type' => 'checkbox',
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Display Date', 'web-stories' ),
|
||||
'active_callback' => fn() => ( $this->is_option_enabled( 'show_stories' ) && ! $this->is_view_type( 'circles' ) ),
|
||||
]
|
||||
);
|
||||
}
|
||||
|
||||
if ( $theme_support['sharp_corners']['enabled'] ) {
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[sharp_corners]',
|
||||
[
|
||||
'default' => $theme_support['sharp_corners']['default'],
|
||||
'type' => 'option',
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[sharp_corners]',
|
||||
[
|
||||
'type' => 'checkbox',
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Sharp Corners', 'web-stories' ),
|
||||
'active_callback' => fn() => ( $this->is_option_enabled( 'show_stories' ) && ! $this->is_view_type( 'circles' ) ),
|
||||
]
|
||||
);
|
||||
}
|
||||
|
||||
if ( $theme_support['archive_link']['enabled'] ) {
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[show_archive_link]',
|
||||
[
|
||||
'default' => $theme_support['archive_link']['default'],
|
||||
'type' => 'option',
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[show_archive_link]',
|
||||
[
|
||||
'type' => 'checkbox',
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Display Archive Link', 'web-stories' ),
|
||||
'active_callback' => $active_callback,
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_setting(
|
||||
self::STORY_OPTION . '[archive_link_label]',
|
||||
[
|
||||
'type' => 'option',
|
||||
'default' => $theme_support['archive_link']['label'],
|
||||
]
|
||||
);
|
||||
|
||||
$wp_customize->add_control(
|
||||
self::STORY_OPTION . '[archive_link_label]',
|
||||
[
|
||||
'type' => 'text',
|
||||
'section' => self::SECTION_SLUG,
|
||||
'label' => __( 'Archive Link Label', 'web-stories' ),
|
||||
'active_callback' => fn() => ( $this->is_option_enabled( 'show_stories' ) && $this->is_option_enabled( 'show_archive_link' ) ),
|
||||
]
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Validates the number of story setting value.
|
||||
*
|
||||
* @since 1.5.0
|
||||
*
|
||||
* @param WP_Error $validity WP_Error object.
|
||||
* @param int $value Value to be validated.
|
||||
*/
|
||||
public function validate_number_of_stories( WP_Error $validity, int $value ): WP_Error {
|
||||
$value = (int) $value;
|
||||
|
||||
if ( $value <= 0 || $value > 20 ) {
|
||||
$validity->add( 'invalid_number', __( 'The number of stories must be between 1 and 20.', 'web-stories' ) );
|
||||
}
|
||||
return $validity;
|
||||
}
|
||||
|
||||
/**
|
||||
* Validates the number of columns setting value.
|
||||
*
|
||||
* @since 1.5.0
|
||||
*
|
||||
* @param WP_Error $validity WP_Error object.
|
||||
* @param int $value Value to be validated.
|
||||
*/
|
||||
public function validate_number_of_columns( WP_Error $validity, int $value ): WP_Error {
|
||||
$value = (int) $value;
|
||||
|
||||
if ( $value <= 0 || $value > 5 ) {
|
||||
$validity->add( 'invalid_number', __( 'The number of columns must be between 1 and 4.', 'web-stories' ) );
|
||||
}
|
||||
return $validity;
|
||||
}
|
||||
|
||||
/**
|
||||
* Renders web stories based on the customizer selected options.
|
||||
*
|
||||
* @SuppressWarnings(PHPMD.NPathComplexity)
|
||||
* @SuppressWarnings(PHPMD.CyclomaticComplexity)
|
||||
*
|
||||
* @since 1.5.0
|
||||
*/
|
||||
public function render_stories(): string {
|
||||
/**
|
||||
* Render options.
|
||||
*
|
||||
* @var array<string,string|bool> $options
|
||||
* @phpstan-var StoryAttributes
|
||||
*/
|
||||
$options = (array) $this->settings->get_setting( self::STORY_OPTION );
|
||||
|
||||
if ( empty( $options['show_stories'] ) || true !== $options['show_stories'] ) {
|
||||
return '';
|
||||
}
|
||||
|
||||
$theme_support = $this->get_stories_theme_support()['customizer'];
|
||||
|
||||
$story_attributes = [
|
||||
'view_type' => $options['view_type'] ?? $theme_support['view_type']['default'],
|
||||
'show_title' => isset( $options['show_title'] ) ? (bool) $options['show_title'] : $theme_support['title']['default'],
|
||||
'show_excerpt' => isset( $options['show_excerpt'] ) ? (bool) $options['show_excerpt'] : $theme_support['excerpt']['default'],
|
||||
'show_author' => isset( $options['show_author'] ) ? (bool) $options['show_author'] : $theme_support['author']['default'],
|
||||
'show_date' => isset( $options['show_date'] ) ? (bool) $options['show_date'] : $theme_support['date']['default'],
|
||||
'show_archive_link' => isset( $options['show_archive_link'] ) ? (bool) $options['show_archive_link'] : $theme_support['archive_link']['default'],
|
||||
'archive_link_label' => isset( $options['archive_link_label'] ) ? (string) $options['archive_link_label'] : $theme_support['archive_link']['label'],
|
||||
'circle_size' => isset( $options['circle_size'] ) ? (int) $options['circle_size'] : $theme_support['circle_size']['default'],
|
||||
'sharp_corners' => isset( $options['sharp_corners'] ) ? (bool) $options['sharp_corners'] : $theme_support['sharp_corners']['default'],
|
||||
'image_alignment' => isset( $options['image_alignment'] ) ? (string) $options['image_alignment'] : $theme_support['image_alignment']['default'],
|
||||
'number_of_columns' => isset( $options['number_of_columns'] ) ? (int) $options['number_of_columns'] : $theme_support['number_of_columns']['default'],
|
||||
'class' => 'web-stories-list--customizer',
|
||||
];
|
||||
|
||||
$query_arguments = [
|
||||
'posts_per_page' => isset( $options['number_of_stories'] ) ? (int) $options['number_of_stories'] : $theme_support['number_of_stories']['default'], // phpcs:ignore WordPress.WP.PostsPerPage.posts_per_page_posts_per_page
|
||||
'orderby' => isset( $options['orderby'] ) ? (string) $options['orderby'] : $theme_support['orderby']['default'],
|
||||
'order' => isset( $options['order'] ) ? (string) $options['order'] : $theme_support['order']['default'],
|
||||
];
|
||||
|
||||
return ( new Story_Query( $story_attributes, $query_arguments ) )->render();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get theme support configuration.
|
||||
*
|
||||
* @since 1.14.0
|
||||
*
|
||||
* @return array Theme support configuration
|
||||
*
|
||||
* @phpstan-return ThemeSupport
|
||||
*/
|
||||
public function get_stories_theme_support(): array {
|
||||
/**
|
||||
* Theme support configuration.
|
||||
*
|
||||
* @var ThemeSupport[]|array<int, false> $support
|
||||
*/
|
||||
$support = get_theme_support( 'web-stories' );
|
||||
$support = isset( $support[0] ) && \is_array( $support[0] ) ? $support[0] : [];
|
||||
|
||||
$has_archive = (bool) $this->story_post_type->get_has_archive();
|
||||
|
||||
$default_support = [
|
||||
'customizer' => [
|
||||
'view_type' => [
|
||||
'enabled' => [ 'circles' ],
|
||||
'default' => 'circles',
|
||||
],
|
||||
'title' => [
|
||||
'enabled' => true,
|
||||
'default' => true,
|
||||
],
|
||||
'excerpt' => [
|
||||
'enabled' => true,
|
||||
'default' => false,
|
||||
],
|
||||
'author' => [
|
||||
'enabled' => true,
|
||||
'default' => true,
|
||||
],
|
||||
'date' => [
|
||||
'enabled' => false,
|
||||
'default' => false,
|
||||
],
|
||||
'archive_link' => [
|
||||
'enabled' => $has_archive,
|
||||
'default' => $has_archive,
|
||||
'label' => __( 'View all stories', 'web-stories' ),
|
||||
],
|
||||
'sharp_corners' => [
|
||||
'enabled' => false,
|
||||
'default' => false,
|
||||
],
|
||||
'order' => [
|
||||
'default' => 'DESC',
|
||||
],
|
||||
'orderby' => [
|
||||
'default' => 'post_date',
|
||||
],
|
||||
'circle_size' => [
|
||||
'default' => 150,
|
||||
],
|
||||
'number_of_stories' => [
|
||||
'default' => 10,
|
||||
],
|
||||
'number_of_columns' => [
|
||||
'default' => 2,
|
||||
],
|
||||
'image_alignment' => [
|
||||
'default' => is_rtl() ? 'right' : 'left',
|
||||
],
|
||||
],
|
||||
];
|
||||
|
||||
/**
|
||||
* Theme support config.
|
||||
*
|
||||
* @var ThemeSupport $support
|
||||
*/
|
||||
$support = $this->parse_args( $support, $default_support );
|
||||
|
||||
return $support;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the view type choices.
|
||||
*
|
||||
* @since 1.5.0
|
||||
*
|
||||
* @param array<string,mixed> $view_type View type to check.
|
||||
* @return array<string,mixed> An array of view type choices.
|
||||
*/
|
||||
private function get_view_type_choices( array $view_type ): array {
|
||||
$view_type_choices = $this->stories_script_data->get_layouts();
|
||||
|
||||
if ( empty( $view_type ) ) {
|
||||
return $view_type_choices;
|
||||
}
|
||||
|
||||
return array_intersect_key( $view_type_choices, array_fill_keys( $view_type, true ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Checks whether the given option is enabled or not.
|
||||
*
|
||||
* @since 1.5.0
|
||||
*
|
||||
* @param string $option_name The name of the option to check.
|
||||
* @return bool Returns true if the given option is enabled otherwise false.
|
||||
*/
|
||||
private function is_option_enabled( string $option_name ): bool {
|
||||
$setting = $this->wp_customize->get_setting( self::STORY_OPTION . "[{$option_name}]" );
|
||||
return ( $setting instanceof WP_Customize_Setting && true === $setting->value() );
|
||||
}
|
||||
|
||||
/**
|
||||
* Verifies the current view type.
|
||||
*
|
||||
* @since 1.5.0
|
||||
*
|
||||
* @param string $view_type View type to check.
|
||||
* @return bool Whether or not current view type matches the one passed.
|
||||
*/
|
||||
private function is_view_type( string $view_type ): bool {
|
||||
$setting = $this->wp_customize->get_setting( self::STORY_OPTION . '[view_type]' );
|
||||
return ( $setting instanceof WP_Customize_Setting && $view_type === $setting->value() );
|
||||
}
|
||||
|
||||
/**
|
||||
* Merges user defined arguments into defaults array.
|
||||
*
|
||||
* Like wp_parse_args(), but recursive.
|
||||
*
|
||||
* @since 1.14.0
|
||||
*
|
||||
* @see wp_parse_args()
|
||||
*
|
||||
* @param array<string, mixed> $args Value to merge with $defaults.
|
||||
* @param array<string, array<string, array<string, array<int,string>|bool|int|string>>> $defaults Optional. Array that serves as the defaults. Default empty array.
|
||||
* @return array<string, mixed> Merged user defined values with defaults.
|
||||
*/
|
||||
private function parse_args( array $args, array $defaults = [] ): array {
|
||||
$parsed_args = $defaults;
|
||||
|
||||
foreach ( $args as $key => $value ) {
|
||||
if ( \is_array( $value ) && isset( $parsed_args[ $key ] ) ) {
|
||||
/**
|
||||
* Default value.
|
||||
*
|
||||
* @var array<string, array<string, array<string, array<int,string>|bool|int|string>>> $def
|
||||
*/
|
||||
$def = $parsed_args[ $key ];
|
||||
$parsed_args[ $key ] = $this->parse_args( $value, $def );
|
||||
} else {
|
||||
$parsed_args[ $key ] = $value;
|
||||
}
|
||||
}
|
||||
|
||||
return $parsed_args;
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user