diff --git a/projects/plugins/jetpack/changelog/fix-blogroll-block-unhelpful-error-when-user-not-connected b/projects/plugins/jetpack/changelog/fix-blogroll-block-unhelpful-error-when-user-not-connected new file mode 100644 index 0000000000000..7c5157e9f931c --- /dev/null +++ b/projects/plugins/jetpack/changelog/fix-blogroll-block-unhelpful-error-when-user-not-connected @@ -0,0 +1,4 @@ +Significance: patch +Type: other + +Show connection nudge instead of error if user is not connected on blogroll block diff --git a/projects/plugins/jetpack/extensions/blocks/ai-assistant/components/connect-prompt/index.tsx b/projects/plugins/jetpack/extensions/blocks/ai-assistant/components/connect-prompt/index.tsx deleted file mode 100644 index a09c7e233010d..0000000000000 --- a/projects/plugins/jetpack/extensions/blocks/ai-assistant/components/connect-prompt/index.tsx +++ /dev/null @@ -1,35 +0,0 @@ -/* - * External dependencies - */ -import { __ } from '@wordpress/i18n'; -/* - * Internal dependencies - */ -import { Nudge } from '../../../../shared/components/upgrade-nudge'; -import useAutosaveAndRedirect from '../../../../shared/use-autosave-and-redirect'; - -const ConnectPrompt = () => { - const checkoutUrl = `${ window?.Jetpack_Editor_Initial_State?.adminUrl }admin.php?page=my-jetpack#/connection`; - const { autosaveAndRedirect, isRedirecting } = useAutosaveAndRedirect( checkoutUrl ); - - const goToCheckoutPage = event => { - autosaveAndRedirect( event ); - }; - - return ( - - ); -}; - -export default ConnectPrompt; diff --git a/projects/plugins/jetpack/extensions/blocks/ai-assistant/edit.js b/projects/plugins/jetpack/extensions/blocks/ai-assistant/edit.js index eecedd8f92044..d56d949833921 100644 --- a/projects/plugins/jetpack/extensions/blocks/ai-assistant/edit.js +++ b/projects/plugins/jetpack/extensions/blocks/ai-assistant/edit.js @@ -26,8 +26,8 @@ import clsx from 'clsx'; */ import UsagePanel from '../../plugins/ai-assistant-plugin/components/usage-panel'; import { USAGE_PANEL_PLACEMENT_BLOCK_SETTINGS_SIDEBAR } from '../../plugins/ai-assistant-plugin/components/usage-panel/types'; +import ConnectBanner from '../../shared/components/connect-banner'; import { PLAN_TYPE_FREE, PLAN_TYPE_UNLIMITED, usePlanType } from '../../shared/use-plan-type'; -import ConnectPrompt from './components/connect-prompt'; import FeedbackControl from './components/feedback-control'; import QuotaExceededMessage, { FairUsageNotice } from './components/quota-exceeded-message'; import ToolbarControls from './components/toolbar-controls'; @@ -305,7 +305,7 @@ export default function AIAssistantEdit( { attributes, setAttributes, clientId, const banner = ( <> { isOverLimit && isSelected && } - { ! connected && } + { ! connected && } ); diff --git a/projects/plugins/jetpack/extensions/blocks/ai-chat/components/nudge-connect/index.js b/projects/plugins/jetpack/extensions/blocks/ai-chat/components/nudge-connect/index.js deleted file mode 100644 index fbf17fc5cf115..0000000000000 --- a/projects/plugins/jetpack/extensions/blocks/ai-chat/components/nudge-connect/index.js +++ /dev/null @@ -1,39 +0,0 @@ -/* - * External dependencies - */ -import { __ } from '@wordpress/i18n'; -/* - * Internal dependencies - */ -import { Nudge } from '../../../../shared/components/upgrade-nudge'; -import useAutosaveAndRedirect from '../../../../shared/use-autosave-and-redirect'; - -const ConnectPrompt = () => { - const connectUrl = `${ window?.Jetpack_Editor_Initial_State?.adminUrl }admin.php?page=my-jetpack#/connection`; - const { autosaveAndRedirect, isRedirecting } = useAutosaveAndRedirect( connectUrl ); - - if ( window?.Jetpack_Editor_Initial_State?.jetpack?.is_current_user_connected ) { - return null; - } - - const goToCheckoutPage = event => { - autosaveAndRedirect( event ); - }; - - return ( - - ); -}; - -export default ConnectPrompt; diff --git a/projects/plugins/jetpack/extensions/blocks/ai-chat/edit.js b/projects/plugins/jetpack/extensions/blocks/ai-chat/edit.js index 57f0626191e8e..4b5125ba9f892 100644 --- a/projects/plugins/jetpack/extensions/blocks/ai-chat/edit.js +++ b/projects/plugins/jetpack/extensions/blocks/ai-chat/edit.js @@ -12,7 +12,7 @@ import { useSelect } from '@wordpress/data'; * Internal dependencies */ import './editor.scss'; -import ConnectPrompt from './components/nudge-connect'; +import ConnectBanner from '../../shared/components/connect-banner'; import EnableJetpackSearchPrompt from './components/nudge-enable-search'; import { DEFAULT_ASK_BUTTON_LABEL, DEFAULT_PLACEHOLDER } from './constants'; import { AiChatControls } from './controls'; @@ -34,7 +34,7 @@ export default function Edit( { attributes, setAttributes, clientId } ) { ); return (
- +
+ + + ); + } + const errorMessage = recommendationsErrorMessage || subscriptionsErrorMessage; return ( diff --git a/projects/plugins/jetpack/extensions/shared/components/connect-banner/index.tsx b/projects/plugins/jetpack/extensions/shared/components/connect-banner/index.tsx new file mode 100644 index 0000000000000..4c8852eb44554 --- /dev/null +++ b/projects/plugins/jetpack/extensions/shared/components/connect-banner/index.tsx @@ -0,0 +1,47 @@ +/* + * External dependencies + */ +import { __ } from '@wordpress/i18n'; +/* + * Internal dependencies + */ +import useAutosaveAndRedirect from '../../use-autosave-and-redirect'; +import { Nudge } from '../upgrade-nudge'; +import type { MouseEvent, FC } from 'react'; + +interface ConnectBannerProps { + explanation?: string; +} + +import './style.scss'; + +const ConnectBanner: FC< ConnectBannerProps > = ( { explanation = null } ) => { + const checkoutUrl = `${ window?.Jetpack_Editor_Initial_State?.adminUrl }admin.php?page=my-jetpack#/connection`; + const { autosaveAndRedirect, isRedirecting } = useAutosaveAndRedirect( checkoutUrl ); + + const goToCheckoutPage = ( event: MouseEvent< HTMLButtonElement > ) => { + autosaveAndRedirect( event ); + }; + + return ( +
+ +
+ { explanation && ( +
+

{ explanation }

+
+ ) } +
+
+ ); +}; + +export default ConnectBanner; diff --git a/projects/plugins/jetpack/extensions/shared/components/connect-banner/style.scss b/projects/plugins/jetpack/extensions/shared/components/connect-banner/style.scss new file mode 100644 index 0000000000000..a1f0a8e82f57c --- /dev/null +++ b/projects/plugins/jetpack/extensions/shared/components/connect-banner/style.scss @@ -0,0 +1,45 @@ +@import '@automattic/jetpack-base-styles/style'; + +.jetpack-connect-banner-nudge { + .jetpack-upgrade-plan-banner__wrapper { + flex-wrap: nowrap; + + &__description { + line-height: 24px; + } + + .components-button.is-primary { + background-color: var( --jp-white ); + color: var( --jp-black ); + margin-top: 8px; + margin-bottom: 8px; + + &:hover { + background-color: var( --jp-gray-0 ); + } + } + } +} + +.jetpack-connect-banner { + color: var( --jp-black-80 ); + background-color: var( --jp-white ); + box-shadow: 0px 12px 15px 0px rgba(0, 0, 0, 0.12), 0px 3px 9px 0px rgba(0, 0, 0, 0.12), 0px 1px 3px 0px rgba(0, 0, 0, 0.15); + border-radius: 0 0 2px 2px; + + &__explanation { + display: flex; + padding: 8px 8px 8px 12px; + align-items: flex-end; + box-sizing: border-box; + border-radius: 6px 6px 0 0; + gap: 6px; + + p { + color: var( --jp-gray-20 ); + font-size: var( --font-label ); + padding: 6px 8px; + margin: 0; + } + } +} diff --git a/projects/plugins/jetpack/extensions/shared/components/upgrade-nudge/index.jsx b/projects/plugins/jetpack/extensions/shared/components/upgrade-nudge/index.jsx index e2d919cefe007..4dab71f5bfe78 100644 --- a/projects/plugins/jetpack/extensions/shared/components/upgrade-nudge/index.jsx +++ b/projects/plugins/jetpack/extensions/shared/components/upgrade-nudge/index.jsx @@ -5,13 +5,13 @@ import clsx from 'clsx'; import './style.scss'; export const Nudge = ( { - align, className, - title, description, + align = null, + title = null, buttonText = null, visible = true, - context, + context = null, checkoutUrl = null, goToCheckoutPage = null, isRedirecting = false,