Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Image: Make Placeholder white when there is a <Spinner /> on top #63885

Merged
merged 7 commits into from
Jul 31, 2024

Conversation

noisysocks
Copy link
Member

What?

Updates the design of the Placeholder component when passed the hasIllustration flag.

Why?

Moving to a darker design based on the UI colour so that you can more easily see any Spinner placed on top. See #63643 (comment).

How?

I did what @jameskoster suggested in #63643 (comment) 😀

I also removed the placeholder-style mixin because it isn't really doing anything in most of the places it's used. The mixin adds &::before styling and we're often including it into a &::before or &::after which means there is no effect.

As far as I can tell this styling is only used in <Placeholder hasIllustration> which is the media blocks when not selected or when uploading.

Testing Instructions

If you make these changes locally you can force the Spinner to always appear:

diff --git a/packages/block-library/src/image/image.js b/packages/block-library/src/image/image.js
index 385a740e652..3417b1fc1a8 100644
--- a/packages/block-library/src/image/image.js
+++ b/packages/block-library/src/image/image.js
@@ -827,7 +827,7 @@ export default function Image( {
 	const isRounded = attributes.className?.includes( 'is-style-rounded' );
 
 	let img =
-		temporaryURL && hasImageErrored ? (
+		true || ( temporaryURL && hasImageErrored ) ? (
 			// Show a placeholder during upload when the blob URL can't be loaded. This can
 			// happen when the user uploads a HEIC image in a browser that doesn't support them.
 			<Placeholder

Then:

  1. Add an image block.
  2. De-select it. You'll see the placeholder there.
  3. Upload an image into the image block.
  4. You'll see the placeholder there with a Spinner on top.

Screenshots or screencast

Before After
Screenshot 2024-07-24 at 15 06 02 Screenshot 2024-07-24 at 15 04 42

@noisysocks noisysocks added [Type] Enhancement A suggestion for improvement. [Block] Image Affects the Image Block [Feature] Component System WordPress component system labels Jul 24, 2024
@noisysocks noisysocks self-assigned this Jul 24, 2024
Copy link

github-actions bot commented Jul 24, 2024

The following accounts have interacted with this PR and/or linked issues. I will continue to update these lists as activity occurs. You can also manually ask me to refresh this list by adding the props-bot label.

If you're merging code through a pull request on GitHub, copy and paste the following into the bottom of the merge commit message.

Co-authored-by: noisysocks <noisysocks@git.wordpress.org>
Co-authored-by: jameskoster <jameskoster@git.wordpress.org>

To understand the WordPress project's expectations around crediting contributors, please review the Contributor Attribution page in the Core Handbook.

Copy link

github-actions bot commented Jul 24, 2024

Size Change: +4.37 kB (+0.25%)

Total Size: 1.76 MB

Filename Size Change
build/block-editor/content-rtl.css 4.56 kB -35 B (-0.76%)
build/block-editor/content.css 4.56 kB -34 B (-0.74%)
build/block-editor/index.min.js 255 kB +928 B (+0.37%)
build/block-editor/style-rtl.css 16.3 kB +122 B (+0.75%)
build/block-editor/style.css 16.3 kB +122 B (+0.76%)
build/block-library/blocks/gallery/editor-rtl.css 955 B -3 B (-0.31%)
build/block-library/blocks/gallery/editor.css 958 B -4 B (-0.42%)
build/block-library/blocks/group/editor-rtl.css 344 B -58 B (-14.43%) 👏
build/block-library/blocks/group/editor.css 344 B -58 B (-14.43%) 👏
build/block-library/blocks/image/editor-rtl.css 894 B +32 B (+3.71%)
build/block-library/blocks/image/editor.css 892 B +31 B (+3.6%)
build/block-library/blocks/latest-posts/editor-rtl.css 186 B -18 B (-8.82%)
build/block-library/blocks/latest-posts/editor.css 183 B -21 B (-10.29%) 👏
build/block-library/blocks/navigation/editor-rtl.css 2.18 kB -21 B (-0.95%)
build/block-library/blocks/navigation/editor.css 2.19 kB -19 B (-0.86%)
build/block-library/blocks/post-excerpt/style-rtl.css 155 B +14 B (+9.93%) ⚠️
build/block-library/blocks/post-excerpt/style.css 155 B +14 B (+9.93%) ⚠️
build/block-library/blocks/site-title/style-rtl.css 90 B +19 B (+26.76%) 🚨
build/block-library/blocks/site-title/style.css 90 B +19 B (+26.76%) 🚨
build/block-library/blocks/video/editor-rtl.css 541 B -12 B (-2.17%)
build/block-library/blocks/video/editor.css 542 B -12 B (-2.17%)
build/block-library/editor-rtl.css 11.9 kB -2 B (-0.02%)
build/block-library/editor.css 11.9 kB -4 B (-0.03%)
build/block-library/index.min.js 217 kB +499 B (+0.23%)
build/block-library/style-rtl.css 14.7 kB +45 B (+0.31%)
build/block-library/style.css 14.7 kB +44 B (+0.3%)
build/blocks/index.min.js 52.3 kB +96 B (+0.18%)
build/components/index.min.js 222 kB +209 B (+0.09%)
build/components/style-rtl.css 12.1 kB +112 B (+0.93%)
build/components/style.css 12.1 kB +114 B (+0.95%)
build/core-data/index.min.js 73.1 kB +295 B (+0.41%)
build/edit-site/index.min.js 214 kB +844 B (+0.4%)
build/edit-site/posts-rtl.css 6.81 kB +29 B (+0.43%)
build/edit-site/posts.css 6.82 kB +26 B (+0.38%)
build/edit-site/style-rtl.css 12 kB +69 B (+0.58%)
build/edit-site/style.css 12 kB +65 B (+0.54%)
build/edit-widgets/index.min.js 17.6 kB +14 B (+0.08%)
build/editor/index.min.js 99.7 kB +419 B (+0.42%)
build/editor/style-rtl.css 9.32 kB +5 B (+0.05%)
build/format-library/index.min.js 8.07 kB +3 B (+0.04%)
build/format-library/style-rtl.css 477 B -29 B (-5.73%)
build/format-library/style.css 477 B -28 B (-5.54%)
build/interactivity/image.min.js 1.78 kB -1 B (-0.06%)
build/block-library/blocks/loginout/style-rtl.css 61 B +61 B (new file) 🆕
build/block-library/blocks/loginout/style.css 61 B +61 B (new file) 🆕
build/block-library/blocks/site-tagline/style-rtl.css 65 B +65 B (new file) 🆕
build/block-library/blocks/site-tagline/style.css 65 B +65 B (new file) 🆕
build/block-library/blocks/table-of-contents/style-rtl.css 83 B +83 B (new file) 🆕
build/block-library/blocks/table-of-contents/style.css 83 B +83 B (new file) 🆕
build/block-library/blocks/tag-cloud/editor-rtl.css 63 B +63 B (new file) 🆕
build/block-library/blocks/tag-cloud/editor.css 63 B +63 B (new file) 🆕
ℹ️ View Unchanged
Filename Size
build/a11y/index.min.js 951 B
build/annotations/index.min.js 2.26 kB
build/api-fetch/index.min.js 2.31 kB
build/autop/index.min.js 2.12 kB
build/blob/index.min.js 579 B
build/block-directory/index.min.js 7.29 kB
build/block-directory/style-rtl.css 1.01 kB
build/block-directory/style.css 1.01 kB
build/block-editor/default-editor-styles-rtl.css 394 B
build/block-editor/default-editor-styles.css 394 B
build/block-library/blocks/archives/editor-rtl.css 61 B
build/block-library/blocks/archives/editor.css 60 B
build/block-library/blocks/archives/style-rtl.css 90 B
build/block-library/blocks/archives/style.css 90 B
build/block-library/blocks/audio/editor-rtl.css 149 B
build/block-library/blocks/audio/editor.css 151 B
build/block-library/blocks/audio/style-rtl.css 132 B
build/block-library/blocks/audio/style.css 132 B
build/block-library/blocks/audio/theme-rtl.css 134 B
build/block-library/blocks/audio/theme.css 134 B
build/block-library/blocks/avatar/editor-rtl.css 115 B
build/block-library/blocks/avatar/editor.css 115 B
build/block-library/blocks/avatar/style-rtl.css 104 B
build/block-library/blocks/avatar/style.css 104 B
build/block-library/blocks/button/editor-rtl.css 310 B
build/block-library/blocks/button/editor.css 310 B
build/block-library/blocks/button/style-rtl.css 538 B
build/block-library/blocks/button/style.css 538 B
build/block-library/blocks/buttons/editor-rtl.css 336 B
build/block-library/blocks/buttons/editor.css 336 B
build/block-library/blocks/buttons/style-rtl.css 328 B
build/block-library/blocks/buttons/style.css 328 B
build/block-library/blocks/calendar/style-rtl.css 240 B
build/block-library/blocks/calendar/style.css 240 B
build/block-library/blocks/categories/editor-rtl.css 132 B
build/block-library/blocks/categories/editor.css 131 B
build/block-library/blocks/categories/style-rtl.css 152 B
build/block-library/blocks/categories/style.css 152 B
build/block-library/blocks/code/editor-rtl.css 53 B
build/block-library/blocks/code/editor.css 53 B
build/block-library/blocks/code/style-rtl.css 121 B
build/block-library/blocks/code/style.css 121 B
build/block-library/blocks/code/theme-rtl.css 122 B
build/block-library/blocks/code/theme.css 122 B
build/block-library/blocks/columns/editor-rtl.css 108 B
build/block-library/blocks/columns/editor.css 108 B
build/block-library/blocks/columns/style-rtl.css 420 B
build/block-library/blocks/columns/style.css 420 B
build/block-library/blocks/comment-author-avatar/editor-rtl.css 124 B
build/block-library/blocks/comment-author-avatar/editor.css 124 B
build/block-library/blocks/comment-content/style-rtl.css 90 B
build/block-library/blocks/comment-content/style.css 90 B
build/block-library/blocks/comment-template/style-rtl.css 200 B
build/block-library/blocks/comment-template/style.css 199 B
build/block-library/blocks/comments-pagination-numbers/editor-rtl.css 122 B
build/block-library/blocks/comments-pagination-numbers/editor.css 121 B
build/block-library/blocks/comments-pagination/editor-rtl.css 221 B
build/block-library/blocks/comments-pagination/editor.css 211 B
build/block-library/blocks/comments-pagination/style-rtl.css 234 B
build/block-library/blocks/comments-pagination/style.css 231 B
build/block-library/blocks/comments-title/editor-rtl.css 75 B
build/block-library/blocks/comments-title/editor.css 75 B
build/block-library/blocks/comments/editor-rtl.css 832 B
build/block-library/blocks/comments/editor.css 832 B
build/block-library/blocks/comments/style-rtl.css 632 B
build/block-library/blocks/comments/style.css 631 B
build/block-library/blocks/cover/editor-rtl.css 668 B
build/block-library/blocks/cover/editor.css 669 B
build/block-library/blocks/cover/style-rtl.css 1.62 kB
build/block-library/blocks/cover/style.css 1.6 kB
build/block-library/blocks/details/editor-rtl.css 65 B
build/block-library/blocks/details/editor.css 65 B
build/block-library/blocks/details/style-rtl.css 86 B
build/block-library/blocks/details/style.css 86 B
build/block-library/blocks/embed/editor-rtl.css 314 B
build/block-library/blocks/embed/editor.css 314 B
build/block-library/blocks/embed/style-rtl.css 419 B
build/block-library/blocks/embed/style.css 419 B
build/block-library/blocks/embed/theme-rtl.css 133 B
build/block-library/blocks/embed/theme.css 133 B
build/block-library/blocks/file/editor-rtl.css 326 B
build/block-library/blocks/file/editor.css 326 B
build/block-library/blocks/file/style-rtl.css 278 B
build/block-library/blocks/file/style.css 279 B
build/block-library/blocks/file/view.min.js 324 B
build/block-library/blocks/footnotes/style-rtl.css 198 B
build/block-library/blocks/footnotes/style.css 197 B
build/block-library/blocks/form-input/editor-rtl.css 229 B
build/block-library/blocks/form-input/editor.css 229 B
build/block-library/blocks/form-input/style-rtl.css 342 B
build/block-library/blocks/form-input/style.css 342 B
build/block-library/blocks/form-submission-notification/editor-rtl.css 344 B
build/block-library/blocks/form-submission-notification/editor.css 341 B
build/block-library/blocks/form-submit-button/style-rtl.css 69 B
build/block-library/blocks/form-submit-button/style.css 69 B
build/block-library/blocks/form/view.min.js 470 B
build/block-library/blocks/freeform/editor-rtl.css 2.6 kB
build/block-library/blocks/freeform/editor.css 2.6 kB
build/block-library/blocks/gallery/style-rtl.css 1.71 kB
build/block-library/blocks/gallery/style.css 1.71 kB
build/block-library/blocks/gallery/theme-rtl.css 108 B
build/block-library/blocks/gallery/theme.css 108 B
build/block-library/blocks/group/style-rtl.css 103 B
build/block-library/blocks/group/style.css 103 B
build/block-library/blocks/group/theme-rtl.css 79 B
build/block-library/blocks/group/theme.css 79 B
build/block-library/blocks/heading/style-rtl.css 188 B
build/block-library/blocks/heading/style.css 188 B
build/block-library/blocks/html/editor-rtl.css 346 B
build/block-library/blocks/html/editor.css 347 B
build/block-library/blocks/image/style-rtl.css 1.59 kB
build/block-library/blocks/image/style.css 1.59 kB
build/block-library/blocks/image/theme-rtl.css 137 B
build/block-library/blocks/image/theme.css 137 B
build/block-library/blocks/image/view.min.js 1.65 kB
build/block-library/blocks/latest-comments/style-rtl.css 355 B
build/block-library/blocks/latest-comments/style.css 354 B
build/block-library/blocks/latest-posts/style-rtl.css 509 B
build/block-library/blocks/latest-posts/style.css 510 B
build/block-library/blocks/list/style-rtl.css 107 B
build/block-library/blocks/list/style.css 107 B
build/block-library/blocks/media-text/editor-rtl.css 304 B
build/block-library/blocks/media-text/editor.css 303 B
build/block-library/blocks/media-text/style-rtl.css 516 B
build/block-library/blocks/media-text/style.css 515 B
build/block-library/blocks/more/editor-rtl.css 427 B
build/block-library/blocks/more/editor.css 427 B
build/block-library/blocks/navigation-link/editor-rtl.css 663 B
build/block-library/blocks/navigation-link/editor.css 664 B
build/block-library/blocks/navigation-link/style-rtl.css 192 B
build/block-library/blocks/navigation-link/style.css 191 B
build/block-library/blocks/navigation-submenu/editor-rtl.css 295 B
build/block-library/blocks/navigation-submenu/editor.css 294 B
build/block-library/blocks/navigation/style-rtl.css 2.25 kB
build/block-library/blocks/navigation/style.css 2.23 kB
build/block-library/blocks/navigation/view.min.js 1.03 kB
build/block-library/blocks/nextpage/editor-rtl.css 392 B
build/block-library/blocks/nextpage/editor.css 392 B
build/block-library/blocks/page-list/editor-rtl.css 378 B
build/block-library/blocks/page-list/editor.css 378 B
build/block-library/blocks/page-list/style-rtl.css 175 B
build/block-library/blocks/page-list/style.css 175 B
build/block-library/blocks/paragraph/editor-rtl.css 236 B
build/block-library/blocks/paragraph/editor.css 236 B
build/block-library/blocks/paragraph/style-rtl.css 341 B
build/block-library/blocks/paragraph/style.css 340 B
build/block-library/blocks/post-author/style-rtl.css 175 B
build/block-library/blocks/post-author/style.css 176 B
build/block-library/blocks/post-comments-form/editor-rtl.css 96 B
build/block-library/blocks/post-comments-form/editor.css 96 B
build/block-library/blocks/post-comments-form/style-rtl.css 527 B
build/block-library/blocks/post-comments-form/style.css 528 B
build/block-library/blocks/post-content/editor-rtl.css 74 B
build/block-library/blocks/post-content/editor.css 74 B
build/block-library/blocks/post-date/style-rtl.css 62 B
build/block-library/blocks/post-date/style.css 62 B
build/block-library/blocks/post-excerpt/editor-rtl.css 71 B
build/block-library/blocks/post-excerpt/editor.css 71 B
build/block-library/blocks/post-featured-image/editor-rtl.css 729 B
build/block-library/blocks/post-featured-image/editor.css 726 B
build/block-library/blocks/post-featured-image/style-rtl.css 341 B
build/block-library/blocks/post-featured-image/style.css 341 B
build/block-library/blocks/post-navigation-link/style-rtl.css 215 B
build/block-library/blocks/post-navigation-link/style.css 214 B
build/block-library/blocks/post-template/editor-rtl.css 99 B
build/block-library/blocks/post-template/editor.css 98 B
build/block-library/blocks/post-template/style-rtl.css 399 B
build/block-library/blocks/post-template/style.css 398 B
build/block-library/blocks/post-terms/style-rtl.css 96 B
build/block-library/blocks/post-terms/style.css 96 B
build/block-library/blocks/post-time-to-read/style-rtl.css 70 B
build/block-library/blocks/post-time-to-read/style.css 70 B
build/block-library/blocks/post-title/style-rtl.css 100 B
build/block-library/blocks/post-title/style.css 100 B
build/block-library/blocks/preformatted/style-rtl.css 125 B
build/block-library/blocks/preformatted/style.css 125 B
build/block-library/blocks/pullquote/editor-rtl.css 134 B
build/block-library/blocks/pullquote/editor.css 134 B
build/block-library/blocks/pullquote/style-rtl.css 342 B
build/block-library/blocks/pullquote/style.css 342 B
build/block-library/blocks/pullquote/theme-rtl.css 167 B
build/block-library/blocks/pullquote/theme.css 167 B
build/block-library/blocks/query-pagination-numbers/editor-rtl.css 121 B
build/block-library/blocks/query-pagination-numbers/editor.css 118 B
build/block-library/blocks/query-pagination/editor-rtl.css 220 B
build/block-library/blocks/query-pagination/editor.css 208 B
build/block-library/blocks/query-pagination/style-rtl.css 287 B
build/block-library/blocks/query-pagination/style.css 283 B
build/block-library/blocks/query-title/style-rtl.css 64 B
build/block-library/blocks/query-title/style.css 64 B
build/block-library/blocks/query/editor-rtl.css 452 B
build/block-library/blocks/query/editor.css 451 B
build/block-library/blocks/query/view.min.js 958 B
build/block-library/blocks/quote/style-rtl.css 238 B
build/block-library/blocks/quote/style.css 238 B
build/block-library/blocks/quote/theme-rtl.css 221 B
build/block-library/blocks/quote/theme.css 225 B
build/block-library/blocks/read-more/style-rtl.css 138 B
build/block-library/blocks/read-more/style.css 138 B
build/block-library/blocks/rss/editor-rtl.css 101 B
build/block-library/blocks/rss/editor.css 101 B
build/block-library/blocks/rss/style-rtl.css 288 B
build/block-library/blocks/rss/style.css 287 B
build/block-library/blocks/search/editor-rtl.css 193 B
build/block-library/blocks/search/editor.css 193 B
build/block-library/blocks/search/style-rtl.css 672 B
build/block-library/blocks/search/style.css 671 B
build/block-library/blocks/search/theme-rtl.css 113 B
build/block-library/blocks/search/theme.css 113 B
build/block-library/blocks/search/view.min.js 475 B
build/block-library/blocks/separator/editor-rtl.css 100 B
build/block-library/blocks/separator/editor.css 100 B
build/block-library/blocks/separator/style-rtl.css 248 B
build/block-library/blocks/separator/style.css 248 B
build/block-library/blocks/separator/theme-rtl.css 195 B
build/block-library/blocks/separator/theme.css 195 B
build/block-library/blocks/shortcode/editor-rtl.css 286 B
build/block-library/blocks/shortcode/editor.css 286 B
build/block-library/blocks/site-logo/editor-rtl.css 806 B
build/block-library/blocks/site-logo/editor.css 803 B
build/block-library/blocks/site-logo/style-rtl.css 218 B
build/block-library/blocks/site-logo/style.css 218 B
build/block-library/blocks/site-tagline/editor-rtl.css 87 B
build/block-library/blocks/site-tagline/editor.css 87 B
build/block-library/blocks/site-title/editor-rtl.css 123 B
build/block-library/blocks/site-title/editor.css 123 B
build/block-library/blocks/social-link/editor-rtl.css 338 B
build/block-library/blocks/social-link/editor.css 338 B
build/block-library/blocks/social-links/editor-rtl.css 676 B
build/block-library/blocks/social-links/editor.css 675 B
build/block-library/blocks/social-links/style-rtl.css 1.51 kB
build/block-library/blocks/social-links/style.css 1.5 kB
build/block-library/blocks/spacer/editor-rtl.css 346 B
build/block-library/blocks/spacer/editor.css 346 B
build/block-library/blocks/spacer/style-rtl.css 48 B
build/block-library/blocks/spacer/style.css 48 B
build/block-library/blocks/table/editor-rtl.css 394 B
build/block-library/blocks/table/editor.css 394 B
build/block-library/blocks/table/style-rtl.css 640 B
build/block-library/blocks/table/style.css 639 B
build/block-library/blocks/table/theme-rtl.css 152 B
build/block-library/blocks/table/theme.css 152 B
build/block-library/blocks/tag-cloud/style-rtl.css 266 B
build/block-library/blocks/tag-cloud/style.css 265 B
build/block-library/blocks/template-part/editor-rtl.css 393 B
build/block-library/blocks/template-part/editor.css 393 B
build/block-library/blocks/template-part/theme-rtl.css 113 B
build/block-library/blocks/template-part/theme.css 113 B
build/block-library/blocks/term-description/style-rtl.css 126 B
build/block-library/blocks/term-description/style.css 126 B
build/block-library/blocks/text-columns/editor-rtl.css 95 B
build/block-library/blocks/text-columns/editor.css 95 B
build/block-library/blocks/text-columns/style-rtl.css 165 B
build/block-library/blocks/text-columns/style.css 165 B
build/block-library/blocks/verse/style-rtl.css 98 B
build/block-library/blocks/verse/style.css 98 B
build/block-library/blocks/video/style-rtl.css 192 B
build/block-library/blocks/video/style.css 192 B
build/block-library/blocks/video/theme-rtl.css 134 B
build/block-library/blocks/video/theme.css 134 B
build/block-library/classic-rtl.css 179 B
build/block-library/classic.css 179 B
build/block-library/common-rtl.css 1.1 kB
build/block-library/common.css 1.1 kB
build/block-library/editor-elements-rtl.css 75 B
build/block-library/editor-elements.css 75 B
build/block-library/elements-rtl.css 54 B
build/block-library/elements.css 54 B
build/block-library/reset-rtl.css 472 B
build/block-library/reset.css 472 B
build/block-library/theme-rtl.css 702 B
build/block-library/theme.css 707 B
build/block-serialization-default-parser/index.min.js 1.12 kB
build/block-serialization-spec-parser/index.min.js 2.87 kB
build/commands/index.min.js 16.1 kB
build/commands/style-rtl.css 955 B
build/commands/style.css 952 B
build/compose/index.min.js 12.9 kB
build/core-commands/index.min.js 2.81 kB
build/customize-widgets/index.min.js 11 kB
build/customize-widgets/style-rtl.css 1.35 kB
build/customize-widgets/style.css 1.35 kB
build/data-controls/index.min.js 641 B
build/data/index.min.js 8.98 kB
build/date/index.min.js 18 kB
build/deprecated/index.min.js 458 B
build/dom-ready/index.min.js 325 B
build/dom/index.min.js 4.65 kB
build/edit-post/classic-rtl.css 578 B
build/edit-post/classic.css 580 B
build/edit-post/index.min.js 12.6 kB
build/edit-post/style-rtl.css 2.31 kB
build/edit-post/style.css 2.31 kB
build/edit-widgets/style-rtl.css 4.2 kB
build/edit-widgets/style.css 4.2 kB
build/editor/style.css 9.32 kB
build/element/index.min.js 4.83 kB
build/escape-html/index.min.js 537 B
build/hooks/index.min.js 1.54 kB
build/html-entities/index.min.js 445 B
build/i18n/index.min.js 3.58 kB
build/interactivity/debug.min.js 16.5 kB
build/interactivity/file.min.js 447 B
build/interactivity/index.min.js 13.4 kB
build/interactivity/navigation.min.js 1.16 kB
build/interactivity/query.min.js 742 B
build/interactivity/router.min.js 2.8 kB
build/interactivity/search.min.js 615 B
build/is-shallow-equal/index.min.js 526 B
build/keyboard-shortcuts/index.min.js 1.31 kB
build/keycodes/index.min.js 1.46 kB
build/list-reusable-blocks/index.min.js 2.16 kB
build/list-reusable-blocks/style-rtl.css 846 B
build/list-reusable-blocks/style.css 846 B
build/media-utils/index.min.js 2.92 kB
build/modules/importmap-polyfill.min.js 12.3 kB
build/notices/index.min.js 946 B
build/nux/index.min.js 1.59 kB
build/nux/style-rtl.css 749 B
build/nux/style.css 745 B
build/patterns/index.min.js 7.36 kB
build/patterns/style-rtl.css 687 B
build/patterns/style.css 685 B
build/plugins/index.min.js 1.81 kB
build/preferences-persistence/index.min.js 2.06 kB
build/preferences/index.min.js 2.9 kB
build/preferences/style-rtl.css 554 B
build/preferences/style.css 554 B
build/primitives/index.min.js 829 B
build/priority-queue/index.min.js 1.54 kB
build/private-apis/index.min.js 1.01 kB
build/react-i18n/index.min.js 630 B
build/react-refresh-entry/index.min.js 9.47 kB
build/react-refresh-runtime/index.min.js 6.76 kB
build/redux-routine/index.min.js 2.69 kB
build/reusable-blocks/index.min.js 2.54 kB
build/reusable-blocks/style-rtl.css 256 B
build/reusable-blocks/style.css 256 B
build/rich-text/index.min.js 10.1 kB
build/router/index.min.js 1.96 kB
build/server-side-render/index.min.js 1.94 kB
build/shortcode/index.min.js 1.4 kB
build/style-engine/index.min.js 2.03 kB
build/token-list/index.min.js 581 B
build/url/index.min.js 3.85 kB
build/vendors/react-dom.min.js 41.7 kB
build/vendors/react-jsx-runtime.min.js 560 B
build/vendors/react.min.js 4.02 kB
build/viewport/index.min.js 965 B
build/warning/index.min.js 250 B
build/widgets/index.min.js 7.19 kB
build/widgets/style-rtl.css 1.16 kB
build/widgets/style.css 1.16 kB
build/wordcount/index.min.js 1.03 kB

compressed-size-action

@jameskoster
Copy link
Contributor

I flip-flopped back to a white overlay, the contrast against the gray spinner track is less harsh. Also pushed a couple other style tweaks, and removed a margin that was making the spinner slightly off-center.

I'm a bit confused by the behavior though. I'm seeing the overlay without a spinner when an image hasn't been uploaded. Shouldn't both the overlay and the spinner become visible whilst the image is being uploaded?

@noisysocks
Copy link
Member Author

noisysocks commented Jul 25, 2024

The overlay will show when you have not picked an image and you deselect the block.

A faded out image + spinner will show while an image is being uploaded.

The overlay + spinner will show while an image that isn't supported by your browser (e.g. HEIC) is being uploded.

Does that make sense?


Thanks for pushing. The diagonal line isn't appearing on the overlay anymore because of the z-index:

Screenshot 2024-07-25 at 11 35 44

I imagine that's a mistake? I'll remove the z-indexes (which I think are unnecessary?) which makes it look like this:

Screenshot 2024-07-25 at 11 35 48

Here's how everything looks together:

Kapture.2024-07-25.at.11.39.29.mp4

And here's how the placeholder looks like when it's on top of a background image:

Screenshot 2024-07-25 at 11 45 56

I like it! Add an approving review if you're happy 🙂

@jameskoster
Copy link
Contributor

The overlay will show when you have not picked an image and you deselect the block.

Hmm, I don't understand why we're showing an overlay when the block is deselected. What purpose is that serving? I'd expect to see the standard placeholder with no overlay, this one:

Screenshot 2024-07-25 at 09 54 26

My understanding was that the overlay's purpose was to ensure the spinner was visible?

The z-index was to ensure the overlay and spinner appear 'above' the placeholder. Previously the placeholder was appearing above the overlay which seemed wrong.

Here's what I'd expect:

upload

Does that make sense?

@noisysocks
Copy link
Member Author

noisysocks commented Jul 26, 2024

Sorry, think there's some confusion. What do you mean by overlay? In my comment above I used overlay as a synonym for the <Placeholder />.

When an image that the browser can render (JPEG) is being uploaded, we show that image with the is-transient class which sets the opacity of the image to 0.3 with a <Spinner /> on top.

When an image that the browser can't render (HEIC) is being uploaded, we show a <Placeholder hasIllustration /> with a <Spinner /> on top.

When an Image block with no image selected is deselected, we show a <Placeholder hasIllustration /> by itself.

When <Placeholder> has the hasIllustration prop, it shows a diagonal line and we place some &::before styling on it that gives the Placeholder a solid background.

So I think things are currently working as you expect? There's no overlay on top of the <Placeholder /> or image. The <Spinner /> appears either directly on top of the <Placeholder /> or directly on top of the image with its opacity reduced. This PR changes the <Placeholder /> to be a colour that doesn't make it too hard to see any <Spinner /> that is on top.

@jameskoster
Copy link
Contributor

Ah I see, thanks for clarifying. Sorry about the confusion, that's my fault. I didn't realise the overlay and the placeholder were the same element.

The part that doesn't seem to be working as expected is that the white background should only applied when the spinner is visible. Currently it seems to be applied regardless.

If it's not trivial to do that, then it's probably okay to just leave things as they are (but include the margin fix).

@noisysocks
Copy link
Member Author

The part that doesn't seem to be working as expected is that the white background should only applied when the spinner is visible. Currently it seems to be applied regardless.

If it's not trivial to do that, then it's probably okay to just leave things as they are (but include the margin fix).

👍 you got it, done in b54c323.

@noisysocks noisysocks changed the title Update Placeholder design Image: Make Placeholder white when there is a <Spinner /> on top Jul 30, 2024
@jameskoster
Copy link
Contributor

Bingo, here's what I see:

Screenshot 2024-07-30 at 13 04 30

The only other minor tweak I'd suggest (if it's possible) would be to reduce the opacity of the diagonal stroke, it's obscuring the spinner a little. Otherwise this seems good.

@noisysocks
Copy link
Member Author

The only other minor tweak I'd suggest (if it's possible) would be to reduce the opacity of the diagonal stroke, it's obscuring the spinner a little. Otherwise this seems good.

Done 👍

@noisysocks noisysocks enabled auto-merge (squash) July 31, 2024 05:13
@noisysocks noisysocks merged commit b27ff6f into trunk Jul 31, 2024
61 of 62 checks passed
@noisysocks noisysocks deleted the update/placeholder-design branch July 31, 2024 05:46
@github-actions github-actions bot added this to the Gutenberg 19.0 milestone Jul 31, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Block] Image Affects the Image Block [Feature] Component System WordPress component system [Type] Enhancement A suggestion for improvement.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants