diff --git a/src/block-components/alignment/attributes.js b/src/block-components/alignment/attributes.js index 7c635d869..49d31e148 100644 --- a/src/block-components/alignment/attributes.js +++ b/src/block-components/alignment/attributes.js @@ -30,8 +30,9 @@ export const addAttributes = attrObject => { default: '', }, innerBlockOrientation: { + stkResponsive: true, type: 'string', - default: '', + default: 'vertical', }, // Flex. innerBlockJustify: { diff --git a/src/block-components/alignment/edit.js b/src/block-components/alignment/edit.js index dd02239e3..a0b2a0c97 100644 --- a/src/block-components/alignment/edit.js +++ b/src/block-components/alignment/edit.js @@ -55,8 +55,12 @@ const ALIGN_OPTIONS_NO_JUSTIFY = ALIGN_OPTIONS.filter( option => option.align != export const Edit = memo( props => { const { contentAlign, + contentAlignTablet, + contentAlignMobile, columnJustify, innerBlockOrientation, + innerBlockOrientationTablet, + innerBlockOrientationMobile, innerBlockWrap, containerWidth, containerWidthTablet, @@ -67,8 +71,12 @@ export const Edit = memo( props => { } = useBlockAttributesContext( attributes => { return { contentAlign: attributes.contentAlign, + contentAlignTablet: attributes.contentAlignTablet, + contentAlignMobile: attributes.contentAlignMobile, columnJustify: attributes.columnJustify, innerBlockOrientation: attributes.innerBlockOrientation, + innerBlockOrientationTablet: attributes.innerBlockOrientationTablet, + innerBlockOrientationMobile: attributes.innerBlockOrientationMobile, innerBlockWrap: attributes.innerBlockWrap, containerWidth: attributes.containerWidth, containerWidthTablet: attributes.containerWidthTablet, @@ -81,6 +89,14 @@ export const Edit = memo( props => { const setAttributes = useBlockSetAttributesContext() const deviceType = useDeviceType() + const _contentAlignTablet = contentAlignTablet || contentAlign + const _contentAlignMobile = contentAlignMobile || _contentAlignTablet + + const _innerBlockOrientationTablet = innerBlockOrientationTablet || innerBlockOrientation + const _innerBlockOrientationMobile = innerBlockOrientationMobile || _innerBlockOrientationTablet + + const _innerBlockOrientation = deviceType === 'Desktop' ? innerBlockOrientation : ( deviceType === 'Tablet' ? _innerBlockOrientationTablet : _innerBlockOrientationMobile ) + const { labelContentAlign = sprintf( __( '%s Alignment', i18n ), __( 'Content', i18n ) ), enableContentAlign = true, @@ -140,8 +156,16 @@ export const Edit = memo( props => { <> setAttributes( { contentAlign } ) } + value={ deviceType === 'Desktop' ? contentAlign : ( deviceType === 'Tablet' ? _contentAlignTablet : _contentAlignMobile ) } + onChange={ contentAlign => { + if ( deviceType === 'Desktop' ) { + setAttributes( { contentAlign } ) + } else if ( deviceType === 'Tablet' ) { + setAttributes( { contentAlignTablet: contentAlign } ) + } else { + setAttributes( { contentAlignMobile: contentAlign } ) + } + } } alignmentControls={ props.hasContentJustify ? ALIGN_OPTIONS : ALIGN_OPTIONS_NO_JUSTIFY } /> @@ -220,20 +244,46 @@ export const Edit = memo( props => { title: __( 'Horizontal', i18n ), }, { - value: '', + value: 'vertical', title: __( 'Vertical', i18n ), }, ] } attribute="innerBlockOrientation" + responsive="all" + value={ _innerBlockOrientation } + default="vertical" onChange={ value => { - const newAttributes = { - innerBlockOrientation: value, - } - if ( value === '' ) { // Vertical. + const newAttributes = {} + + if ( deviceType === 'Desktop' ) { + // If the new desktop value is the same as the tablet value, set the tablet value to '' + // since tablet value will just inherit the desktop value + // otherwise, set the tablet value to the old desktop value because tablet was inheriting the old value + if ( innerBlockOrientationTablet === value ) { + newAttributes.innerBlockOrientationTablet = '' + } else { + newAttributes.innerBlockOrientationTablet = innerBlockOrientation + } + newAttributes.innerBlockOrientation = value newAttributes.innerBlockJustify = '' - } else { // Horizontal newAttributes.innerBlockAlign = '' + } else if ( deviceType === 'Tablet' ) { + if ( innerBlockOrientationMobile === value ) { + newAttributes.innerBlockOrientationMobile = '' + } else { + newAttributes.innerBlockOrientationMobile = _innerBlockOrientationTablet + } + + // if the new tablet value is the same as the desktop value, set the tablet value to '' + newAttributes.innerBlockOrientationTablet = innerBlockOrientation === value ? '' : value + newAttributes.innerBlockJustifyTablet = '' + newAttributes.innerBlockAlignTablet = '' + } else { + newAttributes.innerBlockOrientationMobile = _innerBlockOrientationTablet === value ? '' : value + newAttributes.innerBlockJustifyMobile = '' + newAttributes.innerBlockAlignMobile = '' } + setAttributes( newAttributes ) } } /> @@ -243,7 +293,7 @@ export const Edit = memo( props => { label={ sprintf( __( '%s Justify', i18n ), __( 'Inner Block', i18n ) ) } attribute="innerBlockJustify" responsive="all" - controls={ innerBlockOrientation ? 'flex-horizontal' : 'horizontal' } + controls={ _innerBlockOrientation === 'horizontal' ? 'flex-horizontal' : 'horizontal' } visualGuide={ { selector: '.stk-%s-container, .stk-%s-container > * > .block-editor-block-list__layout > [data-type]', highlight: 'outline-first-offset', @@ -259,7 +309,7 @@ export const Edit = memo( props => { label={ sprintf( __( '%s Alignment', i18n ), __( 'Inner Block', i18n ) ) } attribute="innerBlockAlign" responsive="all" - controls={ innerBlockOrientation ? 'vertical' : 'flex-justify-vertical' } + controls={ _innerBlockOrientation === 'horizontal' ? 'vertical' : 'flex-justify-vertical' } disabled={ alignLastBlockToBottom ? 'all' : undefined } visualGuide={ { selector: '.stk-%s-container, .stk-%s-container > * > .block-editor-block-list__layout > [data-type]', @@ -272,7 +322,7 @@ export const Edit = memo( props => { help={ __( 'Set Content Min. Height for alignment to display properly', i18n ) } /> } - { innerBlockOrientation && + { _innerBlockOrientation && { attribute="innerBlockWrap" /> } - { innerBlockOrientation && // This is "column gap" when the blocks are horizontal. + { _innerBlockOrientation && // This is "column gap" when the blocks are horizontal. { } /> } - { ( props.hasColumnAlignment || props.hasBlockAlignment ) && ! innerBlockOrientation && // This is "row gap" when the blocks are vertical. + { ( props.hasColumnAlignment || props.hasBlockAlignment ) && _innerBlockOrientation !== 'horizontal' && // This is "row gap" when the blocks are vertical. { } } /> } - { ( innerBlockOrientation && innerBlockWrap === 'wrap' ) && + { ( _innerBlockOrientation === 'horizontal' && innerBlockWrap === 'wrap' ) && .block-editor-inner-blocks { - flex: 1 1 100%; - display: flex; - flex-direction: column; - > .block-editor-block-list__layout { + @include desktop { + > .block-editor-inner-blocks { flex: 1 1 100%; - display: flex !important; + display: flex; flex-direction: column; - > * { - width: auto; - margin-inline: 0; + > .block-editor-block-list__layout { + flex: 1 1 100%; + display: flex !important; + flex-direction: column; + > * { + width: auto; + margin-inline: 0; - // Placeholder images will collapse. - &[data-type="stackable/image"]:has(.stk-img-placeholder) { - min-width: min(30%, 200px); + // Placeholder images will collapse. + &[data-type="stackable/image"]:has(.stk-img-placeholder) { + min-width: min(30%, 200px); + } } } } } } &.stk--block-horizontal-flex { - > .block-editor-inner-blocks { - > .block-editor-block-list__layout { - height: 100%; - > * { - margin-inline: 0; + @include desktop { + > .block-editor-inner-blocks { + > .block-editor-block-list__layout { + height: 100%; + > * { + margin-inline: 0; + } } } } } -} + &:not(.stk--block-horizontal-flex-tablet) { + @include tablet { + > .block-editor-inner-blocks { + flex: 1 1 100%; + display: flex; + flex-direction: column; + > .block-editor-block-list__layout { + flex: 1 1 100%; + display: flex !important; + flex-direction: column; + > * { + width: auto; + margin-inline: 0; + + // Placeholder images will collapse. + &[data-type="stackable/image"]:has(.stk-img-placeholder) { + min-width: min(30%, 200px); + } + } + } + } + } + } + &.stk--block-horizontal-flex-tablet { + @include tablet { + > .block-editor-inner-blocks { + > .block-editor-block-list__layout { + height: 100%; + > * { + margin-inline: 0; + } + } + } + } + } + + &:not(.stk--block-horizontal-flex-mobile) { + @include mobile { + > .block-editor-inner-blocks { + flex: 1 1 100%; + display: flex; + flex-direction: column; + > .block-editor-block-list__layout { + flex: 1 1 100%; + display: flex !important; + flex-direction: column; + > * { + width: auto; + margin-inline: 0; + + // Placeholder images will collapse. + &[data-type="stackable/image"]:has(.stk-img-placeholder) { + min-width: min(30%, 200px); + } + } + } + } + } + } + &.stk--block-horizontal-flex-mobile { + @include mobile { + > .block-editor-inner-blocks { + > .block-editor-block-list__layout { + height: 100%; + > * { + margin-inline: 0; + } + } + } + } + } +} // for firefox :has polyfill // this needs to be on a separate css ruleset because firefox ignores any CSS ruleset that includes the :has selector diff --git a/src/block-components/alignment/style.js b/src/block-components/alignment/style.js index 5efa60abf..badbd959e 100644 --- a/src/block-components/alignment/style.js +++ b/src/block-components/alignment/style.js @@ -11,8 +11,8 @@ export const addStyles = ( blockStyleGenerator, props = {} ) => { editorSelectorCallback = getAttribute => `.stk--block-align-${ getAttribute( 'uniqueId' ) }`, columnAlignSelectorEditCallback = ( () => '' ), columnAlignSelectorSaveCallback = ( () => '' ), - innerBlockSelectorCallback = getAttribute => `.stk-${ getAttribute( 'uniqueId' ) }-inner-blocks > .block-editor-inner-blocks > .block-editor-block-list__layout`, - editorInnerBlockSelectorCallback = getAttribute => `.stk-${ getAttribute( 'uniqueId' ) }-inner-blocks`, + editorInnerBlockSelectorCallback = getAttribute => `.stk-${ getAttribute( 'uniqueId' ) }-inner-blocks > .block-editor-inner-blocks > .block-editor-block-list__layout`, + innerBlockSelectorCallback = getAttribute => `.stk-${ getAttribute( 'uniqueId' ) }-inner-blocks`, dependencies = [], } = props @@ -62,16 +62,15 @@ export const addStyles = ( blockStyleGenerator, props = {} ) => { ], } ] ) - { /* When blocks are vertical */ } - blockStyleGenerator.addBlockStyles( 'innerBlockJustify', [ { + blockStyleGenerator.addBlockStyles( 'innerBlockOrientation', [ { ...propsToPass, renderIn: 'edit', - selectorCallback: innerBlockSelectorCallback, - styleRule: 'alignItems', - attrName: 'innerBlockJustify', - key: 'innerBlockJustifyVerticalEdit', + selectorCallback: editorInnerBlockSelectorCallback, + styleRule: 'flexDirection', + attrName: 'innerBlockOrientation', + key: 'innerBlockOrientation', responsive: 'all', - enabledCallback: getAttribute => getAttribute( 'innerBlockOrientation' ) !== 'horizontal', + valueCallback: value => value === 'horizontal' ? 'row' : 'column', dependencies: [ 'innerBlockOrientation', ...dependencies, @@ -79,27 +78,50 @@ export const addStyles = ( blockStyleGenerator, props = {} ) => { }, { ...propsToPass, renderIn: 'save', - selectorCallback: editorInnerBlockSelectorCallback, - styleRule: 'alignItems', - attrName: 'innerBlockJustify', - key: 'innerBlockJustifyVerticalSave', + selectorCallback: innerBlockSelectorCallback, + styleRule: 'flexDirection', + attrName: 'innerBlockOrientation', + key: 'innerBlockOrientation-save', responsive: 'all', - enabledCallback: getAttribute => getAttribute( 'innerBlockOrientation' ) !== 'horizontal', + valueCallback: value => value === 'horizontal' ? 'row' : 'column', dependencies: [ 'innerBlockOrientation', ...dependencies, - ], + ], } ] ) - blockStyleGenerator.addBlockStyles( 'innerBlockAlign', [ { + blockStyleGenerator.addBlockStyles( 'innerBlockOrientation', [ { ...propsToPass, renderIn: 'edit', - selectorCallback: innerBlockSelectorCallback, - styleRule: 'justifyContent', - attrName: 'innerBlockAlign', - key: 'innerBlockAlignVerticalEdit', + selectorCallback: editorInnerBlockSelectorCallback, + styleRule: 'alignItems', + attrName: 'innerBlockOrientation', + key: 'innerBlockOrientationAlignItems', responsive: 'all', - enabledCallback: getAttribute => getAttribute( 'innerBlockOrientation' ) !== 'horizontal', + valuePreCallback: ( value, getAttribute, device ) => { + if ( device === 'desktop' ) { + if ( value === 'horizontal' ) { + return getAttribute( 'innerBlockAlign' ) + } + + return getAttribute( 'innerBlockJustify' ) + } + + const inheritOrientation = device === 'tablet' ? getAttribute( 'innerBlockOrientation', 'desktop' ) : getAttribute( 'innerBlockOrientation', 'tablet' ) || getAttribute( 'innerBlockOrientation', 'desktop' ) + + // For tablet and mobile, inner block orientation is '' if it is the same as the previous device + // otherwise, it will have a value of either 'horizontal' or 'vertical' + // reset alignItems to default if inner block orientation is different than the previous device + if ( value === 'horizontal' ) { + return getAttribute( 'innerBlockAlign', device ) || 'initial' + } else if ( value === 'vertical' ) { + return getAttribute( 'innerBlockJustify', device ) || 'initial' + } else if ( inheritOrientation === 'horizontal' ) { + return getAttribute( 'innerBlockAlign', device ) + } + + return getAttribute( 'innerBlockJustify', device ) + }, dependencies: [ 'innerBlockOrientation', ...dependencies, @@ -107,56 +129,73 @@ export const addStyles = ( blockStyleGenerator, props = {} ) => { }, { ...propsToPass, renderIn: 'save', - selectorCallback: editorInnerBlockSelectorCallback, - styleRule: 'justifyContent', - attrName: 'innerBlockAlign', - key: 'innerBlockAlignVerticalSave', + selectorCallback: innerBlockSelectorCallback, + styleRule: 'alignItems', + attrName: 'innerBlockOrientation', + key: 'innerBlockOrientationAlignItems-save', responsive: 'all', - enabledCallback: getAttribute => getAttribute( 'innerBlockOrientation' ) !== 'horizontal', + valuePreCallback: ( value, getAttribute, device ) => { + if ( device === 'desktop' ) { + if ( value === 'horizontal' ) { + return getAttribute( 'innerBlockAlign' ) + } + + return getAttribute( 'innerBlockJustify' ) + } + + const inheritOrientation = device === 'tablet' ? getAttribute( 'innerBlockOrientation', 'desktop' ) : getAttribute( 'innerBlockOrientation', 'tablet' ) || getAttribute( 'innerBlockOrientation', 'desktop' ) + + // For tablet and mobile, inner block orientation is '' if it is the same as the previous device + // otherwise, it will have a value of either 'horizontal' or 'vertical' + // reset alignItems to default if inner block orientation is different than the previous device + if ( value === 'horizontal' ) { + return getAttribute( 'innerBlockAlign', device ) || 'initial' + } else if ( value === 'vertical' ) { + return getAttribute( 'innerBlockJustify', device ) || 'initial' + } else if ( inheritOrientation === 'horizontal' ) { + return getAttribute( 'innerBlockAlign', device ) + } + + return getAttribute( 'innerBlockJustify', device ) + }, dependencies: [ 'innerBlockOrientation', ...dependencies, - ], + ], } ] ) - { /* When blocks are horizontal */ } - blockStyleGenerator.addBlockStyles( 'innerBlockJustify', [ { + blockStyleGenerator.addBlockStyles( 'innerBlockOrientation', [ { ...propsToPass, renderIn: 'edit', - selectorCallback: innerBlockSelectorCallback, - styleRule: 'justifyContent', - attrName: 'innerBlockJustify', - key: 'innerBlockJustifyHorizontalEdit', - responsive: 'all', - enabledCallback: getAttribute => getAttribute( 'innerBlockOrientation' ) === 'horizontal', - dependencies: [ - 'innerBlockOrientation', - ...dependencies, - ], - }, { - ...propsToPass, - renderIn: 'save', selectorCallback: editorInnerBlockSelectorCallback, styleRule: 'justifyContent', - attrName: 'innerBlockJustify', - key: 'innerBlockJustifyHorizontalSave', + attrName: 'innerBlockOrientation', + key: 'innerBlockOrientationJustifyContent', responsive: 'all', - enabledCallback: getAttribute => getAttribute( 'innerBlockOrientation' ) === 'horizontal', - dependencies: [ - 'innerBlockOrientation', - ...dependencies, - ], - } ] ) + valuePreCallback: ( value, getAttribute, device ) => { + if ( device === 'desktop' ) { + if ( value === 'horizontal' ) { + return getAttribute( 'innerBlockJustify' ) + } - blockStyleGenerator.addBlockStyles( 'innerBlockAlign', [ { - ...propsToPass, - renderIn: 'edit', - selectorCallback: innerBlockSelectorCallback, - styleRule: 'alignItems', - attrName: 'innerBlockAlign', - key: 'innerBlockAlignHorizontalEdit', - responsive: 'all', - enabledCallback: getAttribute => getAttribute( 'innerBlockOrientation' ) === 'horizontal', + return getAttribute( 'innerBlockAlign' ) + } + + const inheritOrientation = device === 'tablet' ? getAttribute( 'innerBlockOrientation', 'desktop' ) : getAttribute( 'innerBlockOrientation', 'tablet' ) || getAttribute( 'innerBlockOrientation', 'desktop' ) + + // For tablet and mobile, inner block orientation is '' if it is the same as the previous device + // otherwise, it will have a value of either 'horizontal' or 'vertical' + // reset justifyContent to default if inner block orientation is different than the previous device + if ( value === 'horizontal' ) { + return getAttribute( 'innerBlockJustify', device ) || 'space-evenly' + } else if ( value === 'vertical' ) { + return getAttribute( 'innerBlockAlign', device ) || 'initial' + } else if ( inheritOrientation === 'horizontal' ) { + return getAttribute( 'innerBlockJustify', device ) + } + + return getAttribute( 'innerBlockAlign', device ) + }, dependencies: [ 'innerBlockOrientation', ...dependencies, @@ -164,22 +203,46 @@ export const addStyles = ( blockStyleGenerator, props = {} ) => { }, { ...propsToPass, renderIn: 'save', - selectorCallback: editorInnerBlockSelectorCallback, - styleRule: 'alignItems', - attrName: 'innerBlockAlign', - key: 'innerBlockAlignHorizontalSave', + selectorCallback: innerBlockSelectorCallback, + styleRule: 'justifyContent', + attrName: 'innerBlockOrientation', + key: 'innerBlockOrientationJustifyContent-save', responsive: 'all', - enabledCallback: getAttribute => getAttribute( 'innerBlockOrientation' ) === 'horizontal', + valuePreCallback: ( value, getAttribute, device ) => { + if ( device === 'desktop' ) { + if ( value === 'horizontal' ) { + return getAttribute( 'innerBlockJustify' ) + } + + return getAttribute( 'innerBlockAlign' ) + } + + const inheritOrientation = device === 'tablet' ? getAttribute( 'innerBlockOrientation', 'desktop' ) : getAttribute( 'innerBlockOrientation', 'tablet' ) || getAttribute( 'innerBlockOrientation', 'desktop' ) + + // For tablet and mobile, inner block orientation is '' if it is the same as the previous device + // otherwise, it will have a value of either 'horizontal' or 'vertical' + // reset justifyContent to default if inner block orientation is different than the previous device + if ( value === 'horizontal' ) { + return getAttribute( 'innerBlockJustify', device ) || 'space-evenly' + } else if ( value === 'vertical' ) { + return getAttribute( 'innerBlockAlign', device ) || 'initial' + } else if ( inheritOrientation === 'horizontal' ) { + return getAttribute( 'innerBlockJustify', device ) + } + + return getAttribute( 'innerBlockAlign', device ) + }, dependencies: [ 'innerBlockOrientation', ...dependencies, - ], + ], } ] ) + /* Inner Block Wrap */ blockStyleGenerator.addBlockStyles( 'innerBlockWrap', [ { ...propsToPass, renderIn: 'edit', - selectorCallback: innerBlockSelectorCallback, + selectorCallback: editorInnerBlockSelectorCallback, styleRule: 'flexWrap', attrName: 'innerBlockWrap', key: 'innerBlockWrapEdit', @@ -192,7 +255,7 @@ export const addStyles = ( blockStyleGenerator, props = {} ) => { }, { ...propsToPass, renderIn: 'save', - selectorCallback: editorInnerBlockSelectorCallback, + selectorCallback: innerBlockSelectorCallback, styleRule: 'flexWrap', attrName: 'innerBlockWrap', key: 'innerBlockWrapSave', @@ -207,7 +270,7 @@ export const addStyles = ( blockStyleGenerator, props = {} ) => { blockStyleGenerator.addBlockStyles( 'innerBlockColumnGap', [ { ...propsToPass, renderIn: 'edit', - selectorCallback: innerBlockSelectorCallback, + selectorCallback: editorInnerBlockSelectorCallback, styleRule: 'columnGap', attrName: 'innerBlockColumnGap', key: 'innerBlockColumnGapEdit', @@ -221,7 +284,7 @@ export const addStyles = ( blockStyleGenerator, props = {} ) => { }, { ...propsToPass, renderIn: 'save', - selectorCallback: editorInnerBlockSelectorCallback, + selectorCallback: innerBlockSelectorCallback, styleRule: 'columnGap', attrName: 'innerBlockColumnGap', key: 'innerBlockColumnGapSave', @@ -237,7 +300,7 @@ export const addStyles = ( blockStyleGenerator, props = {} ) => { blockStyleGenerator.addBlockStyles( 'innerBlockRowGap', [ { ...propsToPass, renderIn: 'edit', - selectorCallback: innerBlockSelectorCallback, + selectorCallback: editorInnerBlockSelectorCallback, styleRule: 'rowGap', attrName: 'innerBlockRowGap', key: 'innerBlockRowGapEdit', @@ -255,7 +318,7 @@ export const addStyles = ( blockStyleGenerator, props = {} ) => { }, { ...propsToPass, renderIn: 'save', - selectorCallback: editorInnerBlockSelectorCallback, + selectorCallback: innerBlockSelectorCallback, styleRule: 'rowGap', attrName: 'innerBlockRowGap', key: 'innerBlockRowGapSave', @@ -276,7 +339,7 @@ export const addStyles = ( blockStyleGenerator, props = {} ) => { blockStyleGenerator.addBlockStyles( 'innerBlockAlign', [ { ...propsToPass, renderIn: 'edit', - selectorCallback: innerBlockSelectorCallback, + selectorCallback: editorInnerBlockSelectorCallback, styleRule: 'alignContent', attrName: 'innerBlockAlign', key: 'innerBlockAlignWrapEdit', @@ -290,7 +353,7 @@ export const addStyles = ( blockStyleGenerator, props = {} ) => { }, { ...propsToPass, renderIn: 'save', - selectorCallback: editorInnerBlockSelectorCallback, + selectorCallback: innerBlockSelectorCallback, styleRule: 'alignContent', attrName: 'innerBlockAlign', key: 'innerBlockAlignWrapSave', diff --git a/src/block-components/alignment/use-alignment.js b/src/block-components/alignment/use-alignment.js index abf0ae6e9..7ae22948d 100644 --- a/src/block-components/alignment/use-alignment.js +++ b/src/block-components/alignment/use-alignment.js @@ -17,6 +17,8 @@ export const getAlignmentClasses = attributes => { // We need to put this in a class to we can also target horizontal // orientations in css. [ `stk--block-horizontal-flex` ]: attributes.innerBlockOrientation === 'horizontal', + [ `stk--block-horizontal-flex-tablet` ]: attributes.innerBlockOrientationTablet === 'horizontal' || ( ! attributes.innerBlockOrientationTablet && attributes.innerBlockOrientation === 'horizontal' ), + [ `stk--block-horizontal-flex-mobile` ]: attributes.innerBlockOrientationMobile === 'horizontal' || ( ! attributes.innerBlockOrientationMobile && attributes.innerBlockOrientationTablet === 'horizontal' ) || ( ! attributes.innerBlockOrientationMobile && ! attributes.innerBlockOrientationTablet && attributes.innerBlockOrientation === 'horizontal' ), // We need to put this class to make the 'stk--column-flex': attributes.innerBlockJustify || attributes.innerBlockAlign, diff --git a/src/styles/editor-block.scss b/src/styles/editor-block.scss index 1a2a6a1db..3871b1c06 100644 --- a/src/styles/editor-block.scss +++ b/src/styles/editor-block.scss @@ -185,22 +185,68 @@ width: 100%; } } -.stk--block-horizontal-flex > .block-editor-inner-blocks { - width: 100%; - > .block-editor-block-list__layout { - display: flex !important; - flex-direction: row; - justify-content: space-evenly; // Default justify-content for horizontal flex. - > * { - margin-top: 0; - margin-bottom: 0; - > .stk-block { +@include desktop { + .stk--block-horizontal-flex > .block-editor-inner-blocks { + width: 100%; + > .block-editor-block-list__layout { + display: flex !important; + flex-direction: row; + justify-content: space-evenly; // Default justify-content for horizontal flex. + > * { + margin-top: 0; margin-bottom: 0; + > .stk-block { + margin-bottom: 0; + } + } + > [data-block] { + width: auto; + margin-inline: revert; } } - > [data-block] { - width: auto; - margin-inline: revert; + } +} + +@include tablet { + .stk--block-horizontal-flex-tablet > .block-editor-inner-blocks { + width: 100%; + > .block-editor-block-list__layout { + display: flex !important; + flex-direction: row; + justify-content: space-evenly; // Default justify-content for horizontal flex. + > * { + margin-top: 0; + margin-bottom: 0; + > .stk-block { + margin-bottom: 0; + } + } + > [data-block] { + width: auto; + margin-inline: revert; + } + } + } +} + +@include mobile { + .stk--block-horizontal-flex-mobile > .block-editor-inner-blocks { + width: 100%; + > .block-editor-block-list__layout { + display: flex !important; + flex-direction: row; + justify-content: space-evenly; // Default justify-content for horizontal flex. + > * { + margin-top: 0; + margin-bottom: 0; + > .stk-block { + margin-bottom: 0; + } + } + > [data-block] { + width: auto; + margin-inline: revert; + } } } }