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

[RNMobile] Update Image component to avoid flicker when updating the URI #57869

Merged
merged 20 commits into from
Jan 31, 2024

Conversation

derekblank
Copy link
Member

@derekblank derekblank commented Jan 16, 2024

What?

Fixes an issue where image uploads disappear or "blink" when transitioning from local to network states.

Related PRs:

Why?

Fixes:

Currently when uploading an Image, the Image itself "blinks" when transitioning its URI reference from a local on-device image to the uploaded, network-available image. This "blink" is possibly due to the time spent downloading the network-available resource itself, where the visual asset appears unavailable while the network image is downloading.

How?

Adds more descriptive states when a uri is changed to await the full loading of a network-based image, before swapping out the URI from the local filestore-based image.

Testing Instructions

  1. Create a post and add an Image or Gallery block
  2. Select "Choose from Device" from the media upload options and upload an image
  3. When the image has been uploaded, observe that it does not blink or disappear when transitioning to full opacity

Screenshots or screencast

Before After
A gif of an image blinking A gif of an image with a smooth transition
Copy link

github-actions bot commented Jan 16, 2024

Size Change: +1.42 kB (0%)

Total Size: 1.7 MB

Filename Size Change
build/a11y/index.min.js 955 B -9 B (-1%)
build/annotations/index.min.js 2.69 kB -20 B (-1%)
build/api-fetch/index.min.js 2.32 kB -12 B (-1%)
build/autop/index.min.js 2.1 kB -7 B (0%)
build/blob/index.min.js 578 B -12 B (-2%)
build/block-directory/index.min.js 7.22 kB -32 B (0%)
build/block-directory/style-rtl.css 1.02 kB -28 B (-3%)
build/block-directory/style.css 1.02 kB -27 B (-3%)
build/block-editor/content-rtl.css 4.38 kB +70 B (+2%)
build/block-editor/content.css 4.38 kB +71 B (+2%)
build/block-editor/default-editor-styles-rtl.css 381 B -22 B (-5%)
build/block-editor/default-editor-styles.css 381 B -22 B (-5%)
build/block-editor/index.min.js 250 kB +2.76 kB (+1%)
build/block-editor/style-rtl.css 15.5 kB +148 B (+1%)
build/block-editor/style.css 15.5 kB +142 B (+1%)
build/block-library/blocks/audio/theme-rtl.css 126 B -12 B (-9%)
build/block-library/blocks/audio/theme.css 126 B -12 B (-9%)
build/block-library/blocks/button/editor-rtl.css 415 B -4 B (-1%)
build/block-library/blocks/button/editor.css 414 B -3 B (-1%)
build/block-library/blocks/button/style-rtl.css 627 B -5 B (-1%)
build/block-library/blocks/button/style.css 626 B -5 B (-1%)
build/block-library/blocks/cover/style-rtl.css 1.69 kB -11 B (-1%)
build/block-library/blocks/cover/style.css 1.68 kB -12 B (-1%)
build/block-library/blocks/embed/editor-rtl.css 322 B +29 B (+10%) ⚠️
build/block-library/blocks/embed/editor.css 322 B +29 B (+10%) ⚠️
build/block-library/blocks/embed/theme-rtl.css 126 B -12 B (-9%)
build/block-library/blocks/embed/theme.css 126 B -12 B (-9%)
build/block-library/blocks/file/view.min.js 316 B -6 B (-2%)
build/block-library/blocks/form-input/editor-rtl.css 227 B -2 B (-1%)
build/block-library/blocks/form-input/editor.css 227 B -1 B (0%)
build/block-library/blocks/form-submission-notification/editor-rtl.css 340 B -3 B (-1%)
build/block-library/blocks/form-submission-notification/editor.css 340 B -2 B (-1%)
build/block-library/blocks/form/view.min.js 471 B +19 B (+4%)
build/block-library/blocks/freeform/editor-rtl.css 2.61 kB -1 B (0%)
build/block-library/blocks/gallery/editor-rtl.css 947 B -10 B (-1%)
build/block-library/blocks/gallery/editor.css 952 B -10 B (-1%)
build/block-library/blocks/gallery/style-rtl.css 1.72 kB -26 B (-1%)
build/block-library/blocks/gallery/style.css 1.72 kB -27 B (-2%)
build/block-library/blocks/gallery/theme-rtl.css 108 B -14 B (-11%) 👏
build/block-library/blocks/gallery/theme.css 108 B -14 B (-11%) 👏
build/block-library/blocks/html/editor-rtl.css 336 B -4 B (-1%)
build/block-library/blocks/html/editor.css 337 B -4 B (-1%)
build/block-library/blocks/image/editor-rtl.css 863 B +29 B (+3%)
build/block-library/blocks/image/editor.css 862 B +29 B (+3%)
build/block-library/blocks/image/style-rtl.css 1.6 kB -7 B (0%)
build/block-library/blocks/image/style.css 1.59 kB -8 B (0%)
build/block-library/blocks/image/theme-rtl.css 126 B -11 B (-8%)
build/block-library/blocks/image/theme.css 126 B -11 B (-8%)
build/block-library/blocks/image/view.min.js 2.01 kB -2 B (0%)
build/block-library/blocks/navigation-link/editor-rtl.css 668 B -3 B (0%)
build/block-library/blocks/navigation-link/editor.css 669 B -3 B (0%)
build/block-library/blocks/navigation-submenu/editor-rtl.css 296 B -3 B (-1%)
build/block-library/blocks/navigation-submenu/editor.css 295 B -4 B (-1%)
build/block-library/blocks/navigation/editor-rtl.css 2.25 kB -5 B (0%)
build/block-library/blocks/navigation/editor.css 2.26 kB -5 B (0%)
build/block-library/blocks/navigation/style-rtl.css 2.24 kB -11 B (0%)
build/block-library/blocks/navigation/style.css 2.23 kB -9 B (0%)
build/block-library/blocks/navigation/view.min.js 1.1 kB -6 B (-1%)
build/block-library/blocks/page-list/editor-rtl.css 377 B -24 B (-6%)
build/block-library/blocks/page-list/editor.css 377 B -24 B (-6%)
build/block-library/blocks/post-featured-image/style-rtl.css 342 B -3 B (-1%)
build/block-library/blocks/post-featured-image/style.css 342 B -3 B (-1%)
build/block-library/blocks/pullquote/style-rtl.css 354 B +19 B (+6%) 🔍
build/block-library/blocks/pullquote/style.css 354 B +19 B (+6%) 🔍
build/block-library/blocks/query/view.min.js 1.1 kB +458 B (+71%) 🆘
build/block-library/blocks/search/style-rtl.css 614 B +12 B (+2%)
build/block-library/blocks/search/style.css 614 B +12 B (+2%)
build/block-library/blocks/search/view.min.js 471 B -4 B (-1%)
build/block-library/blocks/separator/style-rtl.css 229 B -5 B (-2%)
build/block-library/blocks/separator/style.css 229 B -5 B (-2%)
build/block-library/blocks/shortcode/editor-rtl.css 323 B -6 B (-2%)
build/block-library/blocks/shortcode/editor.css 323 B -6 B (-2%)
build/block-library/blocks/site-logo/editor-rtl.css 754 B -6 B (-1%)
build/block-library/blocks/site-logo/editor.css 754 B -6 B (-1%)
build/block-library/blocks/social-links/style-rtl.css 1.49 kB -4 B (0%)
build/block-library/blocks/social-links/style.css 1.48 kB -4 B (0%)
build/block-library/blocks/spacer/editor-rtl.css 348 B -11 B (-3%)
build/block-library/blocks/spacer/editor.css 348 B -11 B (-3%)
build/block-library/blocks/table/style-rtl.css 639 B -7 B (-1%)
build/block-library/blocks/table/style.css 639 B -6 B (-1%)
build/block-library/blocks/table/theme-rtl.css 146 B -11 B (-7%)
build/block-library/blocks/table/theme.css 146 B -11 B (-7%)
build/block-library/blocks/video/style-rtl.css 185 B -6 B (-3%)
build/block-library/blocks/video/style.css 185 B -6 B (-3%)
build/block-library/blocks/video/theme-rtl.css 126 B -13 B (-9%)
build/block-library/blocks/video/theme.css 126 B -13 B (-9%)
build/block-library/common-rtl.css 1.1 kB -12 B (-1%)
build/block-library/common.css 1.1 kB -13 B (-1%)
build/block-library/editor-rtl.css 12.3 kB +12 B (0%)
build/block-library/editor.css 12.3 kB +9 B (0%)
build/block-library/index.min.js 215 kB -81 B (0%)
build/block-library/style-rtl.css 14.7 kB -40 B (0%)
build/block-library/style.css 14.7 kB -27 B (0%)
build/block-library/theme-rtl.css 688 B -12 B (-2%)
build/block-library/theme.css 693 B -12 B (-2%)
build/block-serialization-default-parser/index.min.js 1.12 kB -8 B (-1%)
build/block-serialization-spec-parser/index.min.js 2.87 kB -2 B (0%)
build/blocks/index.min.js 51.5 kB -58 B (0%)
build/commands/index.min.js 15.5 kB -2 B (0%)
build/commands/style-rtl.css 921 B -26 B (-3%)
build/commands/style.css 918 B -24 B (-3%)
build/components/index.min.js 235 kB -223 B (0%)
build/components/style-rtl.css 12 kB -88 B (-1%)
build/components/style.css 12 kB -87 B (-1%)
build/compose/index.min.js 12.6 kB -143 B (-1%)
build/core-commands/index.min.js 2.71 kB -15 B (-1%)
build/core-data/index.min.js 72.7 kB -74 B (0%)
build/customize-widgets/index.min.js 12.1 kB -9 B (0%)
build/customize-widgets/style-rtl.css 1.34 kB -25 B (-2%)
build/customize-widgets/style.css 1.33 kB -25 B (-2%)
build/data-controls/index.min.js 640 B -11 B (-2%)
build/data/index.min.js 8.92 kB -21 B (0%)
build/date/index.min.js 17.9 kB -4 B (0%)
build/deprecated/index.min.js 451 B -11 B (-2%)
build/dom-ready/index.min.js 324 B -12 B (-4%)
build/dom/index.min.js 4.65 kB -40 B (-1%)
build/edit-post/classic-rtl.css 544 B -27 B (-5%)
build/edit-post/classic.css 545 B -26 B (-5%)
build/edit-post/index.min.js 25 kB +114 B (0%)
build/edit-post/style-rtl.css 5.67 kB -16 B (0%)
build/edit-post/style.css 5.66 kB -16 B (0%)
build/edit-site/index.min.js 195 kB -231 B (0%)
build/edit-site/style-rtl.css 15.2 kB +197 B (+1%)
build/edit-site/style.css 15.2 kB +196 B (+1%)
build/edit-widgets/index.min.js 17.3 kB -58 B (0%)
build/edit-widgets/style-rtl.css 4.48 kB +42 B (+1%)
build/edit-widgets/style.css 4.48 kB +48 B (+1%)
build/editor/index.min.js 61.7 kB -71 B (0%)
build/editor/style-rtl.css 5.43 kB -48 B (-1%)
build/editor/style.css 5.43 kB -49 B (-1%)
build/element/index.min.js 4.83 kB -41 B (-1%)
build/escape-html/index.min.js 537 B -11 B (-2%)
build/format-library/index.min.js 7.85 kB -126 B (-2%)
build/format-library/style-rtl.css 478 B -22 B (-4%)
build/format-library/style.css 477 B -23 B (-5%)
build/hooks/index.min.js 1.55 kB -23 B (-1%)
build/html-entities/index.min.js 448 B -6 B (-1%)
build/i18n/index.min.js 3.58 kB -28 B (-1%)
build/interactivity/file.min.js 440 B -2 B (0%)
build/interactivity/image.min.js 2.15 kB -4 B (0%)
build/interactivity/index.min.js 12.8 kB -185 B (-1%)
build/interactivity/navigation.min.js 1.23 kB +3 B (0%)
build/interactivity/query.min.js 884 B +93 B (+12%) ⚠️
build/is-shallow-equal/index.min.js 527 B -8 B (-1%)
build/keyboard-shortcuts/index.min.js 1.74 kB -18 B (-1%)
build/keycodes/index.min.js 1.46 kB -33 B (-2%)
build/list-reusable-blocks/index.min.js 2.11 kB +4 B (0%)
build/list-reusable-blocks/style-rtl.css 836 B -29 B (-3%)
build/list-reusable-blocks/style.css 836 B -29 B (-3%)
build/media-utils/index.min.js 2.9 kB -16 B (-1%)
build/notices/index.min.js 948 B -16 B (-2%)
build/nux/index.min.js 2 kB -16 B (-1%)
build/nux/style-rtl.css 735 B -40 B (-5%)
build/nux/style.css 732 B -39 B (-5%)
build/patterns/index.min.js 5.46 kB +92 B (+2%)
build/patterns/style-rtl.css 540 B -24 B (-4%)
build/patterns/style.css 539 B -25 B (-4%)
build/plugins/index.min.js 1.8 kB -14 B (-1%)
build/preferences-persistence/index.min.js 2.07 kB -9 B (0%)
build/preferences/index.min.js 2.81 kB +282 B (+11%) ⚠️
build/preferences/style-rtl.css 698 B -27 B (-4%)
build/preferences/style.css 700 B -28 B (-4%)
build/primitives/index.min.js 975 B -19 B (-2%)
build/priority-queue/index.min.js 1.52 kB -2 B (0%)
build/private-apis/index.min.js 1 kB -13 B (-1%)
build/react-i18n/index.min.js 623 B -8 B (-1%)
build/react-refresh-entry/index.min.js 9.47 kB +2 B (0%)
build/react-refresh-runtime/index.min.js 6.78 kB +1 B (0%)
build/redux-routine/index.min.js 2.7 kB -3 B (0%)
build/reusable-blocks/index.min.js 2.72 kB -21 B (-1%)
build/reusable-blocks/style-rtl.css 243 B -22 B (-8%)
build/reusable-blocks/style.css 243 B -22 B (-8%)
build/rich-text/index.min.js 10.4 kB -38 B (0%)
build/router/index.min.js 1.79 kB +2 B (0%)
build/server-side-render/index.min.js 1.95 kB -11 B (-1%)
build/shortcode/index.min.js 1.39 kB -8 B (-1%)
build/style-engine/index.min.js 2.07 kB +11 B (+1%)
build/token-list/index.min.js 582 B -5 B (-1%)
build/url/index.min.js 3.72 kB -104 B (-3%)
build/viewport/index.min.js 957 B -10 B (-1%)
build/warning/index.min.js 249 B -10 B (-4%)
build/widgets/index.min.js 7.21 kB -10 B (0%)
build/widgets/style-rtl.css 1.15 kB -27 B (-2%)
build/widgets/style.css 1.16 kB -26 B (-2%)
build/wordcount/index.min.js 1.02 kB -4 B (0%)
ℹ️ View Unchanged
Filename Size
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 150 B
build/block-library/blocks/audio/editor.css 150 B
build/block-library/blocks/audio/style-rtl.css 122 B
build/block-library/blocks/audio/style.css 122 B
build/block-library/blocks/avatar/editor-rtl.css 116 B
build/block-library/blocks/avatar/editor.css 116 B
build/block-library/blocks/avatar/style-rtl.css 104 B
build/block-library/blocks/avatar/style.css 104 B
build/block-library/blocks/block/editor-rtl.css 305 B
build/block-library/blocks/block/editor.css 305 B
build/block-library/blocks/buttons/editor-rtl.css 337 B
build/block-library/blocks/buttons/editor.css 337 B
build/block-library/blocks/buttons/style-rtl.css 332 B
build/block-library/blocks/buttons/style.css 332 B
build/block-library/blocks/calendar/style-rtl.css 239 B
build/block-library/blocks/calendar/style.css 239 B
build/block-library/blocks/categories/editor-rtl.css 113 B
build/block-library/blocks/categories/editor.css 112 B
build/block-library/blocks/categories/style-rtl.css 124 B
build/block-library/blocks/categories/style.css 124 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 124 B
build/block-library/blocks/code/theme.css 124 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 421 B
build/block-library/blocks/columns/style.css 421 B
build/block-library/blocks/comment-author-avatar/editor-rtl.css 125 B
build/block-library/blocks/comment-author-avatar/editor.css 125 B
build/block-library/blocks/comment-content/style-rtl.css 92 B
build/block-library/blocks/comment-content/style.css 92 B
build/block-library/blocks/comment-template/style-rtl.css 199 B
build/block-library/blocks/comment-template/style.css 198 B
build/block-library/blocks/comments-pagination-numbers/editor-rtl.css 123 B
build/block-library/blocks/comments-pagination-numbers/editor.css 121 B
build/block-library/blocks/comments-pagination/editor-rtl.css 222 B
build/block-library/blocks/comments-pagination/editor.css 209 B
build/block-library/blocks/comments-pagination/style-rtl.css 235 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 840 B
build/block-library/blocks/comments/editor.css 839 B
build/block-library/blocks/comments/style-rtl.css 637 B
build/block-library/blocks/comments/style.css 636 B
build/block-library/blocks/cover/editor-rtl.css 647 B
build/block-library/blocks/cover/editor.css 650 B
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 98 B
build/block-library/blocks/details/style.css 98 B
build/block-library/blocks/embed/style-rtl.css 410 B
build/block-library/blocks/embed/style.css 410 B
build/block-library/blocks/file/editor-rtl.css 316 B
build/block-library/blocks/file/editor.css 316 B
build/block-library/blocks/file/style-rtl.css 280 B
build/block-library/blocks/file/style.css 281 B
build/block-library/blocks/footnotes/style-rtl.css 201 B
build/block-library/blocks/footnotes/style.css 199 B
build/block-library/blocks/form-input/style-rtl.css 343 B
build/block-library/blocks/form-input/style.css 343 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/freeform/editor.css 2.61 kB
build/block-library/blocks/group/editor-rtl.css 654 B
build/block-library/blocks/group/editor.css 654 B
build/block-library/blocks/group/style-rtl.css 57 B
build/block-library/blocks/group/style.css 57 B
build/block-library/blocks/group/theme-rtl.css 78 B
build/block-library/blocks/group/theme.css 78 B
build/block-library/blocks/heading/style-rtl.css 189 B
build/block-library/blocks/heading/style.css 189 B
build/block-library/blocks/latest-comments/style-rtl.css 357 B
build/block-library/blocks/latest-comments/style.css 357 B
build/block-library/blocks/latest-posts/editor-rtl.css 213 B
build/block-library/blocks/latest-posts/editor.css 212 B
build/block-library/blocks/latest-posts/style-rtl.css 478 B
build/block-library/blocks/latest-posts/style.css 478 B
build/block-library/blocks/list/style-rtl.css 88 B
build/block-library/blocks/list/style.css 88 B
build/block-library/blocks/media-text/editor-rtl.css 266 B
build/block-library/blocks/media-text/editor.css 263 B
build/block-library/blocks/media-text/style-rtl.css 505 B
build/block-library/blocks/media-text/style.css 503 B
build/block-library/blocks/more/editor-rtl.css 431 B
build/block-library/blocks/more/editor.css 431 B
build/block-library/blocks/navigation-link/style-rtl.css 103 B
build/block-library/blocks/navigation-link/style.css 103 B
build/block-library/blocks/nextpage/editor-rtl.css 395 B
build/block-library/blocks/nextpage/editor.css 395 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 235 B
build/block-library/blocks/paragraph/editor.css 235 B
build/block-library/blocks/paragraph/style-rtl.css 335 B
build/block-library/blocks/paragraph/style.css 335 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 508 B
build/block-library/blocks/post-comments-form/style.css 508 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 61 B
build/block-library/blocks/post-date/style.css 61 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-excerpt/style-rtl.css 141 B
build/block-library/blocks/post-excerpt/style.css 141 B
build/block-library/blocks/post-featured-image/editor-rtl.css 666 B
build/block-library/blocks/post-featured-image/editor.css 662 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 409 B
build/block-library/blocks/post-template/style.css 408 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 69 B
build/block-library/blocks/post-time-to-read/style.css 69 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 135 B
build/block-library/blocks/pullquote/editor.css 135 B
build/block-library/blocks/pullquote/theme-rtl.css 168 B
build/block-library/blocks/pullquote/theme.css 168 B
build/block-library/blocks/query-pagination-numbers/editor-rtl.css 122 B
build/block-library/blocks/query-pagination-numbers/editor.css 121 B
build/block-library/blocks/query-pagination/editor-rtl.css 221 B
build/block-library/blocks/query-pagination/editor.css 211 B
build/block-library/blocks/query-pagination/style-rtl.css 288 B
build/block-library/blocks/query-pagination/style.css 284 B
build/block-library/blocks/query-title/style-rtl.css 63 B
build/block-library/blocks/query-title/style.css 63 B
build/block-library/blocks/query/editor-rtl.css 486 B
build/block-library/blocks/query/editor.css 486 B
build/block-library/blocks/query/style-rtl.css 312 B
build/block-library/blocks/query/style.css 308 B
build/block-library/blocks/quote/style-rtl.css 237 B
build/block-library/blocks/quote/style.css 237 B
build/block-library/blocks/quote/theme-rtl.css 223 B
build/block-library/blocks/quote/theme.css 226 B
build/block-library/blocks/read-more/style-rtl.css 140 B
build/block-library/blocks/read-more/style.css 140 B
build/block-library/blocks/rss/editor-rtl.css 149 B
build/block-library/blocks/rss/editor.css 149 B
build/block-library/blocks/rss/style-rtl.css 289 B
build/block-library/blocks/rss/style.css 288 B
build/block-library/blocks/search/editor-rtl.css 184 B
build/block-library/blocks/search/editor.css 184 B
build/block-library/blocks/search/theme-rtl.css 114 B
build/block-library/blocks/search/theme.css 114 B
build/block-library/blocks/separator/editor-rtl.css 146 B
build/block-library/blocks/separator/editor.css 146 B
build/block-library/blocks/separator/theme-rtl.css 194 B
build/block-library/blocks/separator/theme.css 194 B
build/block-library/blocks/site-logo/style-rtl.css 204 B
build/block-library/blocks/site-logo/style.css 204 B
build/block-library/blocks/site-tagline/editor-rtl.css 86 B
build/block-library/blocks/site-tagline/editor.css 86 B
build/block-library/blocks/site-title/editor-rtl.css 116 B
build/block-library/blocks/site-title/editor.css 116 B
build/block-library/blocks/site-title/style-rtl.css 57 B
build/block-library/blocks/site-title/style.css 57 B
build/block-library/blocks/social-link/editor-rtl.css 184 B
build/block-library/blocks/social-link/editor.css 184 B
build/block-library/blocks/social-links/editor-rtl.css 682 B
build/block-library/blocks/social-links/editor.css 681 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 395 B
build/block-library/blocks/table/editor.css 395 B
build/block-library/blocks/tag-cloud/style-rtl.css 251 B
build/block-library/blocks/tag-cloud/style.css 253 B
build/block-library/blocks/template-part/editor-rtl.css 403 B
build/block-library/blocks/template-part/editor.css 403 B
build/block-library/blocks/template-part/theme-rtl.css 101 B
build/block-library/blocks/template-part/theme.css 101 B
build/block-library/blocks/term-description/style-rtl.css 111 B
build/block-library/blocks/term-description/style.css 111 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 166 B
build/block-library/blocks/text-columns/style.css 166 B
build/block-library/blocks/verse/style-rtl.css 99 B
build/block-library/blocks/verse/style.css 99 B
build/block-library/blocks/video/editor-rtl.css 552 B
build/block-library/blocks/video/editor.css 555 B
build/block-library/classic-rtl.css 179 B
build/block-library/classic.css 179 B
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/interactivity/router.min.js 971 B
build/interactivity/search.min.js 610 B
build/modules/importmap-polyfill.min.js 12.2 kB
build/vendors/inert-polyfill.min.js 2.48 kB
build/vendors/react-dom.min.js 41.8 kB
build/vendors/react.min.js 4.02 kB

