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

Update TimePicker component design #64390

Open
jameskoster opened this issue Aug 9, 2024 · 11 comments
Open

Update TimePicker component design #64390

jameskoster opened this issue Aug 9, 2024 · 11 comments
Labels
Design System Issues related to the system of combining components according to best practices. [Focus] Accessibility (a11y) Changes that impact accessibility and need corresponding review (e.g. markup changes). Needs Design Needs design efforts. [Package] Components /packages/components [Type] Enhancement A suggestion for improvement.

Comments

@jameskoster
Copy link
Contributor

Extracted from #64267 (comment)

TimePicker was originally designed with a fairly narrow scope; the date picking UI in the page inspector:

Screenshot 2024-08-09 at 09 56 49

In this context (popover) there is room enough for a more elaborate UI with multiple controls. However in a more traditional form setting this design is convoluted and overly prominent. Let's explore a more lightweight design, applicable either as a variant or a full redesign.

Inspiration can be taken from the datetime-local input type which condenses everything into a single text field with a built-in calendar/time selection popover:

Screenshot 2024-08-09 at 09 59 11
@jameskoster jameskoster added [Type] Enhancement A suggestion for improvement. [Package] Components /packages/components labels Aug 9, 2024
@jameskoster jameskoster added the Needs Design Needs design efforts. label Aug 9, 2024
@mirka
Copy link
Member

mirka commented Aug 9, 2024

Possibly related: #60971

@seifeldinio
Copy link

Here's a suggested design update for the TimePicker component.
In the new design, I’ve taken into consideration the need for a more lightweight and streamlined UI.

Here's a prototype to showcase the updated design in action:

demo.mp4

Component:

component

Mockup:

mockup

Would love to hear your thoughts!

@christopherabalos
Copy link

While I agree that TimePicker feels heavy, the separate controls also ensure accessibility. Calendar and time controls are two of the most difficult UIs to make accessible.

The native datetime-location input type allow selection of each date/time segment:

356532746-c7b65faf-7e44-4d93-a8e2-d99f2c8ae630

Something similar would need to happen in an updated TimePicker.

@jameskoster
Copy link
Contributor Author

jameskoster commented Aug 12, 2024

@christopherabalos absolutely, 100%! I think the first step here is to assess the accessibility of the datetime-location input type, and how much of that should be embodied 1:1 in the updated design.

From there it'll mostly be a case of applying the wp design language to the visuals, as @seifeldinio did above.

It's worth keeping date range picking in mind as well (#60971 as pointed out above), with additional shortcuts for things like "Last week", "Month to date", etc. This will be useful for filtering data views (e.g. to show pages published in the last month).

@jameskoster jameskoster added the [Focus] Accessibility (a11y) Changes that impact accessibility and need corresponding review (e.g. markup changes). label Aug 12, 2024
@mirka
Copy link
Member

mirka commented Aug 30, 2024

Might be stupid question, but what is stopping us from just using the native <input type="datetime-local"> (or <InputControl type="datetime-local">)? Especially when we want to shift to this "popover" style. A recent accessibility test said that "its overall experience surpasses any other custom date picker I’ve encountered on various booking platforms". And we get a ton of stuff for free, like mobile support.

Even for the date range picker case, I find it likely that the easiest way to build that accessibly is to use two native datetime-local inputs, rather than going for a custom or library solution.

@DaniGuardiola
Copy link
Contributor

@mirka I would push for using the platform for these things every day of the week, for those same reasons. Unless there's a very specific, very critical requirement or constraint to not do that, I feel like these days it's the best option in almost every aspect, at the cost of slightly less design freedom.

@jameskoster
Copy link
Contributor Author

I lean in that direction as well, and had the same thought about combining two native datetime-local inputs for the range picker. A detail missing there would be shortcuts for quick selecting presets like 'Month to date', 'Last week', etc., but that can be discussed in #60971 and a design solution seems trivial on the surface.

As Dani points out the main drawback is styling; making it blend seamlessly with the broader UI may not be possible. That is arguably an acceptable trade-off though; there are too many benefits to ignore. The mobile experience in particular is really slick... getting all of this for free, without having to worry about the ongoing maintenance feels like a huge win:

Frame 1000005746

@DaniGuardiola
Copy link
Contributor

@jameskoster glad to see some agreement! FWIW, there are some ways to still get the design closer to what we want, mainly:

Not sure if they apply to these specific input types though. I would assume they do or, at least, they will at some point.

@jameskoster
Copy link
Contributor Author

Assuming we adopt the native input the design for this one seems relatively straight-forward, largely taking cues from other inputs types:

Screenshot 2024-09-23 at 13 35 42

There is however a question about implementation. In the post/page publish flows upcoming events are (loosely) displayed by virtue of an instance of DatePicker and its events prop. An equivalent would not be possible using the native input, so we'd need a different way of displaying upcoming events. Perhaps something like the following (left is current, right would be new):

date

Theoretically there could be a middle-ground:

middle

What do y'all think?

@jasmussen jasmussen added the Design System Issues related to the system of combining components according to best practices. label Sep 24, 2024
@oandregal
Copy link
Member

Thinking about this use case (filters for DataViews), for dates we'd want a mix of timepicker component + preset dates (today, last week, etc.). Is that a pattern that we'd use in more places than the DataViews filters? How do we see those two things working together (separate components, single one, etc.)?

@jameskoster
Copy link
Contributor Author

jameskoster commented Sep 25, 2024

@oandregal in addition to the simple TimePicker (an existing component) I think we need to create a new component for date range picking (which will likely have applications outside of filtering data views). I'll open a new issue never mind we already have one :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Design System Issues related to the system of combining components according to best practices. [Focus] Accessibility (a11y) Changes that impact accessibility and need corresponding review (e.g. markup changes). Needs Design Needs design efforts. [Package] Components /packages/components [Type] Enhancement A suggestion for improvement.
Projects
Status: Next
Status: 🏗️ In Progress
Development

No branches or pull requests

7 participants