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

Added hex color conversion #1432

Merged
merged 10 commits into from
Nov 13, 2024
Merged

Added hex color conversion #1432

merged 10 commits into from
Nov 13, 2024

Conversation

jsheely
Copy link
Contributor

@jsheely jsheely commented Jan 15, 2024

Solves issue #1354

I'm not sure if this is desired but seemed like an easy quality of life feature to allow hex to rgb for creating colors.


Please upvote 👍 this pull request if you are interested in it.

Copy link
Contributor

@patriksvensson patriksvensson left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  • The constructor only tests the happy path.
  • I think public static Color.FromHex(string hex) would be a more desirable approach here from an API perspective.
  • All errors will need to be resolved.

@nils-a
Copy link
Contributor

nils-a commented Jan 16, 2024

  • I think public static Color.FromHex(string hex) would be a more desirable approach here from an API perspective.

I'd vote for a combination of public static Color ParseHex(string hex) and public static bool TryParseHex(string hex, out Color color)

@patriksvensson
Copy link
Contributor

We use "ToHex" so "FromHex" and "TryFromHex" is more consistent API wise

@FrankRay78
Copy link
Contributor

It looks like hex[2..4] is not supported in netstandard 2.0

@FrankRay78
Copy link
Contributor

Unfortunately, the build still breaks @jsheely - see the build log above, looks like simple char/string conversion error. Want to update and push again?

@FrankRay78
Copy link
Contributor

Thank you @jsheely, if no one else gets to it first, I'll review (and hopefully merge) your PR this week.

@FrankRay78 FrankRay78 added this to the 0.49 milestone Mar 20, 2024
test/Spectre.Console.Tests/Unit/ColorTests.cs Outdated Show resolved Hide resolved
test/Spectre.Console.Tests/Unit/ColorTests.cs Outdated Show resolved Hide resolved
@FrankRay78
Copy link
Contributor

Dear @patriksvensson, I have rebased this branch, implemented full unit test coverage for both happy and unhappy paths, and ensured the failure to parse an invalid colour raises a FormatException with (what seems to me) to be a reasonable message.

I think it's suitable for merging, please re-review when you can.

@github-actions github-actions bot added the ⭐ top pull request Top pull request. label Apr 21, 2024
@nils-a
Copy link
Contributor

nils-a commented May 30, 2024

Do we want to support the short-hands for hex values? (E.g. using #a1b instead of #aa11bb)

@FrankRay78
Copy link
Contributor

Do we want to support the short-hands for hex values? (E.g. using #a1b instead of #aa11bb)

You tell me @nils-a 😉, as someone who would like to merge this PR for me... I'm happy to implement the short color code if you'd like.

This (seemingly trivial) PR has been hanging around for too long for my liking.

@nils-a
Copy link
Contributor

nils-a commented Jul 31, 2024

This (seemingly trivial) PR has been hanging around for too long for my liking.

Agreed. Let's use it as it is.

@patriksvensson I feel your requested changes were addressed, right?

@FrankRay78
Copy link
Contributor

I'm pretty sure you want to merge this PR @nils-a . Remember that really nice, warm fuzzy feeling from doing so? It's waiting.

@github-actions github-actions bot added ⭐ top pull request Top pull request. and removed ⭐ top pull request Top pull request. labels Aug 30, 2024
@patriksvensson patriksvensson modified the milestones: 0.49, 0.50 Sep 2, 2024
@github-actions github-actions bot removed the ⭐ top pull request Top pull request. label Sep 6, 2024
@nils-a nils-a dismissed patriksvensson’s stale review November 13, 2024 12:22

requested changes were made.

@nils-a nils-a merged commit 574ead6 into spectreconsole:main Nov 13, 2024
3 checks passed
@nils-a
Copy link
Contributor

nils-a commented Nov 13, 2024

@jsheely your changes have been merged, thanks for your contribution 👍

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: PR 📬
Development

Successfully merging this pull request may close these issues.

Ability to instantiate a new instance of the Color class with a HEX color as well as RGB.
4 participants