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

Add an apiFetch middleware to automatically handle media upload failures #17858

Merged
merged 6 commits into from
Oct 14, 2019

Conversation

youknowriad
Copy link
Contributor

@youknowriad youknowriad commented Oct 9, 2019

closes #17474

Implements the new Media "post-process" endpoint to recover from media upload failures

Testing instructions

See here #17474 (comment)

or #17858 (comment)

Perhaps another (simpler) way to test is to add the following to a WP plugin:

add_filter( 'intermediate_image_sizes_advanced', '_test_image_post_processing' );
add_filter( 'wp_get_missing_image_subsizes', '_test_image_post_processing' );
function _test_image_post_processing( $sizes ) {
	if ( rand( 1, 2 ) === 2 ) {
		trigger_error( '', E_USER_ERROR );
		exit;
	}
	
	return $sizes;
}

It will fail 50% of the time and should trigger multiple post_process request.

With that in place, you either drag & drop an image from your desktop or use the upload button.

@youknowriad youknowriad added [Type] Bug An existing feature does not function as intended [Feature] Media Anything that impacts the experience of managing media REST API Interaction Related to REST API labels Oct 9, 2019
@youknowriad youknowriad self-assigned this Oct 9, 2019
@youknowriad youknowriad requested a review from azaozz October 9, 2019 09:31
@@ -80,48 +77,9 @@ const defaultFetchHandler = ( nextOptions ) => {
}
);

