From 50117a6820b0ac0475e04079f8de112fd07ccc60 Mon Sep 17 00:00:00 2001 From: Maud Leray Date: Fri, 31 May 2024 10:43:46 +0200 Subject: [PATCH] PLANET-7369 Use custom button text setting in Actions List block (#2292) * PLANET-7369 Use custom button text setting in Actions List block This is to replicate the Covers block behaviour --- .../src/blocks/ActionCustomButtonText/edit.js | 15 ++++ .../blocks/ActionCustomButtonText/index.js | 13 +++ assets/src/blocks/ActionsList/index.js | 5 +- .../TakeActionBoxoutEditor.js | 2 +- assets/src/editorIndex.js | 2 + assets/src/js/actions_list_clickable_cards.js | 2 +- assets/src/scss/blocks/ActionsList.scss | 7 +- src/Blocks/ActionButtonText.php | 81 +++++++++++++++++++ src/Loader.php | 2 + 9 files changed, 117 insertions(+), 12 deletions(-) create mode 100644 assets/src/blocks/ActionCustomButtonText/edit.js create mode 100644 assets/src/blocks/ActionCustomButtonText/index.js create mode 100644 src/Blocks/ActionButtonText.php diff --git a/assets/src/blocks/ActionCustomButtonText/edit.js b/assets/src/blocks/ActionCustomButtonText/edit.js new file mode 100644 index 0000000000..19055ed286 --- /dev/null +++ b/assets/src/blocks/ActionCustomButtonText/edit.js @@ -0,0 +1,15 @@ +import {useEntityProp} from '@wordpress/core-data'; + +const {__} = wp.i18n; + +const DEFAULT_TEXT = window.p4_vars.options.take_action_covers_button_text || __('Take action', 'planet4-blocks'); + +export default function Edit({context: {postId}}) { + const [metaFields] = useEntityProp('postType', 'p4_action', 'meta', postId); + + return ( + + ); +} diff --git a/assets/src/blocks/ActionCustomButtonText/index.js b/assets/src/blocks/ActionCustomButtonText/index.js new file mode 100644 index 0000000000..b3e67151d1 --- /dev/null +++ b/assets/src/blocks/ActionCustomButtonText/index.js @@ -0,0 +1,13 @@ +import {registerBlockType} from '@wordpress/blocks'; + +import edit from './edit'; + +export const registerActionButtonTextBlock = () => registerBlockType( + 'planet4-blocks/action-button-text', + { + title: 'Action Button Text', + category: 'planet4-blocks', + description: 'Displays the custom button text for an Action, or the default text if undefined', + usesContext: ['postId'], + edit, + }); diff --git a/assets/src/blocks/ActionsList/index.js b/assets/src/blocks/ActionsList/index.js index 717a4c67e2..ce3bb5a23c 100644 --- a/assets/src/blocks/ActionsList/index.js +++ b/assets/src/blocks/ActionsList/index.js @@ -69,10 +69,7 @@ export const registerActionsListBlock = () => { ['core/post-excerpt'], ]], ['core/group', {className: 'read-more-nav'}, [ - ['core/read-more', { - className: 'btn btn-small btn-primary', - content: __('Take Action', 'planet4-blocks-backend'), - }], + ['planet4-blocks/action-button-text'], ]], ]], ['core/buttons', { diff --git a/assets/src/blocks/TakeActionBoxout/TakeActionBoxoutEditor.js b/assets/src/blocks/TakeActionBoxout/TakeActionBoxoutEditor.js index 0d0a4eafd2..7fd832de9a 100644 --- a/assets/src/blocks/TakeActionBoxout/TakeActionBoxoutEditor.js +++ b/assets/src/blocks/TakeActionBoxout/TakeActionBoxoutEditor.js @@ -23,7 +23,7 @@ import {ImagePlaceholder} from './ImagePlaceholder'; const {__} = wp.i18n; // Planet 4 settings (Planet 4 >> Defaults content >> Take Action Covers default button text). -const DEFAULT_BUTTON_TEXT = window.p4_vars.take_action_covers_button_text || __('Take action', 'planet4-blocks'); +const DEFAULT_BUTTON_TEXT = window.p4_vars.options.take_action_covers_button_text || __('Take action', 'planet4-blocks'); export const TakeActionBoxoutEditor = ({ attributes, diff --git a/assets/src/editorIndex.js b/assets/src/editorIndex.js index 032bf37367..c6c4dd0270 100644 --- a/assets/src/editorIndex.js +++ b/assets/src/editorIndex.js @@ -12,6 +12,7 @@ import {registerTimelineBlock} from './blocks/Timeline/TimelineBlock'; import {registerColumnsBlock} from './blocks/Columns/ColumnsBlock'; import {registerBlockStyles} from './block-styles'; import {registerBlockVariations} from './block-variations'; +import {registerActionButtonTextBlock} from './blocks/ActionCustomButtonText'; wp.domReady(() => { // Make sure to unregister the posts-list native variation before registering planet4-blocks/posts-list @@ -30,6 +31,7 @@ wp.domReady(() => { registerBlockTemplates(); // Beta blocks + registerActionButtonTextBlock(); registerActionsListBlock(); registerPostsListBlock(); diff --git a/assets/src/js/actions_list_clickable_cards.js b/assets/src/js/actions_list_clickable_cards.js index ef4e620bcb..83a5879e6e 100644 --- a/assets/src/js/actions_list_clickable_cards.js +++ b/assets/src/js/actions_list_clickable_cards.js @@ -2,7 +2,7 @@ export const setupClickabelActionsListCards = () => { const liElements = document.querySelectorAll('.actions-list ul li:not(.carousel-li)'); liElements.forEach(li => { - const linkElement = li.querySelector('.wp-block-read-more'); + const linkElement = li.querySelector('.wp-block-post-title > a'); if (linkElement) { const url = linkElement.getAttribute('href'); li.tabIndex = 0; diff --git a/assets/src/scss/blocks/ActionsList.scss b/assets/src/scss/blocks/ActionsList.scss index 1cb4a5a43d..e5517f62b1 100644 --- a/assets/src/scss/blocks/ActionsList.scss +++ b/assets/src/scss/blocks/ActionsList.scss @@ -67,7 +67,7 @@ &:focus { box-shadow: 0 4px 14px rgba(0, 0, 0, .2); - .wp-block-read-more { + .btn-primary { background: var(--button-primary--hover--background); color: var(--button-primary--hover--color, var(--color-text-button--cta)); border: var(--button-primary--hover--border, 1px solid transparent); @@ -133,11 +133,6 @@ font-family: var(--font-family-tertiary); } - .wp-block-group .btn-primary { - margin-bottom: $sp-3; - margin-inline-end: $sp-3; - } - &.is-custom-layout-grid { display: block !important; diff --git a/src/Blocks/ActionButtonText.php b/src/Blocks/ActionButtonText.php new file mode 100644 index 0000000000..3209a2f55d --- /dev/null +++ b/src/Blocks/ActionButtonText.php @@ -0,0 +1,81 @@ +register_action_button_text_block(); + } + + /** + * Register ActionButtonText block. + */ + public function register_action_button_text_block(): void + { + register_block_type( + self::get_full_block_name(), + [ + 'render_callback' => [ $this, 'render_block' ], + ] + ); + } + + /** + * Required by the `Base_Block` class. + * + * @param array $fields Unused, required by the abstract function. + * @phpcs:disable SlevomatCodingStandard.Functions.UnusedParameter.UnusedParameter + */ + public function prepare_data(array $fields): array + { + return []; + } + + /** + * @param array $attributes Block attributes. + * @param string $content Block default content. + * @param WP_Block $block Block instance. + * @return string Returns the value for the field. + * @phpcs:disable SlevomatCodingStandard.Functions.UnusedParameter.UnusedParameter + */ + public function render_block(array $attributes, string $content, WP_Block $block): string + { + $post_id = $block->context['postId']; + $link = get_permalink($post_id); + $meta = get_post_meta($post_id); + if (isset($meta['action_button_text']) && $meta['action_button_text'][0]) { + $button_text = $meta['action_button_text'][0]; + } else { + $options = get_option('planet4_options'); + $button_text = $options['take_action_covers_button_text'] ?? __('Take action', 'planet4-blocks'); + } + return '' . $button_text . ''; + } + // @phpcs:enable SlevomatCodingStandard.Functions.UnusedParameter.UnusedParameter +} diff --git a/src/Loader.php b/src/Loader.php index 8b67c37968..683f9f6a79 100644 --- a/src/Loader.php +++ b/src/Loader.php @@ -215,6 +215,8 @@ public static function add_blocks(): void return; } + new Blocks\ActionButtonText();//NOSONAR + Blocks\QueryLoopExtension::registerHooks(); add_filter( 'allowed_block_types_all',