compressed-size-action

@derekblank derekblank added [Type] Enhancement A suggestion for improvement. Mobile App - i.e. Android or iOS Native mobile impl of the block editor. (Note: used in scripts, ping mobile folks to change) Mobile App - Automation Label used to initiate Mobile App PR Automation labels Jan 16, 2024
@derekblank derekblank marked this pull request as ready for review January 19, 2024 04:47
Copy link

github-actions bot commented Jan 19, 2024

Flaky tests detected in 5c4d2d7.
Some tests passed with failed attempts. The failures may not be related to this commit but are still reported for visibility. See the documentation for more information.

🔍 Workflow run URL: https://github.com/WordPress/gutenberg/actions/runs/7707646158
📝 Reported issues:

Copy link
Member

@dcalhoun dcalhoun left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This turned out to be a complex subject. 😅 From my initial testing, the functionality works as described. Well done! 👏🏻

I did notice that replacing media for an Image or Gallery block does not show the newly selected local image immediately. Instead, it displays the previous image until the upload completes, it then swaps to the new image instantly. I'm not sure if this an existing issue or not.

I also noticed an image can flash when the upload finishes in a Gallery block, but only on occasion. It occurs sometimes when I upload ~4 images to a new Gallery block. It could be unrelated to the Gallery block and I just happen to recreate it more frequently with Gallery block given it generally houses multiple images.

