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

Use oklch for the Jenkins UI #10078

Merged
merged 22 commits into from
Jan 15, 2025
Merged

Use oklch for the Jenkins UI #10078

merged 22 commits into from
Jan 15, 2025

Conversation

janfaracik
Copy link
Contributor

@janfaracik janfaracik commented Dec 19, 2024

I've really wanted to do this one for a while, combination of waiting for tooling and browser support to catch up. This PR uses oklch for colours to ensure that our palette is consistent (e.g. colours used for tables, cards, buttons all inherit from the same colour and only have to be defined once).

This change won't have much visual impact on Jenkins, but it will ensure that things are consistent in a way that wasn't easy to do so before. You'll notice slight hue changes here and there across the UI, and actual colours will pop a little bit more depending on if your display supports it.

View comparison

This change also makes it easier for theme developers, say if a developer wanted to develop an 'Accent colour' plugin they'd only need to update one variable (--accent-color) and Jenkins would reflect that across the UI.

image

Changing the accent colour property can have quite an impact on the overall interface now

Why oklch?

  • OKLCH frees designers from the need to manually choose every color. Designers can define a formula, choose a few colors, and an entire design system palette is automatically generated.
  • OKLCH can be used for wide-gamut P3 colors. For instance, new devices (like those from Apple) can display more colors than old sRGB monitors, and we can use OKLCH to specify these new colors.
  • Unlike hsl(), OKLCH is better for color modifications and palette generation. It uses perceptual lightness, so no more unexpected results, like we had with darken() in Sass.
  • Further, with its predictable lightness, OKLCH provides better a11y.
  • Unlike rgb() or hex (#ca0000), OKLCH is human readable. You can quickly and easily know which color an OKLCH value represents simply by looking at the numbers. OKLCH works like HSL, but it encodes lightness better than HSL.

From https://evilmartians.com/chronicles/oklch-in-css-why-quit-rgb-hsl

Testing done

  • Tried in Safari + Chrome
  • Tried in Firefox + Firefox ESR

BOM test: jenkinsci/bom#4187 (in progress)

Proposed changelog entries

  • Use oklch for the Jenkins UI

Proposed upgrade guidelines

N/A

Submitter checklist

Preview Give feedback

Desired reviewers

@jenkinsci/sig-ux

Before the changes are marked as ready-for-merge:

Maintainer checklist

Preview Give feedback

@janfaracik janfaracik added web-ui The PR includes WebUI changes which may need special expertise rfe For changelog: Minor enhancement. use `major-rfe` for changes to be highlighted labels Dec 19, 2024
Copy link
Member

@timja timja left a comment

Choose a reason for hiding this comment

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

does dark theme need a similar PR?

(I haven't run this yet but the comparison screenshots look identical to me

@janfaracik
Copy link
Contributor Author

does dark theme need a similar PR?

It doesn't need one (e.g. still looks fine), but I want to create one to bring over oklch + one for jenkins.io for consistency.

(I haven't run this yet but the comparison screenshots look identical to me

Yeah the hue of the UI is very slightly different, not intended to be noticeable by the user but it does make our UI's theme more consistent.

Copy link
Member

@timja timja left a comment

Choose a reason for hiding this comment

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

@github-actions github-actions bot added the unresolved-merge-conflict There is a merge conflict with the target branch. label Jan 5, 2025
Copy link
Contributor

github-actions bot commented Jan 5, 2025

Please take a moment and address the merge conflicts of your pull request. Thanks!

@github-actions github-actions bot removed the unresolved-merge-conflict There is a merge conflict with the target branch. label Jan 5, 2025
@timja
Copy link
Member

timja commented Jan 12, 2025

HtmlUnit update in #10146

Copy link
Member

@timja timja left a comment

Choose a reason for hiding this comment

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

LGTM

@timja timja added the needs-pct-build A run through of bom is needed label Jan 13, 2025
@timja
Copy link
Member

timja commented Jan 13, 2025

Due to HtmlUnit upgrade required, lets run this through bom before going further with it

@timja timja added pct-successful This PR has successfully passed the full plugin-compatibility-test suite and removed needs-pct-build A run through of bom is needed labels Jan 14, 2025
@timja timja requested a review from a team January 14, 2025 07:47
@krisstern
Copy link
Member

This PR is now ready for merge. We will merge it after approximately 24 hours if there is no negative feedback.

/label ready-for-merge

@comment-ops-bot comment-ops-bot bot added the ready-for-merge The PR is ready to go, and it will be merged soon if there is no negative feedback label Jan 14, 2025
@krisstern krisstern merged commit 9a97e25 into jenkinsci:master Jan 15, 2025
16 checks passed
@janfaracik janfaracik deleted the oklch branch January 15, 2025 09:51
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
pct-successful This PR has successfully passed the full plugin-compatibility-test suite ready-for-merge The PR is ready to go, and it will be merged soon if there is no negative feedback rfe For changelog: Minor enhancement. use `major-rfe` for changes to be highlighted web-ui The PR includes WebUI changes which may need special expertise
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants