From d325c5da6bbd1c579d2e22503142dc4e31fad45e Mon Sep 17 00:00:00 2001 From: George Hotelling Date: Fri, 23 Apr 2021 10:37:40 -0400 Subject: [PATCH] Navigation Block: Add Color Options for Submenus Closes #29963 --- .../src/navigation-link/block.json | 4 ++ .../block-library/src/navigation-link/edit.js | 49 +++++++++++++-- .../src/navigation-link/editor.scss | 6 ++ .../block-library/src/navigation/block.json | 17 +++++- packages/block-library/src/navigation/edit.js | 61 +++++++++++++++++-- 5 files changed, 127 insertions(+), 10 deletions(-) diff --git a/packages/block-library/src/navigation-link/block.json b/packages/block-library/src/navigation-link/block.json index dc31e79bf798a..ac9e3ba4d2343 100644 --- a/packages/block-library/src/navigation-link/block.json +++ b/packages/block-library/src/navigation-link/block.json @@ -38,6 +38,10 @@ "customTextColor", "backgroundColor", "customBackgroundColor", + "overlayTextColor", + "customOverlayTextColor", + "overlayBackgroundColor", + "customOverlayBackgroundColor", "fontSize", "customFontSize", "showSubmenuIcon", diff --git a/packages/block-library/src/navigation-link/edit.js b/packages/block-library/src/navigation-link/edit.js index a1ce7bb2781d9..c08aa34f5305a 100644 --- a/packages/block-library/src/navigation-link/edit.js +++ b/packages/block-library/src/navigation-link/edit.js @@ -157,7 +157,14 @@ export default function NavigationLinkEdit( { url, opensInNewTab, }; - const { textColor, backgroundColor, style, showSubmenuIcon } = context; + const { + textColor, + backgroundColor, + overlayTextColor, + overlayBackgroundColor, + style, + showSubmenuIcon, + } = context; const { saveEntityRecord } = useDispatch( coreStore ); const { insertBlock } = useDispatch( blockEditorStore ); const [ isLinkOpen, setIsLinkOpen ] = useState( false ); @@ -168,6 +175,7 @@ export default function NavigationLinkEdit( { const { isAtMaxNesting, + isTopLevelLink, isParentOfSelectedBlock, isImmediateParentOfSelectedBlock, hasDescendants, @@ -193,6 +201,8 @@ export default function NavigationLinkEdit( { isAtMaxNesting: getBlockParentsByBlockName( clientId, name ).length >= MAX_NESTING, + isTopLevelLink: + getBlockParentsByBlockName( clientId, name ).length === 0, isParentOfSelectedBlock: hasSelectedInnerBlock( clientId, true @@ -304,6 +314,13 @@ export default function NavigationLinkEdit( { }; } + const textColorForNesting = isTopLevelLink + ? textColor + : overlayTextColor || textColor; + const bgColorForNesting = isTopLevelLink + ? backgroundColor + : overlayBackgroundColor || backgroundColor; + const blockProps = useBlockProps( { ref: listItemRef, className: classnames( { @@ -311,10 +328,11 @@ export default function NavigationLinkEdit( { 'is-dragging-within': isDraggingWithin, 'has-link': !! url, 'has-child': hasDescendants, - 'has-text-color': !! textColor || !! style?.color?.text, - [ `has-${ textColor }-color` ]: !! textColor, - 'has-background': !! backgroundColor || !! style?.color?.background, - [ `has-${ backgroundColor }-background-color` ]: !! backgroundColor, + 'has-text-color': !! textColorForNesting || !! style?.color?.text, + [ `has-${ textColorForNesting }-color` ]: !! textColorForNesting, + 'has-background': + !! bgColorForNesting || !! style?.color?.background, + [ `has-${ bgColorForNesting }-background-color` ]: !! bgColorForNesting, } ), style: { color: style?.color?.text, @@ -330,7 +348,28 @@ export default function NavigationLinkEdit( { { className: classnames( 'wp-block-navigation-link__container', { 'is-parent-of-selected-block': isParentOfSelectedBlock, + 'has-text-color': !! ( + overlayTextColor || + textColor || + !! style?.color?.text + ), + [ `has-${ overlayTextColor || textColor }-color` ]: !! ( + overlayTextColor || textColor + ), + 'has-background': + !! overlayBackgroundColor || + backgroundColor || + !! style?.color?.background, + [ `has-${ + overlayBackgroundColor || backgroundColor + }-background-color` ]: !! ( + overlayBackgroundColor || backgroundColor + ), } ), + style: { + color: style?.color?.text, + backgroundColor: style?.color?.background, + }, }, { allowedBlocks: ALLOWED_BLOCKS, diff --git a/packages/block-library/src/navigation-link/editor.scss b/packages/block-library/src/navigation-link/editor.scss index f2f2a6f3e1ded..06051f798853b 100644 --- a/packages/block-library/src/navigation-link/editor.scss +++ b/packages/block-library/src/navigation-link/editor.scss @@ -57,6 +57,12 @@ margin-bottom: $grid-unit-20; margin-left: $grid-unit-20; } + + // Override the list reset for colored, nested menus + ol.has-background, + ul.has-background { + padding: 0; + } } .wp-block-navigation .block-editor-block-list__block[data-type="core/navigation-link"] { diff --git a/packages/block-library/src/navigation/block.json b/packages/block-library/src/navigation/block.json index 28c7d25a89ea6..e49982f6992d6 100644 --- a/packages/block-library/src/navigation/block.json +++ b/packages/block-library/src/navigation/block.json @@ -30,6 +30,18 @@ "showSubmenuIcon": { "type": "boolean", "default": true + }, + "overlayBackgroundColor": { + "type": "string" + }, + "customOverlayBackgroundColor": { + "type": "string" + }, + "overlayTextColor": { + "type": "string" + }, + "customOverlayTextColor": { + "type": "string" } }, "providesContext": { @@ -37,6 +49,10 @@ "customTextColor": "customTextColor", "backgroundColor": "backgroundColor", "customBackgroundColor": "customBackgroundColor", + "overlayTextColor": "overlayTextColor", + "customOverlayTextColor": "customOverlayTextColor", + "overlayBackgroundColor": "overlayBackgroundColor", + "customOverlayBackgroundColor": "customOverlayBackgroundColor", "fontSize": "fontSize", "customFontSize": "customFontSize", "showSubmenuIcon": "showSubmenuIcon", @@ -53,7 +69,6 @@ "__experimentalFontStyle": true, "__experimentalFontWeight": true, "__experimentalTextTransform": true, - "color": true, "__experimentalFontFamily": true, "__experimentalTextDecoration": true }, diff --git a/packages/block-library/src/navigation/edit.js b/packages/block-library/src/navigation/edit.js index 18d9da732015c..c4f90567cbe07 100644 --- a/packages/block-library/src/navigation/edit.js +++ b/packages/block-library/src/navigation/edit.js @@ -15,6 +15,8 @@ import { BlockControls, useBlockProps, store as blockEditorStore, + withColors, + PanelColorSettings, } from '@wordpress/block-editor'; import { useDispatch, withSelect, withDispatch } from '@wordpress/data'; import { PanelBody, ToggleControl, ToolbarGroup } from '@wordpress/components'; @@ -52,6 +54,14 @@ function Navigation( { isSelected, updateInnerBlocks, className, + backgroundColor, + setBackgroundColor, + textColor, + setTextColor, + overlayBackgroundColor, + setOverlayBackgroundColor, + overlayTextColor, + setOverlayTextColor, hasSubmenuIndicatorSetting = true, hasItemJustificationControls = true, } ) { @@ -62,10 +72,22 @@ function Navigation( { const { selectBlock } = useDispatch( blockEditorStore ); const blockProps = useBlockProps( { - className: classnames( className, { - [ `items-justified-${ attributes.itemsJustification }` ]: attributes.itemsJustification, - 'is-vertical': attributes.orientation === 'vertical', - } ), + className: classnames( + className, + textColor.class, + backgroundColor.class, + { + [ `items-justified-${ attributes.itemsJustification }` ]: attributes.itemsJustification, + 'is-vertical': attributes.orientation === 'vertical', + 'has-text-color': !! textColor.color || !! textColor.class, + 'has-background': + !! backgroundColor.color || !! backgroundColor.class, + } + ), + style: { + color: textColor.color, + backgroundColor: backgroundColor.color, + }, } ); const { navigatorToolbarButton, navigatorModal } = useBlockNavigator( @@ -150,6 +172,31 @@ function Navigation( { /> ) } +