Skip to content

Commit

Permalink
Fix layout when slot injects wrapping div inside tools panel
Browse files Browse the repository at this point in the history
  • Loading branch information
aaronrobertshaw committed Sep 14, 2021
1 parent 71d9262 commit 090c908
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ export default function InspectorControlsSlot( {
<BlockSupportToolsPanel group={ group } label={ label }>
<BlockSupportSlotContainer
{ ...props }
className="components-tools-panel__items-wrapper"
bubblesVirtually={ bubblesVirtually }
Slot={ Slot }
/>
Expand Down
25 changes: 25 additions & 0 deletions packages/components/src/tools-panel/styles.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,23 @@ export const ToolsPanel = css`
margin-top: -1px;
padding: ${ space( 4 ) };
row-gap: ${ space( 6 ) };
/**
* Items injected into a ToolsPanel via a virtual bubbling slot will require
* an inner dom element to be injected. The following rule allows for the
* CSS grid display to continue.
*/
.components-tools-panel__items-wrapper {
column-gap: ${ space( 4 ) };
display: grid;
grid-template-columns: 1fr 1fr;
row-gap: ${ space( 6 ) };
grid-column: span 2;
&:empty {
display: none;
}
}
`;

export const ToolsPanelHeader = css`
Expand Down Expand Up @@ -61,4 +78,12 @@ export const ToolsPanelItem = css`
margin-bottom: 0;
max-width: 100%;
}
& > .components-base-control:last-child {
margin-bottom: 0;
.components-base-control__field {
margin-bottom: 0;
}
}
`;

0 comments on commit 090c908

Please sign in to comment.