fix(ui): apply consistent styling to custom & default block thumbnails (#11555)

Fixes #9744
This commit is contained in:
Patrik
2025-03-06 15:34:25 -05:00
committed by GitHub
parent b0da85dfea
commit 8378654fd0
9 changed files with 73 additions and 25 deletions

View File

@@ -1399,6 +1399,9 @@ export type Block = {
singularName?: string singularName?: string
} }
imageAltText?: string imageAltText?: string
/**
* Preferred aspect ratio of the image is 3 : 2
*/
imageURL?: string imageURL?: string
/** Customize generated GraphQL and Typescript schema names. /** Customize generated GraphQL and Typescript schema names.
* The slug is used by default. * The slug is used by default.

View File

@@ -9,9 +9,10 @@
border: 1px solid var(--theme-border-color); border: 1px solid var(--theme-border-color);
border-radius: var(--style-radius-m); border-radius: var(--style-radius-m);
transition: border 100ms cubic-bezier(0, 0.2, 0.2, 1); transition: border 100ms cubic-bezier(0, 0.2, 0.2, 1);
padding: base(0.5);
&__label { &__label {
padding: base(0.5); padding: base(0.75) base(0.5) base(0.25) base(0.5);
overflow: hidden; overflow: hidden;
text-overflow: ellipsis; text-overflow: ellipsis;
white-space: nowrap; white-space: nowrap;

View File

@@ -16,9 +16,19 @@
} }
&__default-image { &__default-image {
display: flex;
align-items: center;
justify-content: center;
width: 100%; width: 100%;
aspect-ratio: 3 / 2;
overflow: hidden; overflow: hidden;
padding-top: base(0.75);
img,
svg {
width: 100%;
height: 100%;
object-fit: cover;
}
} }
&__block-groups { &__block-groups {
@@ -60,7 +70,6 @@
&__blocks { &__blocks {
grid-template-columns: repeat(3, 1fr); grid-template-columns: repeat(3, 1fr);
gap: base(0.5);
} }
&__block-groups { &__block-groups {

View File

@@ -123,13 +123,13 @@ export const BlocksDrawer: React.FC<Props> = (props) => {
closeModal(drawerSlug) closeModal(drawerSlug)
}} }}
thumbnail={ thumbnail={
imageURL ? ( <div className={`${baseClass}__default-image`}>
<img alt={imageAltText} src={imageURL} /> {imageURL ? (
) : ( <img alt={imageAltText} src={imageURL} />
<div className={`${baseClass}__default-image`}> ) : (
<DefaultBlockImage /> <DefaultBlockImage />
</div> )}
) </div>
} }
/> />
</li> </li>

View File

@@ -2,22 +2,43 @@ import React, { useState } from 'react'
import { v4 as uuid } from 'uuid' import { v4 as uuid } from 'uuid'
export const DefaultBlockImage: React.FC = () => { export const DefaultBlockImage: React.FC = () => {
const [patternID] = useState(`pattern${uuid()}`) const [patternID] = useState(() => `pattern${uuid()}`)
const [imageID] = useState(`image${uuid()}`)
return ( return (
<svg fill="none" height="53" viewBox="0 0 82 53" width="82"> <svg
<rect fill={`url(#${patternID})`} height="52.7791" width="80.574" x="0.713013" /> fill="none"
<defs> height="151"
<pattern height="1" id={`${patternID}`} patternContentUnits="objectBoundingBox" width="1"> preserveAspectRatio="xMidYMid slice"
<use transform="scale(0.00387597 0.00591716)" xlinkHref={`#${imageID}`} /> viewBox="0 0 231 151"
</pattern> width="231"
<image xmlns="http://www.w3.org/2000/svg"
height="169" >
id={imageID} <g clipPath={`url(#${patternID})`}>
width="258" <rect fill="#D9D9D9" height="100%" rx="2" width="100%" />
xlinkHref="" <rect
fill="#BCBCBC"
height="116.063"
transform="rotate(52.0687 33.7051 79.3051)"
width="85.8593"
x="33.7051"
y="79.3051"
/> />
<rect
fill="#BCBCBC"
height="116.063"
transform="rotate(52.0687 86.1219 92.6272)"
width="85.8593"
x="86.1219"
y="92.6272"
/>
<circle cx="189" cy="45" fill="#BCBCBC" r="19" />
<rect fill="#B8B8B8" height="5" rx="2.5" width="98" x="66" y="70" />
<rect fill="#B8B8B8" height="5" rx="2.5" width="76" x="77" y="82" />
</g>
<defs>
<clipPath id={`${patternID}`}>
<rect fill="white" height="151" width="231" />
</clipPath>
</defs> </defs>
</svg> </svg>
) )

View File

@@ -11,6 +11,7 @@ export const getBlocksField = (prefix?: string): BlocksField => ({
blocks: [ blocks: [
{ {
slug: prefix ? `${prefix}Content` : 'content', slug: prefix ? `${prefix}Content` : 'content',
imageURL: '/api/uploads/file/payload480x320.jpg',
interfaceName: prefix ? `${prefix}ContentBlock` : 'ContentBlock', interfaceName: prefix ? `${prefix}ContentBlock` : 'ContentBlock',
admin: { admin: {
components: { components: {

Binary file not shown.

After

Width:  |  Height:  |  Size: 34 KiB

View File

@@ -901,7 +901,7 @@ export interface ContentBlock {
* via the `definition` "NoBlockname". * via the `definition` "NoBlockname".
*/ */
export interface NoBlockname { export interface NoBlockname {
text: string; text?: string | null;
id?: string | null; id?: string | null;
blockName?: string | null; blockName?: string | null;
blockType: 'noBlockname'; blockType: 'noBlockname';
@@ -967,7 +967,7 @@ export interface LocalizedContentBlock {
* via the `definition` "localizedNoBlockname". * via the `definition` "localizedNoBlockname".
*/ */
export interface LocalizedNoBlockname { export interface LocalizedNoBlockname {
text: string; text?: string | null;
id?: string | null; id?: string | null;
blockName?: string | null; blockName?: string | null;
blockType: 'localizedNoBlockname'; blockType: 'localizedNoBlockname';

View File

@@ -69,10 +69,15 @@ const dirname = path.dirname(filename)
export const seed = async (_payload: Payload) => { export const seed = async (_payload: Payload) => {
const jpgPath = path.resolve(dirname, './collections/Upload/payload.jpg') const jpgPath = path.resolve(dirname, './collections/Upload/payload.jpg')
const jpg480x320Path = path.resolve(dirname, './collections/Upload/payload480x320.jpg')
const pngPath = path.resolve(dirname, './uploads/payload.png') const pngPath = path.resolve(dirname, './uploads/payload.png')
// Get both files in parallel // Get both files in parallel
const [jpgFile, pngFile] = await Promise.all([getFileByPath(jpgPath), getFileByPath(pngPath)]) const [jpgFile, jpg480x320File, pngFile] = await Promise.all([
getFileByPath(jpgPath),
getFileByPath(jpg480x320Path),
getFileByPath(pngPath),
])
const createdArrayDoc = await _payload.create({ const createdArrayDoc = await _payload.create({
collection: arrayFieldsSlug, collection: arrayFieldsSlug,
@@ -121,6 +126,14 @@ export const seed = async (_payload: Payload) => {
overrideAccess: true, overrideAccess: true,
}) })
await _payload.create({
collection: uploadsSlug,
data: {},
file: jpg480x320File,
depth: 0,
overrideAccess: true,
})
// const createdJPGDocSlug2 = await _payload.create({ // const createdJPGDocSlug2 = await _payload.create({
// collection: uploads2Slug, // collection: uploads2Slug,
// data: { // data: {