Resolves layout display issue when block is selected
@derekblank
Copy link
Member Author

I did notice that replacing media for an Image or Gallery block does not show the newly selected local image immediately. Instead, it displays the previous image until the upload completes, it then swaps to the new image instantly. I'm not sure if this an existing issue or not.

@dcalhoun Good catch, I also noted that the newly selected local image does not immediately replace the local file until it's uploaded to the server. While it still prevents the flickering, I think it's worth seeing if we can improve the replace behavior as well.

derekblank and others added 6 commits January 24, 2024 12:31
The mobile image component introduce new asynchronous effects. We must
await the result of those effect, in the form of asserting UI changes
from the subsequent state updates, to satisfy the React test utilities
expectation that unexpected re-renders do not occur after the test
completes.

Additionally, there were instances of awaiting `act` invocations that
were not asynchronous. The erroneous usage of `await` for these
synchronous `act` calls resulted in cryptic errors. In reality, the
logic run within these `act` calls are synchronous and should merely be
wrapped in `act` to signal that they result in a re-render.
Using width: 1 and height: 1 ensures that onLoad will fire
Copy link
Member

@dcalhoun dcalhoun left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I did not note any new regressions in my testing. During my testing I noted:

  • [Known Regression] Replacing an image does not display the new image until the upload is completed, which is a regression that we may choose to ship. I left an inline comment regarding a potential solution.
  • On iOS only, Media + Text and Cover blocks do not display the local image during the upload, but this appears to be true in the production app as well.
  • Choosing a photo from a "free photo library" does not result in a smooth transition.
