Skip to content

Commit 8378654

Browse files
authored
fix(ui): apply consistent styling to custom & default block thumbnails (#11555)
Fixes #9744
1 parent b0da85d commit 8378654

File tree

9 files changed

+73
-25
lines changed

9 files changed

+73
-25
lines changed

packages/payload/src/fields/config/types.ts

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1399,6 +1399,9 @@ export type Block = {
13991399
singularName?: string
14001400
}
14011401
imageAltText?: string
1402+
/**
1403+
* Preferred aspect ratio of the image is 3 : 2
1404+
*/
14021405
imageURL?: string
14031406
/** Customize generated GraphQL and Typescript schema names.
14041407
* The slug is used by default.

packages/ui/src/elements/ThumbnailCard/index.scss

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -9,9 +9,10 @@
99
border: 1px solid var(--theme-border-color);
1010
border-radius: var(--style-radius-m);
1111
transition: border 100ms cubic-bezier(0, 0.2, 0.2, 1);
12+
padding: base(0.5);
1213

1314
&__label {
14-
padding: base(0.5);
15+
padding: base(0.75) base(0.5) base(0.25) base(0.5);
1516
overflow: hidden;
1617
text-overflow: ellipsis;
1718
white-space: nowrap;

packages/ui/src/fields/Blocks/BlocksDrawer/index.scss

Lines changed: 11 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -16,9 +16,19 @@
1616
}
1717

1818
&__default-image {
19+
display: flex;
20+
align-items: center;
21+
justify-content: center;
1922
width: 100%;
23+
aspect-ratio: 3 / 2;
2024
overflow: hidden;
21-
padding-top: base(0.75);
25+
26+
img,
27+
svg {
28+
width: 100%;
29+
height: 100%;
30+
object-fit: cover;
31+
}
2232
}
2333

2434
&__block-groups {
@@ -60,7 +70,6 @@
6070

6171
&__blocks {
6272
grid-template-columns: repeat(3, 1fr);
63-
gap: base(0.5);
6473
}
6574

6675
&__block-groups {

packages/ui/src/fields/Blocks/BlocksDrawer/index.tsx

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -123,13 +123,13 @@ export const BlocksDrawer: React.FC<Props> = (props) => {
123123
closeModal(drawerSlug)
124124
}}
125125
thumbnail={
126-
imageURL ? (
127-
<img alt={imageAltText} src={imageURL} />
128-
) : (
129-
<div className={`${baseClass}__default-image`}>
126+
<div className={`${baseClass}__default-image`}>
127+
{imageURL ? (
128+
<img alt={imageAltText} src={imageURL} />
129+
) : (
130130
<DefaultBlockImage />
131-
</div>
132-
)
131+
)}
132+
</div>
133133
}
134134
/>
135135
</li>

packages/ui/src/graphics/DefaultBlockImage/index.tsx

Lines changed: 34 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -2,22 +2,43 @@ import React, { useState } from 'react'
22
import { v4 as uuid } from 'uuid'
33

44
export const DefaultBlockImage: React.FC = () => {
5-
const [patternID] = useState(`pattern${uuid()}`)
6-
const [imageID] = useState(`image${uuid()}`)
5+
const [patternID] = useState(() => `pattern${uuid()}`)
76

87
return (
9-
<svg fill="none" height="53" viewBox="0 0 82 53" width="82">
10-
<rect fill={`url(#${patternID})`} height="52.7791" width="80.574" x="0.713013" />
11-
<defs>
12-
<pattern height="1" id={`${patternID}`} patternContentUnits="objectBoundingBox" width="1">
13-
<use transform="scale(0.00387597 0.00591716)" xlinkHref={`#${imageID}`} />
14-
</pattern>
15-
<image
16-
height="169"
17-
id={imageID}
18-
width="258"
19-
xlinkHref=""
8+
<svg
9+
fill="none"
10+
height="151"
11+
preserveAspectRatio="xMidYMid slice"
12+
viewBox="0 0 231 151"
13+
width="231"
14+
xmlns="http://www.w3.org/2000/svg"
15+
>
16+
<g clipPath={`url(#${patternID})`}>
17+
<rect fill="#D9D9D9" height="100%" rx="2" width="100%" />
18+
<rect
19+
fill="#BCBCBC"
20+
height="116.063"
21+
transform="rotate(52.0687 33.7051 79.3051)"
22+
width="85.8593"
23+
x="33.7051"
24+
y="79.3051"
25+
/>
26+
<rect
27+
fill="#BCBCBC"
28+
height="116.063"
29+
transform="rotate(52.0687 86.1219 92.6272)"
30+
width="85.8593"
31+
x="86.1219"
32+
y="92.6272"
2033
/>
34+
<circle cx="189" cy="45" fill="#BCBCBC" r="19" />
35+
<rect fill="#B8B8B8" height="5" rx="2.5" width="98" x="66" y="70" />
36+
<rect fill="#B8B8B8" height="5" rx="2.5" width="76" x="77" y="82" />
37+
</g>
38+
<defs>
39+
<clipPath id={`${patternID}`}>
40+
<rect fill="white" height="151" width="231" />
41+
</clipPath>
2142
</defs>
2243
</svg>
2344
)

test/fields/collections/Blocks/index.ts

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,7 @@ export const getBlocksField = (prefix?: string): BlocksField => ({
1111
blocks: [
1212
{
1313
slug: prefix ? `${prefix}Content` : 'content',
14+
imageURL: '/api/uploads/file/payload480x320.jpg',
1415
interfaceName: prefix ? `${prefix}ContentBlock` : 'ContentBlock',
1516
admin: {
1617
components: {
34.5 KB
Loading

test/fields/payload-types.ts

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -901,7 +901,7 @@ export interface ContentBlock {
901901
* via the `definition` "NoBlockname".
902902
*/
903903
export interface NoBlockname {
904-
text: string;
904+
text?: string | null;
905905
id?: string | null;
906906
blockName?: string | null;
907907
blockType: 'noBlockname';
@@ -967,7 +967,7 @@ export interface LocalizedContentBlock {
967967
* via the `definition` "localizedNoBlockname".
968968
*/
969969
export interface LocalizedNoBlockname {
970-
text: string;
970+
text?: string | null;
971971
id?: string | null;
972972
blockName?: string | null;
973973
blockType: 'localizedNoBlockname';

test/fields/seed.ts

Lines changed: 14 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -69,10 +69,15 @@ const dirname = path.dirname(filename)
6969

7070
export const seed = async (_payload: Payload) => {
7171
const jpgPath = path.resolve(dirname, './collections/Upload/payload.jpg')
72+
const jpg480x320Path = path.resolve(dirname, './collections/Upload/payload480x320.jpg')
7273
const pngPath = path.resolve(dirname, './uploads/payload.png')
7374

7475
// Get both files in parallel
75-
const [jpgFile, pngFile] = await Promise.all([getFileByPath(jpgPath), getFileByPath(pngPath)])
76+
const [jpgFile, jpg480x320File, pngFile] = await Promise.all([
77+
getFileByPath(jpgPath),
78+
getFileByPath(jpg480x320Path),
79+
getFileByPath(pngPath),
80+
])
7681

7782
const createdArrayDoc = await _payload.create({
7883
collection: arrayFieldsSlug,
@@ -121,6 +126,14 @@ export const seed = async (_payload: Payload) => {
121126
overrideAccess: true,
122127
})
123128

129+
await _payload.create({
130+
collection: uploadsSlug,
131+
data: {},
132+
file: jpg480x320File,
133+
depth: 0,
134+
overrideAccess: true,
135+
})
136+
124137
// const createdJPGDocSlug2 = await _payload.create({
125138
// collection: uploads2Slug,
126139
// data: {

0 commit comments

Comments
 (0)