Skip to content

Commit

Permalink
Try using grid layout in Post Template
Browse files Browse the repository at this point in the history
  • Loading branch information
tellthemachines committed Mar 24, 2023
1 parent acc45ae commit b266825
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 12 deletions.
25 changes: 18 additions & 7 deletions packages/block-library/src/post-template/edit.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import classnames from 'classnames';
/**
* WordPress dependencies
*/
import { memo, useMemo, useState } from '@wordpress/element';
import { memo, useMemo, useState, useEffect } from '@wordpress/element';
import { useSelect } from '@wordpress/data';
import { __ } from '@wordpress/i18n';
import {
Expand Down Expand Up @@ -70,6 +70,7 @@ function PostTemplateBlockPreview( {
const MemoizedPostTemplateBlockPreview = memo( PostTemplateBlockPreview );

export default function PostTemplateEdit( {
setAttributes,
clientId,
context: {
query: {
Expand All @@ -95,11 +96,24 @@ export default function PostTemplateEdit( {
} = {},
queryContext = [ { page: 1 } ],
templateSlug,
displayLayout: { type: layoutType = 'flex', columns = 1 } = {},
displayLayout: { type: layoutType = 'grid', columns = 1 } = {},
previewPostType,
},
__unstableLayoutClassNames,
} ) {
const updatedLayoutType =
layoutType === 'list' || layoutType === 'default' ? 'default' : 'grid';

useEffect( () => {
setAttributes( {
layout: {
type: updatedLayoutType,
isResponsive: false,
numberOfColumns: columns,
},
} );
}, [ updatedLayoutType, columns, setAttributes ] );

const [ { page } ] = queryContext;
const [ activeBlockContextId, setActiveBlockContextId ] = useState();
const { posts, blocks } = useSelect(
Expand Down Expand Up @@ -215,12 +229,9 @@ export default function PostTemplateEdit( {
} ) ),
[ posts ]
);
const hasLayoutFlex = layoutType === 'flex' && columns > 1;

const blockProps = useBlockProps( {
className: classnames( __unstableLayoutClassNames, {
'is-flex-container': hasLayoutFlex,
[ `columns-${ columns }` ]: hasLayoutFlex,
} ),
className: classnames( __unstableLayoutClassNames ),
} );

if ( ! posts ) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -97,7 +97,8 @@ export default function QueryInspectorControls( {
const showInheritControl = isControlAllowed( allowedControls, 'inherit' );
const showPostTypeControl =
! inherit && isControlAllowed( allowedControls, 'postType' );
const showColumnsControl = displayLayout?.type === 'flex';
const showColumnsControl =
displayLayout?.type === 'grid' || displayLayout?.type === 'flex';
const showOrderControl =
! inherit && isControlAllowed( allowedControls, 'order' );
const showStickyControl =
Expand Down
12 changes: 8 additions & 4 deletions packages/block-library/src/query/edit/query-toolbar.js
Original file line number Diff line number Diff line change
Expand Up @@ -34,18 +34,22 @@ export default function QueryToolbar( {
{
icon: list,
title: __( 'List view' ),
onClick: () => setDisplayLayout( { type: 'list' } ),
isActive: displayLayout?.type === 'list',
onClick: () => setDisplayLayout( { type: 'default' } ),
isActive:
displayLayout?.type === 'default' ||
displayLayout?.type === 'list',
},
{
icon: grid,
title: __( 'Grid view' ),
onClick: () =>
setDisplayLayout( {
type: 'flex',
type: 'grid',
columns: displayLayout?.columns || 3,
} ),
isActive: displayLayout?.type === 'flex',
isActive:
displayLayout?.type === 'grid' ||
displayLayout?.type === 'flex',
},
];
return (
Expand Down

0 comments on commit b266825

Please sign in to comment.