const parseResponse = ( response ) => {
Copy link
Contributor Author

Choose a reason for hiding this comment

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

The parsing and error normalizing here was extracted to be reused in middlewares.

@azaozz
Copy link
Contributor

azaozz commented Oct 9, 2019

Trying to test this in several ways, works properly when the initial upload request fails, but couldn't get it to do more than one post_process request.

The X-WP-Upload-Attachment-ID header is set for all uploads, but post-processing is currently only possible for images. Perhaps it would be good to check whether the upload is an image before sending a request.

Also, (assuming this is not in yet), if all (5) attempts fail, the new attachment will have to be deleted, and the error should tell the user to "scale down the image and try uploading it again".

@azaozz
Copy link
Contributor

azaozz commented Oct 9, 2019

Perhaps another (simpler) way to test is to add the following to a WP plugin:

add_filter( 'intermediate_image_sizes_advanced', '_test_image_post_processing' );
add_filter( 'wp_get_missing_image_subsizes', '_test_image_post_processing' );
function _test_image_post_processing( $sizes ) {
	if ( rand( 1, 2 ) === 2 ) {
		trigger_error( '', E_USER_ERROR );
		exit;
	}
	
	return $sizes;
}

It will fail 50% of the time and should trigger multiple post_process request.

@youknowriad
Copy link
Contributor Author

The X-WP-Upload-Attachment-ID header is set for all uploads, but post-processing is currently only possible for images. Perhaps it would be good to check whether the upload is an image before sending a request.

I guess the request will just fail for these other media. I wonder if it's better to not check. Potentially, we might need post processing for other medias in the future. The check in a generic way in the middleware might be a bit complex to do. How are you checking in the media library?

@youknowriad
Copy link
Contributor Author

Also, I personally feel that instead of randomly trying to post process 5 times, the server should tell us that it's possible to post process or not using a header.

@youknowriad
Copy link
Contributor Author

Another question: is it possible that a failure request don't contain the "ID"? Said differently, for "delete" and "post-process" requests, should we use the last id received or just keep the first one and use it for all follow-up requests?

@youknowriad
Copy link
Contributor Author

Also potentially, the endpoint should return the "post-process" URL as a header and the client could just "POST" to that URL without any data. It would be more generic.

@getsource
Copy link
Member

getsource commented Oct 10, 2019

The X-WP-Upload-Attachment-ID header is set for all uploads, but post-processing is currently only possible for images. Perhaps it would be good to check whether the upload is an image before sending a request.

I guess the request will just fail for these other media. I wonder if it's better to not check. Potentially, we might need post processing for other medias in the future.

PDFs are the other one I currently know about.
WP also does processing of Audio and Video files. For example, with MP3s, ID3 data is extracted, including the creation of a thumbnail (attachment created). I suspect this round wouldn't handle separating any of that, but thought it might be useful information.

@azaozz
Copy link
Contributor

azaozz commented Oct 10, 2019

(Response to #17858 (comment))

I guess the request will just fail for these other media. I wonder if it's better to not check.

Yeah, that's a possibility too.

Potentially, we might need post processing for other medias in the future.

The new end-point requires the create-image-subsizes "action" which (logically) limits it only to image uploads. The idea was to add other actions for other file types that may need post-processing.

Looking there again, we can check what type of file was uploaded on the PHP side, no need to get that info from the client.

The check in a generic way in the middleware might be a bit complex to do. How are you checking in the media library?

The Media Library uses Plupload, it checks the file type (sets mime type prop) before uploading.

@azaozz
Copy link
Contributor

azaozz commented Oct 10, 2019

(Response to #17858 (comment))

Also, I personally feel that instead of randomly trying to post process 5 times, the server should tell us that it's possible to post process or not using a header.

Yes, it does that. The client should look in the error type/error message returned from the server. If it is an HTTP 500 error (meaning a fatal error in PHP) it can assume there is more work to be done on the server.

If the error is 400, 403, etc. there's no need to do another request. In these cases there is also a "proper" response from the API.

The random/arbitrary part here is how many times to retry to do the post-processing when there are continuous PHP fatal errors. Typically it can fail because the server is busy at that moment, or because there's not enough memory available. In the first case it would take 30 seconds for each request. In the second case it will fail fairly quickly. However there may be other reasons for the error, and post-processing may succeed on a second/third attempt. Seems 3 to 5 times is a good rule of thumb. This can probably be enhanced further in the future.

@azaozz
Copy link
Contributor

azaozz commented Oct 10, 2019

(Reply to #17858 (comment))

Another question: is it possible that a failure request don't contain the "ID"? Said differently, for "delete" and "post-process" requests, should we use the last id received or just keep the first one and use it for all follow-up requests?

Yes, "delete" and "post-process" requests should use the "already known" attachment ID. Earlier version of the API patch did "pass through" the ID, but later that part was removed. If that makes it easier/better lets add it back (just need to add the custom header in post_process_item()).

@azaozz
Copy link
Contributor

azaozz commented Oct 10, 2019

(Reply to #17858 (comment))

Also potentially, the endpoint should return the "post-process" URL as a header and the client could just "POST" to that URL without any data. It would be more generic.

Ideally, yes. However there are some architectural difficulties on the API side to do that in time, before the expected PHP fatal errors. That may get fixed/enhanced in the future.

@azaozz
Copy link
Contributor

azaozz commented Oct 10, 2019

To summarize:

  1. TBD: shall we remove the create-image-subsizes action from the /post-process end-point? Looking at it again, it's not strictly necessary to have an "action" there. Both client and server "know" what file type was just uploaded at this point. The client can decide whether to retry post-processing after a HTTP 500 error, and the server would "know" what action to take for that file.
  2. TBD: shall we pass-through the new attachment ID on requests to the /post-process end-point?
  3. TODO: the client should look into HTTP error types/detect HTTP 500 errors and then do a request to post process images. It would be good to do that only when an image is uploaded (but that may be added in the future).

@azaozz
Copy link
Contributor

azaozz commented Oct 10, 2019

(Reply to #17474 (comment))

Any thoughts on the implementation? Is this something that should be a wp.apiFetch middleware or implemented more specifically per use-case?

Looking at the code, given all the "requirements" mentioned above, I guess it would be nice if the middleware doesn't try to handle these errors "automatically", but instead "pass them up the stack" in some way?

It would be nice to have some more logic on the client side to determine when to do another /post-process request depending on the error type and on uploaded file type? Then that additional logic can be in the "upload" component which can expose it and better determine what happens.

Or perhaps this can be some form of a "callback" on all HTTP errors (with access to the low-level error data)?

@TimothyBJacobs
Copy link
Member

I guess the request will just fail for these other media. I wonder if it's better to not check. Potentially, we might need post processing for other medias in the future. The check in a generic way in the middleware might be a bit complex to do. How are you checking in the media library?

For other types of media the request will succeed and return the results of a GET request to the item with an edit context.

Also, I personally feel that instead of randomly trying to post process 5 times, the server should tell us that it's possible to post process or not using a header.

The server can't know whether it is possible to post process or not. Whether the subsizes can be generated just depends on if the server has enough resources at the moment to process the request.

If that makes it easier/better lets add it back (just need to add the custom header in post_process_item()).

I'd like to not add any more native header calls to the REST API endpoints if at all possible. Looking at the patch, I don't see why it'd be technically required.

TBD: shall we remove the create-image-subsizes action from the /post-process end-point? Looking at it again, it's not strictly necessary to have an "action" there. The client can decide whether to retry post-processing after a HTTP 500 error, and the server can "see" what kind of file was just uploaded and take appropriate action.

I'm -1 to this because it is less forward compatible. When more post processing actions are added in the future, distinguishing between them will be more complex if we didn't require a specific action to be specified up until them.

I think the create-image-subsizes would be fine for pdf thumbs. What types of subsizes wouldn't it make sense for? I guess resizing videos perhaps? But I think generating different video sizes would be an optional post processing step.


You can also check for missing_image_sizes by doing a GET request with an edit context to see if progress is being made when calling post-process.

@azaozz
Copy link
Contributor

azaozz commented Oct 10, 2019

For other types of media the request will succeed and return the results of a GET request to the item with an edit context.

If we have a specific action, shouldn't it return an error instead saying that the action is not supported for the file type?

Also, if eventually there are more actions in the future, what happens when a specific action is not available for a specific file type? Should be an error, right? For example setting "create-image-subsizes" on a text file upload or "resize-video" action on an image upload? WP supports uploading of many file types, only few of them would need any post-processing.

I'm -1 to this because it is less forward compatible.

Yeah, may make sense to have an action there for the eventual case more than one type of post processing is available for a specific file type. For example for videos there may be: "optimize video" and "create video thumbnail". Then eventually the client may decide to do one type of post-processing but skip the other?

On the other hand that will prevent the client to be able to do "all" post-processing with one request... Not sure what's worse :)

The facts are that at this point both the client and the server "know" what file was uploaded. The easiest way imho would be for the client to do a "try to post-process" request after HTTP 500 errors for specific file types. Having an additional action there further limits this, and may eventually require the client to do more than one request.

@youknowriad
Copy link
Contributor Author

It seems to me that the endpoint has been design with the thinking that the post-processing is not really necessary so it's the responsibility of the client to know and ask for the right post-processing (action) on failures. But what happens if we don't post-process? Is it really optional?

The thinking with my suggestions is that post-processing is not optional and the client shouldn't have to decide what post-process to perform or not, it should just tell the server post-process until it finishes.


I can workaround the current design (I'll refresh the patch) and I don't think changes are necessarily required for WordPress 5.3 but I wanted to clarify the thinking here.

@youknowriad
Copy link
Contributor Author

I updated the patch, now it handles deletions properly and also shows the error properly.
It's still a middleware because I think that's something generic (ideally it's just one request, the fact that it's multiple is an implementation detail of the server not capable of running on a single request). I personally think it's ready.

Noting that I won't be able to work on this a lot more, since today is my last day of work before RC.

@azaozz
Copy link
Contributor

azaozz commented Oct 13, 2019

Testing this again, it seems to work properly here:

retries2

For this test the timeout in PHP was set to 3 sec. Note how it timed out three times and succeeded on the forth request to post-process.

@azaozz
Copy link
Contributor

azaozz commented Oct 13, 2019

The thinking with my suggestions is that post-processing is not optional and the client shouldn't have to decide what post-process to perform or not, it should just tell the server post-process until it finishes.

Yes, that was the original idea too. The client should "tell" the server to finish post-processing if there was a server error. The only thing that may still be needed would be to do this only on relevant (HTTP 500) errors. For example the server would not be able to do anything if the error was with permissions, HTTP 400 or 403, etc.

I can workaround the current design (I'll refresh the patch) and I don't think changes are necessarily required for WordPress 5.3 but I wanted to clarify the thinking here.

Right. I'm thinking it would be ideal if this is fixed in the end-point now, before releasing it in WP 5.3. The create-image-subsizes "action" should be removed. The server "knows" what needs to be done to post-process the upload, there is no need to limit this additionally. Then, if something like that is needed in the future, support for an optional "action" can be added.

Alternatively the create-image-subsizes action can be made optional now, but I'm somewhat wary about adding something that is not needed/used.

@getsource
Copy link
Member

Thanks so much @youknowriad @azaozz! I hadn't commented earlier because I wanted to wait until I got this to work, but realized the feedback might be helpful.

The error message looks much better, so I think this would be helpful merged.

However, I've been able to simulate failure (attachment created, but sizes not finished) by reducing the max_execution_time, but can't get this to auto-retry on the new WordPress Docker env. Going to try today in VVV and see if I can track it down.

@youknowriad
Copy link
Contributor Author

Pushed a tweak to limit the behavior to 500 errors.
As I said earlier, we're going to do the Gutenberg RC today and include the fixes in WP 5.3 RC. So our deadline here is in like 4 hours.

@getsource
Copy link
Member

As an update:

I think it might be because continue is working on 500 errors, but not on 502, which is what I’m getting on a partial Upload on the core test environments.

@getsource
Copy link
Member

This is currently working for me and retrying / finishing images that 500. Nice!

I'm working on testing adding 502 (core patch in testing here: https://core.trac.wordpress.org/attachment/ticket/47872/47872.2.diff), but unfortunately have to stop for the night.

Thanks again for all your work on this!

@azaozz
Copy link
Contributor

azaozz commented Oct 14, 2019

I'm working on testing adding 502...

Good catch :) 502s may be caused by other problems but better to retry anyway, for cases where they are caused by PHP fatal errors on the original server. Going to add the above patch to core.

@azaozz
Copy link
Contributor

azaozz commented Oct 14, 2019

With this, think this is ready. Still hoping the REST API team will reconsider removing the create-image-subsizes "action" from the end-point (or at least make it optional) as it doesn't serve any purpose.

Copy link
Contributor

@epiqueras epiqueras left a comment

Choose a reason for hiding this comment

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

Things seem to work in all my tests, but we should open an issue to refactor this code and make it easier to audit.

Comment on lines +82 to +83
.catch( ( response ) => parseAndThrowError( response, parse ) )
.then( ( response ) => parseResponseAndNormalizeError( response, parse ) );
Copy link
Contributor

Choose a reason for hiding this comment

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

This deserves inline comments to explain the flow.

@@ -179,5 +138,6 @@ apiFetch.createNonceMiddleware = createNonceMiddleware;
apiFetch.createPreloadingMiddleware = createPreloadingMiddleware;
apiFetch.createRootURLMiddleware = createRootURLMiddleware;
apiFetch.fetchAllMiddleware = fetchAllMiddleware;
apiFetch.mediaUploadMiddleware = mediaUploadMiddleware;
Copy link
Contributor

Choose a reason for hiding this comment

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

Should we add this to the README middleware section?

@@ -0,0 +1,70 @@
/**
Copy link
Contributor

Choose a reason for hiding this comment

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

The flow here could be simplified a lot and more JSDOC and inline comments should be added.

Let's add a note, but not block this PR so we can get it in the RC.

return next( { ...options, parse: false } )
.catch( ( response ) => {
const attachmentId = response.headers.get( 'x-wp-upload-attachment-id' );
if ( response.status === 500 && attachmentId ) {
Copy link
Contributor

Choose a reason for hiding this comment

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

Do we also need to test for 502s here?

cc @azaozz

Copy link
Contributor

@azaozz azaozz Oct 14, 2019

Choose a reason for hiding this comment

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

Yes. Based on @getsource's testing 502s can also mean fatal PHP errors. Going to add that to core's media modal as well.

Comment on lines +44 to +47
next( {
path: `/wp/v2/media/${ attachmentId }?force=true`,
method: 'DELETE',
} );
Copy link
Contributor

Choose a reason for hiding this comment

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

This could throw right?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I think we don't care if this throws, we need to show the post-processing error anyway in that case.

return Promise.reject( response );
} );
}
return Promise.reject( response );
Copy link
Contributor

Choose a reason for hiding this comment

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

I don't think anything will parse this error.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Good catch we need to wrap it with parseAndThrowError

@epiqueras epiqueras force-pushed the add/media-failures-handling branch from 566abd3 to 6dc1a18 Compare October 14, 2019 18:19
@epiqueras epiqueras force-pushed the add/media-failures-handling branch from 6dc1a18 to 5a904d9 Compare October 14, 2019 18:21
@epiqueras epiqueras merged commit cb3b787 into master Oct 14, 2019
@epiqueras epiqueras deleted the add/media-failures-handling branch October 14, 2019 18:52
@youknowriad youknowriad added this to the Gutenberg 6.7 milestone Oct 15, 2019
gziolo pushed a commit that referenced this pull request Oct 15, 2019
…res (#17858)

* Add an apiFetch middleware to automatically handle media upload failures

* Remove the attachement on failures

* Handle errors properly

* limit the media upload middleware to the 500 responses

* Fix the error handling and unit tests

* Api Fetch: Check for 502s and parse uncaught errors in Media Upload middleware.
@kadamwhite
Copy link
Contributor

TBD: shall we remove the create-image-subsizes action from the /post-process end-point? Looking at it again, it's not strictly necessary to have an "action" there. Both client and server "know" what file type was just uploaded at this point. The client can decide whether to retry post-processing after a HTTP 500 error, and the server would "know" what action to take for that file.
...
The create-image-subsizes "action" should be removed. The server "knows" what needs to be done to post-process the upload, there is no need to limit this additionally. Then, if something like that is needed in the future, support for an optional "action" can be added.

I disagree, and continue to think making the action required is a good course. My feeling is that removing it makes the most sense only if we were beginning to consider this endpoint more of a resource of itself, rather than an action trigger. If it were :id/sizes or something, I could imagine assuming that the endpoint would "know" what was needed and take appropriate secondary action if the information wasn't there; it'd be a bit non-standard but not too hard to work with, in my opinion.

However, if we remain with post-process, as I think we should, I think that the action does serve a useful purpose. It's a small thing to build a wrapper method around so I don't mind the verbosity, and it would be much easier to make this the default later than to add the need to pass an action later. For that reason I believe we should stick with the solution of passing a specific action.

TBD: shall we pass-through the new attachment ID on requests to the /post-process end-point?

Haven't checked the patch to see if this is being included but I don't think it would need to be, as the ID should be available as a route parameter.

SergioEstevao pushed a commit that referenced this pull request Nov 1, 2019
* Adds correct escaping for urls (#17932)

* Add an apiFetch middleware to automatically handle media upload failures (#17858)

* Add an apiFetch middleware to automatically handle media upload failures

* Remove the attachement on failures

* Handle errors properly

* limit the media upload middleware to the 500 responses

* Fix the error handling and unit tests

* Api Fetch: Check for 502s and parse uncaught errors in Media Upload middleware.

* Fix: Gradient presets to verify some MU kses rules (#17940)

* Bump plugin version to 6.7.0-rc.1

* Code Style: Change name of accumulated variables when using reduce function (#17893)

* Fix issue-7378 - change name of accumulated variables when using reduce function

* fix issue-7378 - update variables names

* fix issue-7378 - update variables names

* Fix:Image Block: Hide 'noreferrer' and 'noopener' in Link Rel (#17398)

* Update the regex used when removing NEW_TAB_REL and add trimming (+2 squashed commits)
Squashed commits:
[cf71759c3] Accessibility:Image Block:Link Editor: Move Link Rel field below Open new tab toggle
[310a23c33] Fix:Image Block:Link Editor: Hide 'noreferrer' and 'noopener' in Link Rel field

* post rebases fixes


Co-authored-by: Jorge Costa <jorge.costa@developer.pt>

* Change Cover block min height input step size to 1 (#17927)

* chore(release): publish

 - @wordpress/a11y@2.5.1
 - @wordpress/annotations@1.7.2
 - @wordpress/api-fetch@3.6.2
 - @wordpress/autop@2.5.1
 - @wordpress/babel-preset-default@4.6.2
 - @wordpress/blob@2.5.1
 - @wordpress/block-directory@1.0.2
 - @wordpress/block-editor@3.2.2
 - @wordpress/block-library@2.9.2
 - @wordpress/block-serialization-default-parser@3.4.1
 - @wordpress/block-serialization-spec-parser@3.3.1
 - @wordpress/blocks@6.7.2
 - @wordpress/components@8.3.2
 - @wordpress/compose@3.7.2
 - @wordpress/core-data@2.7.2
 - @wordpress/data-controls@1.3.2
 - @wordpress/data@4.9.2
 - @wordpress/deprecated@2.6.1
 - @wordpress/dom-ready@2.5.1
 - @wordpress/dom@2.5.2
 - @wordpress/e2e-test-utils@2.4.2
 - @wordpress/e2e-tests@1.7.2
 - @wordpress/edit-post@3.8.2
 - @wordpress/edit-widgets@0.7.2
 - @wordpress/editor@9.7.2
 - @wordpress/element@2.8.2
 - @wordpress/escape-html@1.5.1
 - @wordpress/format-library@1.9.2
 - @wordpress/is-shallow-equal@1.6.1
 - @wordpress/keycodes@2.6.2
 - @wordpress/list-reusable-blocks@1.8.2
 - @wordpress/media-utils@1.2.2
 - @wordpress/notices@1.8.2
 - @wordpress/nux@3.7.2
 - @wordpress/plugins@2.7.2
 - @wordpress/priority-queue@1.3.1
 - @wordpress/redux-routine@3.6.2
 - @wordpress/rich-text@3.7.2
 - @wordpress/scripts@5.1.0
 - @wordpress/server-side-render@1.3.2
 - @wordpress/url@2.8.1
 - @wordpress/viewport@2.8.2
 - @wordpress/wordcount@2.6.2

* Update changelogs after the npm release

* Prevent prependHttp from failing if url is not defined (#17928)

* Check that url is defined before passing into prependHttp

* Shift check from component to url lib

* List block: move default style (#17958)

* Storybook: Add stories for Checkbox control component (#17891)

* Add checkbox control stories for Storybook

* Update README example to match story, useState

* Apply suggestions from code review

👍

Co-Authored-By: Enrique Piqueras <epiqueras@users.noreply.github.com>

* Update story to match README

* Add variants for heading, label, help

* Update packages/components/src/checkbox-control/README.md

Co-Authored-By: Grzegorz (Greg) Ziółkowski <grzegorz@gziolo.pl>

* Add Knobs addon to Storybook

* Move storybook addon to dev-dependencies

* Solve lint dependency by excluding stories, dont need in package.json

* Apply suggestions from code review

Co-Authored-By: Enrique Piqueras <epiqueras@users.noreply.github.com>

* Update with story level decorators

* Switch back to global withKnobs, per story not working

* Change the name of the example in ChecboxControl story

* Try with the uppercase name of the component exported from stories

* RNMobile Add size options to mobile  image block (#17245)

* [RNMobile] Native mobile release v1.11.0 (#17181)

* [RNMobile] Fix crash when adding separator

* Build: remove global install of latest npm since we want to use the paired node/npm version (#17134)

* Build: remove global install of latest npm since we want to use the paired node/npm version
* Also update travis to remove --latest-npm flag

* [RNMobile] Try dark mode (iOS) (#17067)

* Adding dark mode component implemented on list and list block

* Adding DarkMode handling to RichText, ToolBar and SafeArea

* Mobile: Using DarkMode as HOC

* iOS DarkMode: Modified colors on block list and block container

* iOS DarkMode: Improved Header Toolbar colors

* iOS DarkMode: Removing background from buttons

* iOS DarkMode warning and unsupported

* iOS DarkMode: MediaPlaceholder

* iOS DarkMode: BottomSheets

* iOS DarkMode: Inserter

* iOS DarkMode: DefaultBlockAppender

* iOS DarkMode: PostTite

* Update hardcoded colors with variables

* iOS DarkMode: Fix bottom-sheet cell value color

* iOS DarkMode: More - PageBreak - Add Block Here

* iOS DarkMode: Better text color

* iOS Darkmode: Code block

* iOS DarkMode: HTML View

* iOS DarkMode: Improve colors on SafeArea

* Fix toolbar not avoiding keyboard regression

* Fix native unit tests

* Fix gutenberg-mobile unit tests

* Adding RNDarkMode mocks

* RNMobile: Fix crash when viewing HTML on iOS

* [RNMobile] Remove toolbar from html view

* [RNMobile] Fix MaxListenersExceededWarning caused by dark-mode event emitter (#17186)

* Fix MaxListenersExceededWarning caused by dark-mode event emitter

* Checking for setMaxListeners trying to avoid CI error

* Adding remove listener to DarkMode HOC

* DarkMode: Binding this.onModeChanged to `this`

* DarkMode: Adding conditional needed to pass UI Tests on CI

* Fix focus title on new posts regression (#17180)

* BottomSheet: Setting DashIcon color directly when theme is default (light) (#17193)

* Activate Travis CI on rnmobile/master branch (#17229)

* Added ability to update image size options (sizeSlug) through a new InspectorControl Cell that leads to a Picker.

* Added a style for Size Inspector Controls cell to align it will other cells that have icons.

* Add native support for the MediaText block (#16305)

* First working version of the MediaText component for native mobile

* Fix adding a block to an innerblock list

* Disable mediaText on production

* MediaText native: improve editor visuals

* Move BlockToolbar from BlockList to Layout

* Remove BlockEditorProvider from BlockList and add native version of EditorProvider to Editor. Plus support InsertionPoint and BlockListAppender

* Update BlockMover for native to hide if locked or if it's the only block

* Make the vertical align button work, add more styling options for toolbar buttons

* Make sure registerCoreBlocks does not break in production

* Copy docblock comment from the web version for registerCoreBlocks

* Fix focusing on the media placeholder

* Only support adding image for now

* Update usage of MediaPlaceholder in MediaContainer

* Enable autoScroll for just the out most block list

* Fix JS Unit tests

* Roll back to IconButton refactor and fix tests

* Fix BlockVerticalAlignmentToolbar buttons style on mobile

* Fix thing for web and ensure ariaPressed is always passed down

* Use AriaPressed directly to style SVG on mobile

* Update snapshots

* Swtiched to react-native Modal onDismiss property for signaling Picker is ready to show

* Added a prop for catching modal dismissal on Android. (onDismiss is iOS only and onModalHide works on Android but breaks on iOS)

* Added icon for Inspector Controls size option. Removed style we no longer need.

* Added title to size option iOS ActionSheet and left alignstyle to size options BottomSheet

* MediaUpload and MediaPlaceholder unify props (#17145)

* Unify media placeholder and upload props within media-text (#17268)

* [RNMobile] Fix dismiss keyboard button for the post title (#17260)

* Set unused functions to undefined instead of false in BottomSheet Modal props

* Recover border colors (#17269)

* [RNMobile] Insure tapping at end of post inserts at end

Previously, tapping at the end of the post would insert a block
immediately after the currently selected block. In addition, this commit
is cleaning out a few unusued props in the block-list file.

* Support group block on mobile (#17251)

* First working version of the MediaText component for native mobile

* Fix adding a block to an innerblock list

* Disable mediaText on production

* MediaText native: improve editor visuals

* Move BlockToolbar from BlockList to Layout

* Remove BlockEditorProvider from BlockList and add native version of EditorProvider to Editor. Plus support InsertionPoint and BlockListAppender

* Update BlockMover for native to hide if locked or if it's the only block

* Make the vertical align button work, add more styling options for toolbar buttons

* Make sure registerCoreBlocks does not break in production

* Copy docblock comment from the web version for registerCoreBlocks

* Fix focusing on the media placeholder

* Only support adding image for now

* Update usage of MediaPlaceholder in MediaContainer

* Enable autoScroll for just the out most block list

* Fix JS Unit tests

* Roll back to IconButton refactor and fix tests

* Fix BlockVerticalAlignmentToolbar buttons style on mobile

* Fix thing for web and ensure ariaPressed is always passed down

* Use AriaPressed directly to style SVG on mobile

* Update snapshots

* Support group block on mobile

* Extend shouldShowInsertionPoint condition to be false when group is selected

* Code refactor

* Update package-lock

* Removing old style reference.

* Moved Picker for image size options into new ImageSizePicker component. Cleaned up sizeOptionLabels.

* Updated total left margin on Android Image size options to be 24 px instead of 28 px

* Image Size options hidden behind __DEV__ flag

* Remove redundant bg color within button appender (#17325)

* [RNMobile] DarkMode improvements (#17309)

* Remove the need to import `useStyle` and pass the theme prop on every instance that `withStyle` is used

* Implement dark-mode refactor on all components

* Fix broken native tests

* Fix default block appender background color on DarkMode

* DarkMode: Make `useStyle` a class function

* Cleaned up default true properties and replaced code with lodash map.

* Updated to use BottomSheetPickerCell. Eliminated code, but size options now open over top inspector controls menu.

* Added leftalign to PickerCell.

* [RNMobile] Add autosave to mobile apps (#17329)

* [RNMobile] Fix crash when adding separator

* Build: remove global install of latest npm since we want to use the paired node/npm version (#17134)

* Build: remove global install of latest npm since we want to use the paired node/npm version
* Also update travis to remove --latest-npm flag

* [RNMobile] Try dark mode (iOS) (#17067)

* Adding dark mode component implemented on list and list block

* Adding DarkMode handling to RichText, ToolBar and SafeArea

* Mobile: Using DarkMode as HOC

* iOS DarkMode: Modified colors on block list and block container

* iOS DarkMode: Improved Header Toolbar colors

* iOS DarkMode: Removing background from buttons

* iOS DarkMode warning and unsupported

* iOS DarkMode: MediaPlaceholder

* iOS DarkMode: BottomSheets

* iOS DarkMode: Inserter

* iOS DarkMode: DefaultBlockAppender

* iOS DarkMode: PostTite

* Update hardcoded colors with variables

* iOS DarkMode: Fix bottom-sheet cell value color

* iOS DarkMode: More - PageBreak - Add Block Here

* iOS DarkMode: Better text color

* iOS Darkmode: Code block

* iOS DarkMode: HTML View

* iOS DarkMode: Improve colors on SafeArea

* Fix toolbar not avoiding keyboard regression

* Fix native unit tests

* Fix gutenberg-mobile unit tests

* Adding RNDarkMode mocks

* RNMobile: Fix crash when viewing HTML on iOS

* [RNMobile] Remove toolbar from html view

* [RNMobile] Fix MaxListenersExceededWarning caused by dark-mode event emitter (#17186)

* Fix MaxListenersExceededWarning caused by dark-mode event emitter

* Checking for setMaxListeners trying to avoid CI error

* Adding remove listener to DarkMode HOC

* DarkMode: Binding this.onModeChanged to `this`

* DarkMode: Adding conditional needed to pass UI Tests on CI

* Fix focus title on new posts regression (#17180)

* BottomSheet: Setting DashIcon color directly when theme is default (light) (#17193)

* Add a preliminary version of the AutosaveMonitor for mobile that calls the "bridge" and asks the native side to save the content

* Add autosave mock function for tests

* Fix merge conflicts

* Fix lint

* Re-add autosave on mobile that was removed erroneously during import-merge from rnmobile/master

* Remove native variant of AutosaveMonitor and introduces changes at  editor store level

* Default to false for `isEditedPostAutosaveable` on mobile. There was a typo in the returing value on the previous commit.

* Make sure to consider edits to the Title when checking if auto-save is needed

* Fix lint

*  Add isAppender functionality on mobile (#17195)

* Add isAppender functionality on mobile

* refactor isAppender conditions

* Replace dropZoneUIOnly in favour of showMediaSelectionUI

* deprecate dropZoneUIOnly and add disableMediaSelection prop

* Update test

* Refactor tests and change prop name

* Remove redundant empty lines

* Refactor conditions inside MediaPlaceholder

* Update block-editor CHANGELOG

* Update packages/block-editor/CHANGELOG.md

Co-Authored-By: Grzegorz (Greg) Ziółkowski <grzegorz@gziolo.pl>

* Autosave monitor - Make the mobile editor ping the native at each keystroke, since the deboucing logic is already well defined in the apps. (#17548)

* [RNMobile] Refactor Dark Mode HOC (#17552)

* [RNMobile] Refactor the Dark Mode HOC to fix naming antipatterns

* Fix lint errors

* Add .native.js suffix to usePreferredColorScheme

* Update usage of theme props renamed to preferredColorScheme

* Update usage of theme props renamed to preferredColorScheme

* Add missing heading levels to the UI (H4, H5, H6) (#17533)

* Fix lint issue (#17598)

* Fix list filter on paste for RN mobile. (#17550)

* Fix method for RN mobile.

* Use array.From instead of slice.

* Remove comment and use Array.from directly

* Convert from NodeList spreadable to Array.from

* Fix lint errors.

* Fix documentation examples to use Array.from

* Add empty line.

* [RNMobile] Move MediaUploadPorgress to its own component folder (#17392)

* Move MediaUploadPorgress to its own component folder (native)

* MediaUploadProgress - Fix import to code standards

* MediaUploadProgress readme

* Mobile - MediaUploadProgress README update

* Rnmobile/fix link editing on start (#17631)

* Don't try to clear links if text is clean.

* Commented LinkUI removal test when no URL.

* Don't try to remove link if we are at start of link and no actual selection is

* Re-implementing https://github.com/WordPress/gutenberg/pull/17802, affected by merge. Fixed extra space and unused code.

* Fixing lint error, trailing space.

* Improve columns flex rule, round 2. (#17968)

* Bump plugin version to 6.7.0

* Small changes to Git Workflow docs (#17662)

* :information_desk_person: add 'upstream' remote

* :bug: origin / remote

* Codeowners: Remove gziolo from some folders (#17971)

I get too many notifications.

* Fix: Invalid import statement for deprecated in the modal component (#17969)

* Fix: Invalid import statement for deprecated in the modal component

* Font Size Picker: Update E2E test to work with new Core changes.

* Add empty line (#17981)

* Try setting a block display name for the Block Navigator. (#17519)

* Really simple first attempt at showing a display name in the navigator

* Strip any RichText formatting

* Add display name for navigation menu item block

* Refactor to use displayNameAttribute property

* Change name of displayName options

* [RNMobile] add RangeControl mobile implementation (slider) (#17282)

* add RangeCell

* Split e2e tests into multiple folders (#17990)

* Playground: Add link to components storybook. (#17982)

* Fix image native test (#17989)

* Update: Refactor button edit to use a functional component (#18006)

* Optimize exports of the wp/compose package (#17945)

Adds `sideEffects:false` to `package.json` so that unused exports can be optimized away
by the bundler.

Moves the `compose` definition (i.e., reexport from Lodash) to its own module, so that
we don't pull in Lodash just by importing something from `@wordpress/compose`. After this
patch, one needs to import `compose` explicitly to trigger the Lodash import.

* [RNMobile] Introduce grouping in the block settings inspector (#17703)

* Intrdouce groupin in the block settings inspector

* Adjust PanelBody to design

* Adjust padding when section doesnt have title

* Rewirte arrow function to function

* Fix lint issue

* Create a PanelActions component for handling action buttons in the block settings inspector

* Remove useless separator type and fix typo

* Refactor after CR

* Correct label styles

* Fix overriding mechanism on label style

* Fix the performance tests (#18020)

* Storybook: Add knobs to ColorIndicator (#18015)

* Add knobs to ColorIndicator

* Lint: new line

* Add dashicon component to storybook (#18027)

* Fix Publish Button!!! (#18016)

Fixes #18004 and thank science, that was driving me insane ever since you pointed it out.

This PR does a couple of things:

1. It adds `isLarge` to the Publish button. It was there for Preview, but not Publish.
2. It simplifies a little CSS as a result of that.
3. It also tweaks the button height as defined for the two preview publish buttons.

* Update MediaPlaceholder README.md (#17980)

* Update MediaPlaceholder README.md

This change updates the readme to properly document the `value` property.

See issue here: https://github.com/WordPress/gutenberg/issues/17967

* Update MediaUpload README.md

* removes decleration of Select button (#18007)

* Fix MediaUpload README value prop description (#18039)

* Tests: Clean up skipped e2e tests (#18003)

* chore(release): publish

 - @wordpress/api-fetch@3.6.3
 - @wordpress/block-directory@1.0.3
 - @wordpress/block-editor@3.2.3
 - @wordpress/block-library@2.9.3
 - @wordpress/core-data@2.7.3
 - @wordpress/data-controls@1.3.3
 - @wordpress/e2e-test-utils@2.4.3
 - @wordpress/e2e-tests@1.7.3
 - @wordpress/edit-post@3.8.3
 - @wordpress/edit-widgets@0.7.3
 - @wordpress/editor@9.7.3
 - @wordpress/format-library@1.9.3
 - @wordpress/list-reusable-blocks@1.8.3
 - @wordpress/media-utils@1.2.3
 - @wordpress/server-side-render@1.3.3
 - @wordpress/url@2.8.2

* Chore: Fix issues related to Node 12 becoming LTS (#18054)

* Chore: Fix issues related to Node 12 becoming LTS

* Include the root package.json file in the linting
This commit also moves the npm-package-json-lint config to the standalone file.

* Add changelog entries to @wordpress/scripts package

* Fix issue when providing multiple shortcode aliases for a new block (#17925)

* Fix issue where providing multiple shortcode aliases to transform into a block only matches the first shortcode

* Add test to ensure blocks can transform using multiple shortcode aliases

* Simplify the approach used to find the individual shortcode being transformed

Props jg314

* Chore: Update the lock file to use newer version of fsevents (#18057)

This fixes the issues when `npm install` on macOS throws several errors.

* Env: Add support for custom ports. (#17697)

* Add isInvalidDate prop to DatePicker (#17498)

* navigation-menu: Implement colors selector button. (#17832)

Summary
block-editor: expose ColorPaletteControl component
navigation-menu: improve colors-selector component
navigation-menu: compose withColors
navigation-menu: render colors selector in bar
navigation-menu: propagate withColor props
navigation-menu: apply theme styles to selection
navigation-item: populate styles to nav item
navigation-menu: apply inline styles and CSS classes

* Update design-systems:dev script to build packages (#18073)

The build-style/style.css needs to be rebuilt prior to
running Storybook in watch mode.

This change adds `npm run build:packages` at the start of
the design-systems:dev script to CSS is built prior.

Issue found in #17997

* Add `@wordpress/base-styles` package (#17883)

- Move `assets/stylesheets/*` to the new package
- Move admin color schemes to the new package

* Add Site Title block and required functionality. (#17207)

* Core Data: Add a Site entity and a hook for entity saving logic.

* Experiments: Add a Full Site Editing experiment.

* Block Library: Add Site Title block.

* Fixtures: Add Site Title block fixture.

* Fixtures: Add missing transform fixtures.

* Block Library: Remove deprecated prop usage in Site Title.

* Site Title: Support nesting inside of a Site block.

* Site Title: Disallow formatting in the rich text field.

* Core Data: Make useEntitySaving experimental.

* Table: remove wrapper around cells (#17711)

* Implement core template loader overrides to rely on wp_template posts (#17626)

* Introduce wp_template post type.

* Improve (temporary) admin UI for wp_template post type by exposing slug.

* Implement template loader overrides to rely on 'wp_template' posts.

* Render viewport meta tag.

* Prevent deletion of fallback 'wp_template' post 'index'.

* Scope PR to just basic wp_template post type registration.

* Implement core template loader overrides to rely on wp_template posts instead.

* Render title tag regardless of theme support

Co-Authored-By: Weston Ruter <westonruter@google.com>

* Make getting correct wp_template post more error-proof

Co-Authored-By: Weston Ruter <westonruter@google.com>

* Template Loader: Add more content filters.

* Templates: Fix experiment flag logic.

* Add logic for basic (temporary) wp_template editing UI (#17625)

* Templates: Add logic for basic temporary editing UI.

* Templates: Fix menu filter.

* Post Slug: Follow class name convention.

* url-input: ensuring value is defined on key down (#18088)

* Code style: Fix ESLint warnings reported for JSDoc definitions (#18025)

* Code style: Fix ESLint warnings reported for JSDoc definitions

* Add WordPress type definitions to the list of names recognized by JSDoc linter

* Local autosave: Clear after successful save (#18051)

* Local autosave: Clear after successful save

Presumably, somewhere in the fixing of conflicts between remote and
local autosaves (purge local upon successful remote autosave),
LocalAutosaveMonitor stopped purging the local autosave upon successful
*saves*.

* Tests: Autosave: Correctly wait for editor chrome before saving

* Chore: Fix: Do not show Gradient panel if gradients are not av… (#18091)

* Fix regression with Gallery margin. (#18019)

I failed to verify the Gallery block when I approved https://github.com/WordPress/gutenberg/pull/17958#issuecomment-543597183 and therefore caused a regression.

This PR adds explicity left margins and paddings to the gallery ul to ensure there isn't any added padding and margin.

* Add platform component (#18058)

* Add platform component

* Improve platform implementation in RN.

* Add more documentation and tests.

* Update readme file.

* Update tests.

* Fix filenames for native versions.

* Add license attribution

* Remove unnecessary lines.

* Improve documentation

* Remove trailing space

* Update packages/element/src/platform.js

Co-Authored-By: Grzegorz (Greg) Ziółkowski <grzegorz@gziolo.pl>

* Update readme.

* Fix lint error.

* Fix: End to end tests do not disable the experiments (#18093)

* Fix: Custom button background color not reflected on reload (#18037)

Fixes: https://github.com/WordPress/gutenberg/issues/18012
We had a bug where the editor may not reflect the custom button background color after a reload. That happened because the rule background: customGradient, may overwrite the background-color rule even if the custom gradient has not set.
This PR performs a logic update to solve the issue.

* List Block: Do not merge list with previous block if deleting first list item and list is not empty (#18032)

* Do not merge list with previous block if deleting first list item and list is not empty

* Add e2e test and clean up

* Correct mistake

* Adjust comment

* Add gradients in cover block (#18001)

* Components: Add VisuallyHidden component (#18022)

* Add ScreenReaderText component

* Add new component readme to manifest

* Remove CSS style loading within stories

* Switch component name to VisuallyHidden

- Rename directory and includes
- Update README usage
- Update Storybook usage

* Switch classname to components-visually-hidden

* Lint: newline

* Add focus style

* Switch to 'as' for specifying tag

* Move renderAsRenderProps to utils.js

* Move utils to inside component folder

Waiting to refine the utils usage a little better before
making it look available for other components to use.

* Apply suggestions from code review

Co-Authored-By: Grzegorz (Greg) Ziółkowski <grzegorz@gziolo.pl>

* Lint: Move newline

* Fix variable name

* Use variable for stylesheet

* Storybook: Apply a set of enhancements to the existing stories (#18030)

* Storybook: Apply a set of enhancements to the existing stories

* Add basic knobs integration to all Button stories

* Env: Add support for running in themes. (#17732)

* Env: Add support for running in themes.

* Env: Optimize context detection filter.

* Env: Update test directory structure to match convention.

* Storybook: Add Color Palette Component (#17997)

* Add Color Palette to Storybook

* Apply suggestions from code review

Co-Authored-By: Enrique Piqueras <epiqueras@users.noreply.github.com>

* Refactor state out of story components, to own

* Update packages/components/src/color-palette/stories/index.js

* Preserve attributes on split (#18102)

* [rnmobile] Breadcrumbs (#17471)

* Add breadcrumbs to floating toolbar

* Add dark mode support

* Add a block selection breadcrumb to the bottom of the editor (#17838)

* RNMobile: Add image alignment controls (#17962)

RNMobile: Add image alignment controls

Only handles left, center, right. Does not permit setting or displaying
either full or wide alignments.

* Fix checkboxes for postmeta. (#18108)

* Add block inspector to the Gutenberg playground. (#18077)

* Block Editor: Implement new colors hook. (#16781)

* Block Editor: Implement new colors hook.

* Block Library: Swap usage of the colors HOC with the colors hook in the heading edit component.

* Use Colors: Add 'has-x-color' class names.

* Use Colors: Avoid memory leaks by making caches limited in size, and tied to hook instances.

* Use Colors: Support children and optional contrast checking in the color panel.

* Use Colors: Expose colors panel without inspector slot/fill wrapper.

* Use Colors: Mark hook as experimental.

* Use Colors: Support custom colors.

* Block Edit: Remove extra context values and use selectors/actions instead.

* Heading: Remove unnecessary color class and set text color on save.

* Use Colors: Add custom/preset color logic.

* Use Colors: Fix panel bugs.

* Heading Block: Detect actual background color for contrast checking.

* Block Edit: Add new export to native file.

* Use Colors: Change CSS "attribute" to "property".

* Fix: Font size picker component relies on WordPress styles (#18078)

* Nav menu item enhancements: display toolbar and remove dropdown (#17986)

* Display toolbar and remove dropdown from menu item

* Fixes block toolbar misalignment on IE.

* Replace destination and deal with keypresses.

* Update fixture.

* Keydown management and attempt at close on blur.

* Add definitive menu item icon.

* Fix label/input styling.

* Clean up styles after rebase.

* Refactor stop propagation .

* Remove duplicate dependency comments

* Navigation Block: Rename 'destination' to 'url' in server-side code

* Fix overlapping controls in the Inline Image formatting toolbar (#18090)

* Fix overlapping controls in the Inline Image formatting toolbar

* Inline mage formatting: make Apply button same height as Width input

* Polish.

* Raw handling: Fix strikethrough formatting when copy/pasting from Google Docs in Safari (#17187)

* Tutorial: Specify block naming restrictions (#18117)

* Tutorial: Specify block naming restrictions

* Remove an incorrect comma

* Components: ExternalLink, add story (#18084)

This update adds a story for the ExternalLink component.
Storybook knobs were added to better demonstrate the component's
properties.

* Storybook: Add ColorPicker component (#18013)

* Add color picker component to Storybook

* Switch screen-reader-text to new VisuallyHidden

* Update ColorPicker tests snapshots

* Add story for showing Alpha Channel

* Move state out of exported component

* Lowercase story name

* Add class mechanism for preset gradients. (#18008)

* Allow media upload post processing for all 5xx responses (#18106)

* Allow travis builds in all wp/* branches

* Add `DimensionControl` component (#16791)

* Adds initial component

Note this is copied wholescale from original PR https://github.com/WordPress/gutenberg/pull/16730

* Remove redunant files. Refactors tests.

* Updates docs

* Checks callbacks are functions prior to calling

* Adds temp testing example usage of component to Group Block

* Updates to allow sizes as an (optionaly) prop dependency

* Update default value label

* Removes unnecessary InstanceId HOC usage

Addresses https://github.com/WordPress/gutenberg/pull/16791#discussion_r323906696

* Remove unused abbreviation in size table

* Revert "Adds temp testing example usage of component to Group Block"

This reverts commit 6f9f3bfd2a7c1a08ecfab143384d414701f0c1e8.

* Remove arbitrary size value from sizes list

This is not required as we cannot know how the dimensions component will be used. Therefore sticking with relative values via the slugs is safer. These can be mapped on a case by case basis as required.

* Remove icon label for a11y reasons

Addresses https://github.com/WordPress/gutenberg/pull/16791#discussion_r324103481

* Update component docs for consistency, spelling and grammar

* Tweak docblock formats

* Update test snapshots to match new default value

* Update API from onSpacingChange to more agnostic onChange

Addresses https://github.com/WordPress/gutenberg/pull/16791#discussion_r331622801

* Update tests to cover onChange handler renamed

* Update currentSize prop to value for consistency with other components

* Removes onReset in favour of onChange with undefined for consistency

Adddresses https://github.com/WordPress/gutenberg/pull/16791#discussion_r331624272

* Move component to @wordpress/components package

* Remove invalid font sizes style import

Accidentally included from rebase.

* Deps update due to rebase

* Remove unneeded doc blocks

* Remove usage suggestion which was not helpful

* Update readme docs to match current API

Addresses https://github.com/WordPress/gutenberg/pull/16791#discussion_r332692714

* Export as experimental component

Addresses https://github.com/WordPress/gutenberg/pull/16791#discussion_r332694561

* Revert "Deps update due to rebase"

This reverts commit 95d00f39010edfaac620980e0d0e7c1001a68c98.

Addresses https://github.com/WordPress/gutenberg/pull/16791#discussion_r332691520

* Paste: allow list attributes (#17144)

* Add grandient fixtures to cover block (#18002)

* Bump plugin version to 6.8.0-rc.1

* Fix RN build after merge with master (#18133)

* Commander: switch cloning method to HTTPS (#18136)

* Commander: switch cloning method to HTTPS

* Add HOME env variable

* Add horizontal option for the block movers (#16615)

* horizontal option for the mover, missing icons, broken hover

* we now have icons

* positioned the mover to the middle left

* horizontal mover on mobile

* vertical layout for horizontal movers

* drop block movers into block edit to enable inline movers

* implemented so as to not be a concern for the block implementer

* removes useless scss variable

* hiding the drag handle at block level

* renamed horizontalMover to moverOptions to incorporate separation of properties

* rafactores the mover options

* Initial CSS work to make the menu more manageable.

This moves to flex instead of grid, neutralizes margins, simplifies a few things.

* Make movers inline again.

* Further improve margins for child blocks.

* adds proper aliases in BlockEdit

* previxed options as experimental

* RTL movers

* removed the position option, marked option experimental

* labeled as experimental new mober and block list props

* refactored direction detection code for better readability, fixed some code alignment issues

* Update ExternalLink Component to fix visually hidden text (#18142)

* Switch screen-reader-txt to VisuallyHidden component

* Fix core embed test snapshot, new classname

* Add Spinner component to storybook (#18145)

* Smart block appender (#16708)

* if thre is only one there is only one

* made a new insertion point selector, some code review refactoring

* better handling of inserter

* refactoring and named block insertion

* updates to the appender

* update snapshots

* update docs

* default inserter label is used in so many tests

* fixed allowed blocks test

* snapshot updated

* better naming and removed the need for es-lint disabling

* improved the inserter label construction

* improved the doc of getTheOnlyAllowedItem selector

* reverting test patches becasue patching without understanding is bad, bad, bad - don't do it

* moved getInsertionIndex out of selectos and back into each component that used it

* docs generated

* added experimental labels to new selectors, added es-lint comment back

* updated docs

* Update packages/block-editor/src/store/selectors.js

Co-Authored-By: Miguel Fonseca <miguelcsf@gmail.com>

* Update packages/block-editor/src/store/selectors.js

Co-Authored-By: Miguel Fonseca <miguelcsf@gmail.com>

* refactored and fixed some coding errors

* small code move

* small code move

* removes aria attrs for autoinserted items

* fixes typo, adds translators comment

* simplifies the intserter logic

* fix for the simplification

* simplifies by using one selector and passing props in compose

* small code updates

* lint

* renamed insertedBlock

* small doc update

* adds tooltip to the default button appender

* refactores for more self documenting varnames

* Components: Draggable, add story (#18070)

* Components: Add Story for Draggable

This update adds a Storybook example for the Draggable component from `@wordpress/components`.

* Fix useState hook for Draggable story example

Solution was to create an Example component with the useState hook.
Render that Example component in the story instead.

* Block Directory: Convert it to UI Plugin to avoid bundling into Core (#17576)

* Block Directory: Convert it to UI Plugin to avoid bundling into Core

* Load the block directory assets only when the experiment is enabled

* Try to reimplement asset overrides to give more flexibility

* Add code style improvemements and perform code cleanup

* Try to make PHP unit tests pass by removing group check

* Ensure that packages and vendor scripts are printed in the footer

* Fix the has action check for the block directory assets

* Move gutenberg-block-directory experiment check out of the action

* Fix bin/get-vendor-scripts.php

* Make the AsyncModeProvider API a stable API (#18154)

* Make the mediaUpload block editor setting a stable API (#18156)

* Fix columns full-wide regression. (#18021)

The Columns block, when full-wide, has intentional left and right padding to ensure the mover controls of child blocks are accessible. This is editor-only, and only when the block is selected.

This regressed at some point, a while ago, probably around the introduction of extra on-click padding to show the dashed outlines of child elements.

This PR shuffles the rules a bit, reduces some of their specificity, and applies the left and right padding elsewhere to make it work.

* Resyncs RichText mobile components with web counterparts. (#17897)

* Resyncs RichText mobile components with web counterparts.

* Remove outdated test.

* Remove unused references.

* Add platform component

* Add components depending of platform.

Only add specific components if we are on the web implementation.

* Abstract paste of files for RN and web

Makes the code for pasting image more abstract in the paste method and
implement specific translation to HTML depending of the platform.

* Compose extra attributes/props on select/dispatch only if mobile.

* Remove RN index file for RichText Wrapper.

Moved all the specific code to the standard index file, so this file
is no longer needed.

* Remove API index native file that is no longer needed.

* Clean up lint errors in file-paste-handler.

* Fix lint errors.

* Implement stub remove browser shortcuts for RN

* Implement autocomplete stub for RN.

* Refactor toolbar presentation to a method.

* Remove no longer needed platform file.

* Consolidate the file paste handler in a single implementation.

Created a stub for createBlobURL for native that simple returns the
original URL.

* Change the text for platform to make it explicit it's native only.

* Remove duplicate files

* Include type in file comparison

* Forgot to rename for native file

* Fix filePasteHandler for native

* Move logging back

* Restore comment on logging

* Add check for files existence.

* Refactor format-toolbar code to use split web/native files

* Remove prop duplication.

* Fix getAnchorRect call

* Remove unnecessary const

* Sync fix for list removal of first empty line

* Fix RN build after merge with master

* Sync with web counterpart.

* Only change selection after new formats are set.

* [RNMobile] Add a subtitle for unsupported blocks (#18107)

* Add a new unsupported subtitle to missing blocks - even we know about the block title

* Update margins, colors and font weight of the unsupported block

* Navigation: Explore default frontend styles (#18094)

* try basic version of varia theme styles as default

* Add class to show submenu indicator

* adjustments for small viewports

* NavigationMenu: set attributes rightly (#18150)

* navigation-menu: set attributes once

* navigation-menu: add CSS class as hook dependencies

* Update packages/block-library/src/navigation-menu/edit.js

Co-Authored-By: Enrique Piqueras <epiqueras@users.noreply.github.com>

* Update packages/block-editor/src/components/colors/use-colors.js (#18147)

Co-Authored-By: Enrique Piqueras <epiqueras@users.noreply.github.com> (+2 squashed commits)
Squashed commits:
[36484b4d3f] Update packages/block-editor/src/components/colors/use-colors.js

Co-Authored-By: Enrique Piqueras <epiqueras@users.noreply.github.com>
[9c4c7694bd] Fix: solve some issues in useColors hook

* [RNMobile] Added support for giphy and pexels images (#18026)

* Scripts: Bump the version of npm-package-json-lint (#18160)

* Experimental Link creation interface (#17846)

* Initial component file structure

* Implement basic icon and toggle mechanic

* Adds basic search input

* Update input to utilise LinkEditor component autocomplete

* Add ability to customise placeholder

* Update to utilise URLInput directly for greater flexibility

* Add example search results and test coverage

* Update class naming convention to match guidelines

See https://github.com/WordPress/gutenberg/blob/master/docs/contributors/coding-guidelines.md#css

Addresses https://github.com/WordPress/gutenberg/pull/17846#discussion_r332567521

* Adds render prop to enable custom suggestions rendering

Previously it wasn’t possible to customise the render of the search suggestions. By providing an optional render prop we now have full control over this if required.

* Update to utilise URLInput render prop to customise search suggestions render

Previously we relied on our own render of suggestions but this wasn’t hooked up to all the accessibility enhancements afforded by URLInput. By utilising the render prop exposed by URLInput to customise the rendering of suggestions, we can have the best of both worlds.

* Update to add post type to the fetchLinkSuggestions responsive mapping

This is required to display the type of entitity in the search results for LinkControl

* Fix to ensure search suggestion interaction states are perceivable

* Update suggestion render prop to provide component props as arguments

Previously when using the `renderSuggestions` render prop the user had to know how to put together the correct props on the correct elements in their custom render. By passing the default props for the listing element and the item element we can relieve the user of this burden by allowing them to spread the props onto the appropriate elements in their render without having to know how they are created.

* Update to match with design visual and provide more accessible markup

* Adds settings area. Fixes missing reset icon.

* Fix search items to be buttons with correct style and layout

* Adds overflow scrolling to search results

* Fix to stop scroll shadow overlaying scrollbars

* Add bespoke settings area and tweak styles

* Update to allow URLs to be conditionally handled as a suggestion

Previously when a URL was entered it was deemed that no suggestions should or could be found and so the process of fetching suggestions was short circuited. Add additional prop to optionally allow developers to have URL-like values handled as suggestions.

* Updates to conditionally use an entity or url based search results fetcher

If the current value of the input is a URL then we conditionally pass a different handler for search results to the URLInput component. For URL based values we immediately return a “suggestion” object with values matching those entered by the user. Non URL based values are handled as previously.

* Fix bug whereby fetchSearchSuggestions wasn’t called

Remove ambiguity by calling the search handler directly rather than proxying through another function and having to apply it immediately.

* Remove default toggle UI and implement Popover close

The LinkControl will be mostly where another element triggers the UI to appear. As a result we don’t want to force a toggle element on the developer. Rather we will expose an API to allow the consuming component to toggle the visibility of the LinkControl

* Adds search text “highlighting” in results list

* Move TextHighlight component to its own file

* Fix bug where update to value prop didn’t cause suggestions to reset.

* Update to remove internal handling of open/closed state

This state is now expected to be handled by the consuming component chosing whether or not to render the component. It has no concept of open or closed.

* Fix React violation by returning only the text for non matches

* Update existing tests to match new implementation

* Add link reset test

* Adds test which uncovers major bug in the implementation

Basically this test has revealed that due to the way we’re detecting and handling URL-like values the wrong data fetcher function gets passed to the URLInput component for the first input `change` event.

For example if you paste `https://make.wordpress.com` directly into the input then it is determined to be a URL but because the current fetcher function for the current render is still the handler that deals with entity searches the correct results are not displayed. Adding another character to trigger a re-render will cause the UI to update to the expected state, but this is a major bug.

* Tweak critical test to be more explicit about what is expected

* Fix bug to make determining search handler use the latest input value

Previously we relied on parent component state to choose which search handler to use for the current input term. However, the state was always 1 tick behind so the previous search handler got used. Updating this to use the real time value of the input passed onChange ensures we select the correct search fetcher when the component re-renders.

* Add loading spinner and associated test coverage

Spinner was technically always rendered but it wasn’t visible due to CSS styling. Fix and also cover with tests.

* Fix bug where value could be empty

* Adds basic editing / view state switching

* Add keydown callback to URLInput

* Select link on ENTER keydown event

* Utilise LinkViewer to render edit state and decode urls for display

* Only display link settings when a link is selected

* Adds current link view styles

* Makes settings toggle controlled by parent component

* Update visuals to match updated design

Addresses https://github.com/WordPress/gutenberg/issues/17557#issuecomment-542401433

* Add standardised min width to popover

* Temporary hack to include Link UI in Playground for testing

* Update to utilise isURL util from @wordpress/url package

* Update to utilise isURL util from @wordpress/url package

* Removes URLPopover dependency

Attempts to remove unwanted deps on other components. We now utilise Popover directly and suffer no consequences as we are not making use of any bespoke features provided by URLPopover.

* Extract settings drawer to sub component

* Refactor search items into a component

* Refactor Input and Search to component

* Fix missing selected state on search suggestions

* Tweak line height on search suggestion url path

* Augment test for URL-like by testing for “www.”

* Fix to stop url overflows and wrapping on to multiple lines

* Uppcase URL in type indicator within search results list

* Avoid reading out slug/URL for entity results

* Ensures i18n of change button

* Always offer URL result in search suggestions as default

* Fix loading spinner position and dim results during loading

Addresses https://github.com/WordPress/gutenberg/pull/17846#issuecomment-543244810

* Fix scroll shadows to use valid alpha transparent values in gradient

Fixes broken shadows in Safari which didn’t recognise transparent as a value to transition to in a gradient.

* Adds instructional text in place of URL for suggestions that are URLs

Addresses designer feedback https://github.com/WordPress/gutenberg/issues/17557#issuecomment-545030027

* Update prop names for consistency

Addresses https://github.com/WordPress/gutenberg/pull/17846#discussion_r337840953

* Update line length to improve readability

Addresses https://github.com/WordPress/gutenberg/pull/17846#discussion_r337842799

* Update to avoid need to utilise partialRight util from lodash

Addresses https://github.com/WordPress/gutenberg/pull/17846#discussion_r337882576

* Updates key to avoid usage of index

We cannot assume the suggestion `id` will be unique. This is because at the moment the search results are `Post`s. However in the future we may also need to include `Category` terms and the term IDs could easily clash with the Post IDs as they are in different DB tables.

Using the `type` to differentiate the key.

Addresses https://github.com/WordPress/gutenberg/pull/17846#discussion_r337883174

* Update to remote isFunction check in favour of direct check

Addresses https://github.com/WordPress/gutenberg/pull/17846#discussion_r337885206

* Update to handle mailto and tel protocols and internal links

* url-input: handle onKeyPress type event

* link-control: add className prop

* link-control: add README file

* Remove unnecessary use of useCallback

Addresses https://github.com/WordPress/gutenberg/pull/17846#discussion_r338363236

* Fix current automated tests

* Improves URL handling test to run for multiple URL value variations

* Updates to display the URL type in the search results

Previously only true `http` URLs were formatted with the correct type and the instructional text. Fixes so that all types of manual URL entry are correctly shown as such in the search results.

Adds test to cover mailto variant of this.

* Refactor tests to assert against all valid protocol formats and link variants

This now includes tel, mailto and internal links.

* Adds test to cover display of fallback URL search result for search values that are potentially URLS

* Adds tests to check URL suggestions don’t display for non-URLs.

* url-input: remove unneeded `suggestion` const

* url-input: always trigger onKeyDown event

* link-control: delegate handling keydown event
Instead of this, let's propagate the onKeyDown and onKeyPress events to the parent component

* link-control: add onKeyDown and onKeyPress handlers

* link-control: playground -> close once onClose

* link-control: propagate onClose() event

* link-control: playground -> hanldling close by ESCAPE key

* Fix to only render settings draw if settings are defined

* Remove redundant commented out test

* Update to render with a “current link” if one is provided.

Previously if you passed in a current link the component would still render with a search box as thought nothing was selected.

Updates so that if `currentLink` is provided the UI reflects that by showing the “selected” item and no search input.

* Render playground with currentLink active

* Adds test to cover currentLink prop

* Remove selected state from Playground

* Adds tests to cover selecting and changing links

* Remove async function in place of direct Promise usage and add test coverage

* Add test to cover keyboard handling

Note: this uncovered a bug whereby keyboard handling of “selecting” the link you want to use is broken. This needs to be fixed.

* Remove unecessary dep from effect

* Fix URLInput to pass the actual suggestion object not the index

If the full object is not provided then consuming components have no way of accessing the details of the selected suggestion thereby rendering it useless.

* Fix keyboard handling so hitting `ENTER` will select an item as the current link

Builds on previous commit.

* Updates keyboard interaction test to include URL entry

* Minor: reword test description

* Fix missing key prop regression

Previously `buildSuggestionItemProps` was including a key. However the implementation of `LinkControl` changed so that this was not required. However we forgot to reinstate on `URLInput`. This update ensures a key prop is set on the default output.

Note that disabling of the autofocus linting was already in place:

https://github.com/WordPress/gutenberg/blob/04e142e9cbd06a45c4ea297ec573d389955c13be/packages/block-editor/src/components/url-input/index.js#L239

Addresses https://github.com/WordPress/gutenberg/pull/17846#discussion_r337841961

* DRY up conditionals

Addresses https://github.com/WordPress/gutenberg/pull/17846#discussion_r337842477

* link-control: set a default experimental link suggestions searcher if it't needed

* link-control: handling key events

* url-input: remove onKeyDown prop

* url-input: remove calling onKeyDown prop

* url-input: rollback some changes

* Mark Link Creation Interface as Experimental (#18110)

* mark main component as experimental

* mark new URLInput props as experimental

* add experimental onKeyPress

* remove key handlers

* Updates to use alias on experimental props

Addresses https://github.com/WordPress/gutenberg/pull/18110#discussion_r339427180

* Remove unused prop from docs

* Update props ordering and readme docs

Also fixes eslint errors that kept me from committing the original changes

* Revert playground changes

* Rename InputSearch to SearchInput

Props @talldan

I really hope those changes I had to make in `search-input.js` don't break anything.

* Remove disabling of jsx-key lint rule

* Change fake id value to something that will not clash with post ids

* [RNMobile] Hotfix 1.15.2 (#18128)

* Force block inserter to re-render on device rotation (#18101)

* Force block inserter to re-render on device rotation

* Dummy

* Revert "Dummy"

This reverts commit 037f076679cb8f89a65ecafdd9130465a0fc03d9.

* Add left right borders to inner blocks (#18109)

* [Mobile]Remove alignment options from Media & Text until they are fixed (#18112)

* Remove alignment options temporarily

* Dummy commit

* Fix: remove getItemLayout which causes scroll position issue (#18060)

* Fix: Media & Text Loses upload status if post is closed/reopened during the upload (#18137)

* Prevent deleting mediaType on upload progress

* Call onMediaUpdate instead of onSelectMedia

* Dummy commit

* Revert "Dummy commit"

This reverts commit 5ce06d61f74af688b9d938c99e2d9fdad090a42c.

* Limit requestMediaImport calls for only image type

* Update comment

* Dummy commit

* Revert "Dummy commit"

This reverts commit 99584e41b097792d61370e9a0ac3c9ab52cf9bf4.

* Fix handling of pasted images and prevent thumbnail uploads (#18215)

* Fix handling of pasted images and prevent thumbnail uploads

* Fix lint errors

* Remove check for image for sync.

* Include the RN mobile releases branch in Travis branches
hypest pushed a commit that referenced this pull request Nov 4, 2019
…res (#17858)

* Add an apiFetch middleware to automatically handle media upload failures

* Remove the attachement on failures

* Handle errors properly

* limit the media upload middleware to the 500 responses

* Fix the error handling and unit tests

* Api Fetch: Check for 502s and parse uncaught errors in Media Upload middleware.
hypest pushed a commit that referenced this pull request Nov 4, 2019
…res (#17858)

* Add an apiFetch middleware to automatically handle media upload failures

* Remove the attachement on failures

* Handle errors properly

* limit the media upload middleware to the 500 responses

* Fix the error handling and unit tests

* Api Fetch: Check for 502s and parse uncaught errors in Media Upload middleware.
@jorgefilipecosta
Copy link
Member

Hi @youknowriad, was this change already backported to WordPress core for 5.3 release or we will need to backport in 5.4?

@youknowriad
Copy link
Contributor Author

youknowriad commented Feb 5, 2020

@jorgefilipecosta yes, it was already backported 👍

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Feature] Media Anything that impacts the experience of managing media REST API Interaction Related to REST API [Type] Bug An existing feature does not function as intended
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Fix handling of HTTP 500 errors while uploading images
7 participants