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

ContextPopover: Component to manage controls within Sidebar #23486

Open
ItsJonQ opened this issue Jun 25, 2020 · 8 comments
Open

ContextPopover: Component to manage controls within Sidebar #23486

ItsJonQ opened this issue Jun 25, 2020 · 8 comments
Assignees
Labels
[Feature] Design Tools Tools that impact the appearance of blocks both to expand the number of tools and improve the experi Needs Design Feedback Needs general design feedback. [Package] Components /packages/components [Type] Enhancement A suggestion for improvement.

Comments

@ItsJonQ
Copy link

ItsJonQ commented Jun 25, 2020

Hi there! 👋

Hope you all are doing well! I'm submitting a feature request for a new component (ContextPopover) to help simplify and improve the experience with Block (inspector) controls that appear in the sidebar.

Overflow

Screen Shot 2020-06-25 at 3 11 17 PM

(Above: Screenshot of Paragraph blocks color settings)

Certain block settings may render a lot of control UI. These controls often grow over time, whether it's from core enhancements or from theme settings (e.g. color palette).

Controlling Overflow

Screen Shot 2020-06-25 at 3 11 24 PM

(Above: Screenshot of color settings simplified with ContextPopover)

My idea is to hide some of that visual complexity in a popover/modal like experience with a new <ContextPopover /> component.

When collapsed, it only shows the most important information. In the above example, a preview of the color value and the attribute it is assigned to.

If we need to modify one of the values, the item can be clicked, which renders a Popover card positioned relatively to the original item. Other things in the sidebar fade away into the background. This brings focus to the settings we're currently editing.

Screen Shot 2020-06-25 at 3 12 05 PM

Here is an initial comparison between the current sidebar controls, and one simplified with ContextPopover:

Screen Shot 2020-06-25 at 3 11 58 PM

In practice, it may look and feel something like this:

contextpopover-demo
(Above: GIF demoing the interaction experience of ContextPopover)

Screencast Demo/Walkthrough

I recorded a quick screencast sharing my thoughts:

https://www.loom.com/share/68b587b57bc64c2f8b06ad6dc61691c9

Implementation + A11Y

I suggest we leverage Popover from Reakit (shoutouts to @diegohaz ) to a lot of the heavy lifting in regards to interaction and a11y. From a UI perspective, we have some pieces already, such as a <Card /> component from @wordpress/components.

We'll need to work out a nice component API that can seamlessly manage the "Trigger" (the element the user clicks) and the Content (the stuff that renders within the popover).

Feedback

I'd love to hear your thoughts! ❤️

Thank you!!

@ItsJonQ ItsJonQ added Needs Design Feedback Needs general design feedback. [Package] Components /packages/components [Feature] Design Tools Tools that impact the appearance of blocks both to expand the number of tools and improve the experi labels Jun 25, 2020
@ItsJonQ ItsJonQ self-assigned this Jun 25, 2020
@MichaelArestad
Copy link
Contributor

I love the idea of focusing the controls so I only have to see the controls relevant to what I'm trying to change. That will be a big win.

One added benefit is that it greatly reduces the complexity in the block sidebar -- perhaps so much that we could remove the need for most of the accordions. It can be tedious to constantly open and close the accordions.

As for the design, I think it would be good to try a few iterations.

On these items:

image

I wonder if it would be good to make the colors/gradients circles, images as a cropped rectangle, and maybe even a text preview somehow (particularly useful when we get into typefaces). Those are likely separate issues, but definitely worth exploring.

Looking at the modal:

image

I wonder if styles similar to the inserter (heavier borders) could help. And maybe make it edge to edge over the sidebar?

@ItsJonQ
Copy link
Author

ItsJonQ commented Jun 25, 2020

I wonder if it would be good to make the colors/gradients circles, images as a cropped rectangle, and maybe even a text preview somehow (particularly useful when we get into typefaces). Those are likely separate issues, but definitely worth exploring.

I didn't change any other design 😊 . I left the current Color components alone.

I had a brief chat with @LevinMedia and Figma was brought up.
Another way to render the Popover may be similar to how Figma handles it:

Screen Shot 2020-06-25 at 3 58 08 PM

Where it's rendered off to one side. There's some benefits to this.
The biggest benefit is that the Popover's width isn't limited to the Sidebar.

It looks like Figma takes it one step further... allowing you to drag the Modal/Popover

😊

Screen Capture on 2020-06-25 at 16-02-13

@shaunandrews
Copy link
Contributor

Another way to render the Popover may be similar to how Figma handles it:

This is exactly what I was going to suggest. It feels like similar to the way block previews work in the sidebar Inserter.

@ItsJonQ
Copy link
Author

ItsJonQ commented Jun 25, 2020

@shaunandrews Yiiisss!! I feel like we're onto something :D

@MichaelArestad
Copy link
Contributor

That's a great idea. Would love that.

@ItsJonQ
Copy link
Author

ItsJonQ commented Jun 26, 2020

How's this :D

Screen Capture on 2020-06-26 at 11-56-07

I had to change how the Custom color interaction works. Showing it as a collapsible disclosure underneath (rather than another popover).

The popover body should be scrollable if overflow happens:

Screen Shot 2020-06-26 at 11 57 08 AM

@ItsJonQ
Copy link
Author

ItsJonQ commented Jun 29, 2020

I've created a deploy preview for my experiments!

https://itsjonq.xyz/iframe.html?id=components-contextpopover--default

Have a play ✌️

@ItsJonQ
Copy link
Author

ItsJonQ commented Jul 27, 2020

Haiii! I haven't forgotten about this.

I attempted to code this today. Unfortunately, I ran into some limitations with our current Popover component.
#21275 (comment)

In my prototypes, I used Reakit/Popover (a brilliant piece of code) to handle the rendering and positioning.

If we want to move forward, we'd have to either...

  • Refactor Popover to support more rendering options (hard)
  • Use Reakit/Popver for this instance (easy). But then, we'd be using 2 popover solutions within @wordpress/components, which isn't ideal.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Feature] Design Tools Tools that impact the appearance of blocks both to expand the number of tools and improve the experi Needs Design Feedback Needs general design feedback. [Package] Components /packages/components [Type] Enhancement A suggestion for improvement.
Projects
None yet
Development

No branches or pull requests

4 participants