-
Notifications
You must be signed in to change notification settings - Fork 4.3k
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
WIP - Add MediaUploadCheck component #9298
Conversation
- Hardcode hasUploadPermissions value to true for now until implementation of server-side and redux state has been finalised Co-authored-by: imath <math.viet@gmail.com>
MediaUploadCheck component will conditionally show/hide parts of the UI related to file uploads dependent on whether the user has the capability to upload files. Co-authored-by: imath <math.viet@gmail.com>
Use early return when no featuredImageId is set. Reduce boolean checks around component rendering. Co-authored-by: imath <math.viet@gmail.com>
…heck component Co-authored-by: imath <math.viet@gmail.com>
…ploads Co-authored-by: imath <math.viet@gmail.com>
/** | ||
* Internal dependencies | ||
*/ | ||
import { name, settings } from '../'; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Seems a shame to remove these tests. I spent a while trying to find a way to mock 'select' and the hasUploadPermissions selector, but couldn't find a suitable way. Any pointers would be appreciated if there is a way to do this.
But I also thought that perhaps it would be better to spend the effort introducing e2e tests that cover the initial state of these blocks?
Work in progress - not quite ready for review yet.
Description
Introduces a MediaUploadCheck component, which can be used to wrap other components and prevent them from rendering if a user does not have adequate permissions (e.g. Contributor roles) to upload files/media. This is implemented in our MediaPlaceholder component and several media blocks (image, video, audio etc.)
Currently this is hard-coded so that users won't see any change. A second PR will be created in a moment adding the checks for the user's capabilities.
These changes were originally implemented in #4155, but have been split into a separate PR to make them easier to review.
Related to issue #3672
Massive thanks to @imath for all the hard work he's put in developing this.
How has this been tested?
Screenshots
Screenshot of how media blocks would appear to users without capabilities
data:image/s3,"s3://crabby-images/04646/04646fc4c605e6f335d2b5654028965833c1c68b" alt="screen shot 2018-08-24 at 2 45 07 pm"
Types of changes
New feature (non-breaking change which adds functionality)
Checklist: