diff --git a/projects/plugins/jetpack/changelog/update-ai-logo-generator-improve-extension-availability-check b/projects/plugins/jetpack/changelog/update-ai-logo-generator-improve-extension-availability-check new file mode 100644 index 0000000000000..1072f17dc400a --- /dev/null +++ b/projects/plugins/jetpack/changelog/update-ai-logo-generator-improve-extension-availability-check @@ -0,0 +1,4 @@ +Significance: patch +Type: other + +AI Logo Generator: only extend the logo block when the AI Assistant is available and not hidden on the editor. diff --git a/projects/plugins/jetpack/extensions/extended-blocks/core-site-logo/index.tsx b/projects/plugins/jetpack/extensions/extended-blocks/core-site-logo/index.tsx index 0fe0f9091e78d..d97f0a50f2207 100644 --- a/projects/plugins/jetpack/extensions/extended-blocks/core-site-logo/index.tsx +++ b/projects/plugins/jetpack/extensions/extended-blocks/core-site-logo/index.tsx @@ -3,8 +3,9 @@ */ import { GeneratorModal } from '@automattic/jetpack-ai-client'; import { BlockControls } from '@wordpress/block-editor'; +import { getBlockType } from '@wordpress/blocks'; import { createHigherOrderComponent } from '@wordpress/compose'; -import { useDispatch, useSelect } from '@wordpress/data'; +import { useDispatch, useSelect, select } from '@wordpress/data'; import { useCallback, useEffect, useState } from '@wordpress/element'; import { addFilter } from '@wordpress/hooks'; /* @@ -69,8 +70,8 @@ const useSetLogo = () => { }; const useSiteDetails = () => { - const siteSettings = useSelect( select => { - return ( select( 'core' ) as CoreSelect ).getEntityRecord( 'root', 'site' ); + const siteSettings = useSelect( selectData => { + return ( selectData( 'core' ) as CoreSelect ).getEntityRecord( 'root', 'site' ); }, [] ); return { @@ -137,21 +138,54 @@ const siteLogoEditWithAiComponents = createHigherOrderComponent( BlockEdit => { }, 'SiteLogoEditWithAiComponents' ); /** - * Function to override the core Site Logo block edit settings. - * Will create a HOC to use as the edit implementation. + * Function to check if the block can be extended. * - * @param {object} settings - The block settings. * @param {string} name - The block name. - * @returns {object} The new block settings. + * @returns {boolean} True if the block can be extended. */ -function jetpackSiteLogoWithAiSupport( settings, name: string ) { - // Only extend the core Site Logo block. +function canExtendBlock( name: string ): boolean { if ( name !== 'core/site-logo' ) { - return settings; + return false; + } + + // Check if the AI Assistant block is registered. If not, we understand that Jetpack AI is not active. + const isAIAssistantBlockRegistered = getBlockType( 'jetpack/ai-assistant' ); + + if ( ! isAIAssistantBlockRegistered ) { + return false; } // Disable if the feature is not available. if ( ! getFeatureAvailability( SITE_LOGO_BLOCK_AI_EXTENSION ) ) { + return false; + } + + /* + * Do not extend if the AI Assistant block is hidden, + * as a way for the user to hide the extension. + * TODO: the `editPostStore` is undefined for P2 sites. + * Let's find a way to check if the block is hidden there. + */ + const { getHiddenBlockTypes } = select( 'core/edit-post' ) || {}; + const hiddenBlocks = getHiddenBlockTypes?.() || []; // It will extend the block if the function is undefined + + if ( hiddenBlocks.includes( 'jetpack/ai-assistant' ) ) { + return false; + } + + return true; +} + +/** + * Function to override the core Site Logo block edit settings. + * Will create a HOC to use as the edit implementation. + * + * @param {object} settings - The block settings. + * @param {string} name - The block name. + * @returns {object} The new block settings. + */ +function jetpackSiteLogoWithAiSupport( settings, name: string ) { + if ( ! canExtendBlock( name ) ) { return settings; } diff --git a/projects/plugins/wpcomsh/changelog/update-ai-logo-generator-improve-extension-availability-check b/projects/plugins/wpcomsh/changelog/update-ai-logo-generator-improve-extension-availability-check new file mode 100644 index 0000000000000..2b86d65fe2c9a --- /dev/null +++ b/projects/plugins/wpcomsh/changelog/update-ai-logo-generator-improve-extension-availability-check @@ -0,0 +1,5 @@ +Significance: patch +Type: changed +Comment: Just bumping versions to comply with changelogger checks. + + diff --git a/projects/plugins/wpcomsh/composer.json b/projects/plugins/wpcomsh/composer.json index 2a274920f23ce..3b3f7dec0adea 100644 --- a/projects/plugins/wpcomsh/composer.json +++ b/projects/plugins/wpcomsh/composer.json @@ -128,7 +128,7 @@ "composer/installers": true, "roots/wordpress-core-installer": true }, - "autoloader-suffix": "26841ac2064774301cbe06d174833bfc_wpcomshⓥ5_1_1" + "autoloader-suffix": "26841ac2064774301cbe06d174833bfc_wpcomshⓥ5_1_2_alpha" }, "extra": { "mirror-repo": "Automattic/wpcom-site-helper", diff --git a/projects/plugins/wpcomsh/package.json b/projects/plugins/wpcomsh/package.json index de9cd4ef2f088..7b7b61907ef5d 100644 --- a/projects/plugins/wpcomsh/package.json +++ b/projects/plugins/wpcomsh/package.json @@ -3,7 +3,7 @@ "name": "@automattic/jetpack-wpcomsh", "description": "A helper for connecting WordPress.com sites to external host infrastructure.", "homepage": "https://jetpack.com", - "version": "5.1.1", + "version": "5.1.2-alpha", "bugs": { "url": "https://github.com/Automattic/jetpack/labels/[Plugin] Wpcomsh" }, diff --git a/projects/plugins/wpcomsh/wpcomsh.php b/projects/plugins/wpcomsh/wpcomsh.php index b152dbeed752b..377e08b2a8344 100644 --- a/projects/plugins/wpcomsh/wpcomsh.php +++ b/projects/plugins/wpcomsh/wpcomsh.php @@ -2,14 +2,14 @@ /** * Plugin Name: WordPress.com Site Helper * Description: A helper for connecting WordPress.com sites to external host infrastructure. - * Version: 5.1.1 + * Version: 5.1.2-alpha * Author: Automattic * Author URI: http://automattic.com/ * * @package wpcomsh */ -define( 'WPCOMSH_VERSION', '5.1.1' ); +define( 'WPCOMSH_VERSION', '5.1.2-alpha' ); // If true, Typekit fonts will be available in addition to Google fonts add_filter( 'jetpack_fonts_enable_typekit', '__return_true' );