You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
When using ColorArea with a large size (e.g., 360px or more) and with HSB/HSL color model, the ColorThumb starts to jitter during mouse drag interactions. This is especially noticeable when moving the thumb diagonally or in rapid movements. It appears to be caused by the lack of control over the xChannelStep and yChannelStep properties in useColorAreaState.
This is noticeable even in your documentation, but not so much because your color selection area is only 192px
🤔 Expected Behavior?
The ColorThumb should move smoothly regardless of the size of the ColorArea.
Developers should be able to configure xChannelStep and yChannelStep in useColorAreaState to fine-tune the behavior for larger ColorArea sizes.
😯 Current Behavior
The useColorAreaState hook in react-aria does not provide options to configure xChannelStep and yChannelStep. As a result, when using a large ColorArea (e.g., 500px or more), the ColorThumb exhibits jittery behavior during dragging. The lack of configurability forces developers to rely on the default step values, which are not optimal for larger sizes.
Additionally, customizing the behavior requires duplicating the useColorAreaState hook and implementing a custom ColorArea component, which leads to maintenance overhead and dependency management issues.
💁 Possible Solution
Add support for xChannelStep and yChannelStep in useColorAreaState. This would allow developers to configure the precision of movements based on the size of the ColorArea.
It would also be nice to add these props to the ColorArea component so that users don't have to create their own ColorArea because of the need to pass props.
Alternatively, implement an automatic step calculation based on the size of the ColorArea to ensure smooth thumb movement.
🔦 Context
Library version: from 1.2.1 to 1.5.0 and further
I had to duplicate the useColorAreaState hook in my project, create a custom ColorArea component, and pin the react-aria library to a specific version without using the caret (^) to avoid breaking changes.
🖥️ Steps to Reproduce
Steps to reproduce:
Create a ColorArea with dimensions larger than 100px (e.g., 500px).
Attempt to drag the ColorThumb diagonally or in rapid movements.
Observe the jittery behavior of the ColorThumb.
(or go to react-aria site, find an example with hsl/hsb. For clarity, you can increase the size of the area in DevTools)
Version
from 1.2.1 to 1.5.0 and later
What browsers are you seeing the problem on?
Chrome
If other, please specify.
No response
What operating system are you using?
MacOS
🧢 Your Company/Team
No response
🕷 Tracking Issue
No response
The text was updated successfully, but these errors were encountered:
I'm not sure what your custom duplicate hook is doing. If I support overriding the xChannelStep and yChannelStep, it's still clamped to the value and does not get rid of the "jitter".
Could you provide a codesandbox or stackblitz demonstrating?
What I am worried about is what would "rgb=22.3,32.7,250.6" mean?
Also, setting a step like that would make it extremely painful for a keyboard user or AT user to move around.
Provide a general summary of the issue here
When using
ColorArea
with a large size (e.g., 360px or more) and with HSB/HSL color model, theColorThumb
starts to jitter during mouse drag interactions. This is especially noticeable when moving the thumb diagonally or in rapid movements. It appears to be caused by the lack of control over thexChannelStep
andyChannelStep
properties inuseColorAreaState
.This is noticeable even in your documentation, but not so much because your color selection area is only 192px
🤔 Expected Behavior?
ColorThumb
should move smoothly regardless of the size of theColorArea
.xChannelStep
andyChannelStep
inuseColorAreaState
to fine-tune the behavior for largerColorArea
sizes.😯 Current Behavior
The useColorAreaState hook in react-aria does not provide options to configure xChannelStep and yChannelStep. As a result, when using a large ColorArea (e.g., 500px or more), the ColorThumb exhibits jittery behavior during dragging. The lack of configurability forces developers to rely on the default step values, which are not optimal for larger sizes.
Additionally, customizing the behavior requires duplicating the useColorAreaState hook and implementing a custom ColorArea component, which leads to maintenance overhead and dependency management issues.
💁 Possible Solution
Add support for xChannelStep and yChannelStep in useColorAreaState. This would allow developers to configure the precision of movements based on the size of the ColorArea.
It would also be nice to add these props to the ColorArea component so that users don't have to create their own ColorArea because of the need to pass props.
Alternatively, implement an automatic step calculation based on the size of the ColorArea to ensure smooth thumb movement.
🔦 Context
Library version: from 1.2.1 to 1.5.0 and further
I had to duplicate the useColorAreaState hook in my project, create a custom ColorArea component, and pin the react-aria library to a specific version without using the caret (^) to avoid breaking changes.
🖥️ Steps to Reproduce
Steps to reproduce:
ColorArea
with dimensions larger than 100px (e.g., 500px).ColorThumb
diagonally or in rapid movements.ColorThumb
.(or go to react-aria site, find an example with hsl/hsb. For clarity, you can increase the size of the area in DevTools)
Version
from 1.2.1 to 1.5.0 and later
What browsers are you seeing the problem on?
Chrome
If other, please specify.
No response
What operating system are you using?
MacOS
🧢 Your Company/Team
No response
🕷 Tracking Issue
No response
The text was updated successfully, but these errors were encountered: