- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 2
          [color-swatch] Add the colorInfo prop
          #118
        
          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
Conversation
Make the color info available programmatically.
| ✅ Deploy Preview for color-elements ready!
 To edit notification comments on pull requests, go to your Netlify site configuration. | 
| I'd like to discuss what is more helpful (for our users) to expose as  Option 1{
    Lightness: 0.9158,
    Chroma: 0.05112,
    Hue: 349.9
}Option 2{
    "oklch.l": 0.9158,
    "oklch.c": 0.05112,
    "oklch.h": 349.9
} | 
| I would vote for the keys, the labels might even be localized or have weird characters. | 
| 
 Thank you. I'm leaning toward that, too. Let me update the code, then. | 
…r code optimization
        
          
                src/color-swatch/color-swatch.js
              
                Outdated
          
        
      | }, | ||
| dependencies: ["color"], | ||
| }, | ||
| infoLabels: { | 
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.
Why do we need a separate infoLabels prop?
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.
Initially, I was thinking of optimizing the code so that we don't have to use Object.entries every time we need to get a channel and its label. It turned out that this was not a good idea: actually, we needed to do this in one place, so there was no need to add an extra prop. I removed it. Thank you for the question; it helped me see the flaw.
That was not a good idea: it's not that much reusable as it seemed to me from the first sight
We should round the result when using it in the UI
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.
LGTM

As we discussed in #96, the color info is also helpful to get programmatically. This PR addresses this. Under the hood, the data structure suggested by @LeaVerou (Option 1) is used.
This PR is the first step to implementing deltas and contrast and is intended to check if I got the main idea shaped in the PR mentioned right. The existing API is the same, so it's not a breaking change. Everything still works as before.
The gist of what this PR introduces can be seen in the screenshot (
<color-swatch>is a Lego block for color charts):