fix(ui): apply consistent styling to custom & default block thumbnails (#11555)
Fixes #9744
This commit is contained in:
@@ -1399,6 +1399,9 @@ export type Block = {
|
||||
singularName?: string
|
||||
}
|
||||
imageAltText?: string
|
||||
/**
|
||||
* Preferred aspect ratio of the image is 3 : 2
|
||||
*/
|
||||
imageURL?: string
|
||||
/** Customize generated GraphQL and Typescript schema names.
|
||||
* The slug is used by default.
|
||||
|
||||
@@ -9,9 +9,10 @@
|
||||
border: 1px solid var(--theme-border-color);
|
||||
border-radius: var(--style-radius-m);
|
||||
transition: border 100ms cubic-bezier(0, 0.2, 0.2, 1);
|
||||
padding: base(0.5);
|
||||
|
||||
&__label {
|
||||
padding: base(0.5);
|
||||
padding: base(0.75) base(0.5) base(0.25) base(0.5);
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
white-space: nowrap;
|
||||
|
||||
@@ -16,9 +16,19 @@
|
||||
}
|
||||
|
||||
&__default-image {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
width: 100%;
|
||||
aspect-ratio: 3 / 2;
|
||||
overflow: hidden;
|
||||
padding-top: base(0.75);
|
||||
|
||||
img,
|
||||
svg {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
object-fit: cover;
|
||||
}
|
||||
}
|
||||
|
||||
&__block-groups {
|
||||
@@ -60,7 +70,6 @@
|
||||
|
||||
&__blocks {
|
||||
grid-template-columns: repeat(3, 1fr);
|
||||
gap: base(0.5);
|
||||
}
|
||||
|
||||
&__block-groups {
|
||||
|
||||
@@ -123,13 +123,13 @@ export const BlocksDrawer: React.FC<Props> = (props) => {
|
||||
closeModal(drawerSlug)
|
||||
}}
|
||||
thumbnail={
|
||||
imageURL ? (
|
||||
<img alt={imageAltText} src={imageURL} />
|
||||
) : (
|
||||
<div className={`${baseClass}__default-image`}>
|
||||
<div className={`${baseClass}__default-image`}>
|
||||
{imageURL ? (
|
||||
<img alt={imageAltText} src={imageURL} />
|
||||
) : (
|
||||
<DefaultBlockImage />
|
||||
</div>
|
||||
)
|
||||
)}
|
||||
</div>
|
||||
}
|
||||
/>
|
||||
</li>
|
||||
|
||||
@@ -2,22 +2,43 @@ import React, { useState } from 'react'
|
||||
import { v4 as uuid } from 'uuid'
|
||||
|
||||
export const DefaultBlockImage: React.FC = () => {
|
||||
const [patternID] = useState(`pattern${uuid()}`)
|
||||
const [imageID] = useState(`image${uuid()}`)
|
||||
const [patternID] = useState(() => `pattern${uuid()}`)
|
||||
|
||||
return (
|
||||
<svg fill="none" height="53" viewBox="0 0 82 53" width="82">
|
||||
<rect fill={`url(#${patternID})`} height="52.7791" width="80.574" x="0.713013" />
|
||||
<defs>
|
||||
<pattern height="1" id={`${patternID}`} patternContentUnits="objectBoundingBox" width="1">
|
||||
<use transform="scale(0.00387597 0.00591716)" xlinkHref={`#${imageID}`} />
|
||||
</pattern>
|
||||
<image
|
||||
height="169"
|
||||
id={imageID}
|
||||
width="258"
|
||||
xlinkHref=""
|
||||
<svg
|
||||
fill="none"
|
||||
height="151"
|
||||
preserveAspectRatio="xMidYMid slice"
|
||||
viewBox="0 0 231 151"
|
||||
width="231"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
>
|
||||
<g clipPath={`url(#${patternID})`}>
|
||||
<rect fill="#D9D9D9" height="100%" rx="2" width="100%" />
|
||||
<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>
|
||||
</svg>
|
||||
)
|
||||
|
||||
@@ -11,6 +11,7 @@ export const getBlocksField = (prefix?: string): BlocksField => ({
|
||||
blocks: [
|
||||
{
|
||||
slug: prefix ? `${prefix}Content` : 'content',
|
||||
imageURL: '/api/uploads/file/payload480x320.jpg',
|
||||
interfaceName: prefix ? `${prefix}ContentBlock` : 'ContentBlock',
|
||||
admin: {
|
||||
components: {
|
||||
|
||||
BIN
test/fields/collections/Upload/payload480x320.jpg
Normal file
BIN
test/fields/collections/Upload/payload480x320.jpg
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 34 KiB |
@@ -901,7 +901,7 @@ export interface ContentBlock {
|
||||
* via the `definition` "NoBlockname".
|
||||
*/
|
||||
export interface NoBlockname {
|
||||
text: string;
|
||||
text?: string | null;
|
||||
id?: string | null;
|
||||
blockName?: string | null;
|
||||
blockType: 'noBlockname';
|
||||
@@ -967,7 +967,7 @@ export interface LocalizedContentBlock {
|
||||
* via the `definition` "localizedNoBlockname".
|
||||
*/
|
||||
export interface LocalizedNoBlockname {
|
||||
text: string;
|
||||
text?: string | null;
|
||||
id?: string | null;
|
||||
blockName?: string | null;
|
||||
blockType: 'localizedNoBlockname';
|
||||
|
||||
@@ -69,10 +69,15 @@ const dirname = path.dirname(filename)
|
||||
|
||||
export const seed = async (_payload: Payload) => {
|
||||
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')
|
||||
|
||||
// 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({
|
||||
collection: arrayFieldsSlug,
|
||||
@@ -121,6 +126,14 @@ export const seed = async (_payload: Payload) => {
|
||||
overrideAccess: true,
|
||||
})
|
||||
|
||||
await _payload.create({
|
||||
collection: uploadsSlug,
|
||||
data: {},
|
||||
file: jpg480x320File,
|
||||
depth: 0,
|
||||
overrideAccess: true,
|
||||
})
|
||||
|
||||
// const createdJPGDocSlug2 = await _payload.create({
|
||||
// collection: uploads2Slug,
|
||||
// data: {
|
||||
|
||||
Reference in New Issue
Block a user