Skip to content

Commit

Permalink
WIP
Browse files Browse the repository at this point in the history
  • Loading branch information
aristath committed Dec 21, 2021
1 parent bcffb9f commit c79c492
Show file tree
Hide file tree
Showing 5 changed files with 42 additions and 71 deletions.
3 changes: 3 additions & 0 deletions packages/block-library/src/columns/block.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,9 @@
"isStackedOnMobile": {
"type": "boolean",
"default": true
},
"columnMinWidth": {
"type": "string"
}
},
"supports": {
Expand Down
33 changes: 31 additions & 2 deletions packages/block-library/src/columns/edit.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ import {
PanelBody,
RangeControl,
ToggleControl,
__experimentalUnitControl as UnitControl,
__experimentalUseCustomUnits as useCustomUnits,
} from '@wordpress/components';

import {
Expand Down Expand Up @@ -59,7 +61,7 @@ function ColumnsEditContainer( {
updateColumns,
clientId,
} ) {
const { isStackedOnMobile, verticalAlignment } = attributes;
const { isStackedOnMobile, verticalAlignment, columnMinWidth } = attributes;

const { count } = useSelect(
( select ) => {
Expand All @@ -83,6 +85,9 @@ function ColumnsEditContainer( {
orientation: 'horizontal',
renderAppender: false,
} );
const units = useCustomUnits( {
availableUnits: [ '%', 'px', 'em', 'rem', 'vw' ],
} );

return (
<>
Expand Down Expand Up @@ -117,6 +122,23 @@ function ColumnsEditContainer( {
} )
}
/>
{ isStackedOnMobile && (
<UnitControl
label={ __( 'Columns minimum width' ) }
description={ __(
'Minimum width for columns is used to determine how columns will stack when the viewport size changes.'
) }
labelPosition="edge"
__unstableInputWidth="80px"
onChange={ ( value ) => {
setAttributes( {
columnMinWidth: value,
} );
} }
value={ columnMinWidth }
units={ units }
/>
) }
</PanelBody>
</InspectorControls>
<div { ...innerBlocksProps } />
Expand Down Expand Up @@ -276,8 +298,15 @@ const ColumnsEdit = ( props ) => {
const Component = hasInnerBlocks
? ColumnsEditContainerWrapper
: Placeholder;
const style = `--wp--columns-min-width:${
props?.attributes?.columnMinWidth || '200px'
}`;
const propsWithStyle = {
...props,
style,
};

return <Component { ...props } />;
return <Component { ...propsWithStyle } />;
};

export default ColumnsEdit;
15 changes: 0 additions & 15 deletions packages/block-library/src/columns/editor.scss
Original file line number Diff line number Diff line change
Expand Up @@ -8,21 +8,6 @@
margin-right: 0;
}

// To do: remove horizontal margin override by the editor.
@include break-small() {
.editor-styles-wrapper
.block-editor-block-list__block.wp-block-column:nth-child(even) {
margin-left: var(--wp--style--block-gap, 2em);
}
}

@include break-medium() {
.editor-styles-wrapper
.block-editor-block-list__block.wp-block-column:not(:first-child) {
margin-left: var(--wp--style--block-gap, 2em);
}
}

// Individual columns do not have top and bottom margins on the frontend.
// So we make the editor match that.
// We use :where to provide minimum specificity, so that intentional margins,
Expand Down
9 changes: 6 additions & 3 deletions packages/block-library/src/columns/save.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import classnames from 'classnames';
import { useInnerBlocksProps, useBlockProps } from '@wordpress/block-editor';

export default function save( { attributes } ) {
const { isStackedOnMobile, verticalAlignment } = attributes;
const { isStackedOnMobile, verticalAlignment, columnMinWidth } = attributes;

const className = classnames( {
[ `are-vertically-aligned-${ verticalAlignment }` ]: verticalAlignment,
Expand All @@ -18,6 +18,9 @@ export default function save( { attributes } ) {

const blockProps = useBlockProps.save( { className } );
const innerBlocksProps = useInnerBlocksProps.save( blockProps );

return <div { ...innerBlocksProps } />;
const styles =
columnMinWidth && isStackedOnMobile
? `--wp--columns-min-width:${ columnMinWidth };`
: null;
return <div { ...innerBlocksProps } style={ styles } />;
}
53 changes: 2 additions & 51 deletions packages/block-library/src/columns/style.scss
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,7 @@

// Responsiveness: Allow wrapping on mobile.
flex-wrap: wrap;

@include break-medium() {
flex-wrap: nowrap;
}
gap: 1.75em 2em;

/**
* All Columns Alignment
Expand All @@ -26,53 +23,7 @@
}

&:not(.is-not-stacked-on-mobile) > .wp-block-column {
@media (max-width: #{ ($break-small - 1) }) {
// Responsiveness: Show at most one columns on mobile. This must be
// important since the Column assigns its own width as an inline style.
flex-basis: 100% !important;
}

// Between mobile and large viewports, allow 2 columns.
@media (min-width: #{ ($break-small) }) and (max-width: #{ ($break-medium - 1) }) {
// Only add two column styling if there are two or more columns
&:not(:only-child) {
// As with mobile styles, this must be important since the Column
// assigns its own width as an inline style, which should take effect
// starting at `break-medium`.
flex-basis: calc(50% - calc(var(--wp--style--block-gap, 2em) / 2)) !important;
flex-grow: 0;
}

// Add space between the multiple columns. Themes can customize this if they wish to work differently.
// Only apply this beyond the mobile breakpoint, as there's only a single column on mobile.
&:nth-child(even) {
margin-left: var(--wp--style--block-gap, 2em);
}
}

// At large viewports, show all columns horizontally.
@include break-medium() {
// Available space should be divided equally amongst columns without an
// assigned width. This is achieved by assigning a flex basis that is
// consistent (equal), would not cause the sum total of column widths to
// exceed 100%, and which would cede to a column with an assigned width.
// The `flex-grow` allows columns to maximally and equally occupy space
// remaining after subtracting the space occupied by columns with
// explicit widths (if any exist).
flex-basis: 0;
flex-grow: 1;

// Columns with an explicitly-assigned width should maintain their
// `flex-basis` width and not grow.
&[style*="flex-basis"] {
flex-grow: 0;
}

// When columns are in a single row, add space before all except the first.
&:not(:first-child) {
margin-left: var(--wp--style--block-gap, 2em);
}
}
min-width: var(--wp--columns-min-width, min-content);
}

&.is-not-stacked-on-mobile {
Expand Down

0 comments on commit c79c492

Please sign in to comment.