Copy link
Member

@dcalhoun dcalhoun left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The proposed changes look good to me.

I have not retested with the latest commits after #57869 (review), as there is not an updated prototype build. However, if you'd like for me to re-test something, please let me know.

I will also note that we should re-test for any Android regressions you noted in #57869 (comment).

Thank you for improving this image upload experience!

On iOS, add 1 to height to account for the 1px non-visible image
that is used to determine when the network image has loaded
We also must verify that it is not NaN, as it can be NaN when the image is loading.
@derekblank
Copy link
Member Author

I will also note that we should re-test for any Android regressions you noted in #57869 (comment).

I ran through the regression tests for both platforms, and did not note any with the updated logic. Your logic change also improved the replacement behavior for Android -- thanks for the contribution!

I did note that when an image is selected on iOS, there is a 1px offset between the border and the image due to the non-visible image. I noted this as something to fix in a previous comment, and updated the imageSelectedStyles to account or this on iOS.

Before | After

Note the 1px offset on the bottom of the selected image in the "Before" example:

Before After
@derekblank
Copy link
Member Author

derekblank commented Jan 31, 2024

@dcalhoun I have started the main apps build CI jobs to reference the latest changes, and tested both platforms successfully locally. Although you've already approved, I just wanted to provide a final chance for any review from the last change to update the selected image styles, and general testing using the prototype builds (which should have succeeded by the time you read this).

Tomorrow I intend to test the main apps CI builds and if successful, merge the Gutenberg / Gutenberg Mobile PRs before cutting the 1.112.0 release. Thanks for your feedback and contributions to this fix. 🙇

Copy link
Member

@dcalhoun dcalhoun left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Latest changes look good and tested well for me on iOS and Android. Hopefully we can refactor/remove this complexity in the future. Thanks for seeing this improvement through!

@derekblank derekblank merged commit 7b77931 into trunk Jan 31, 2024
56 checks passed
@derekblank derekblank deleted the rnmobile/prevent-image-flicker-when-uploading branch January 31, 2024 22:09
@github-actions github-actions bot added this to the Gutenberg 17.7 milestone Jan 31, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Mobile App - Automation Label used to initiate Mobile App PR Automation Mobile App - i.e. Android or iOS Native mobile impl of the block editor. (Note: used in scripts, ping mobile folks to change) [Type] Enhancement A suggestion for improvement.
2 participants