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

Yui button inspired style #10061

Open
wants to merge 11 commits into
base: master
Choose a base branch
from
29 changes: 29 additions & 0 deletions src/main/scss/components/_buttons.scss
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,35 @@
}
}

.jenkins-button--outline {
color: var(--btn-secondary-color) !important;
Copy link
Contributor

Choose a reason for hiding this comment

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

--btn-* vars are deprecated (YUI only), would just use var(--text-color) if it needs to be set.

border: 2px solid var(--btn-secondary-border);
font-weight: bold;
Copy link
Contributor

Choose a reason for hiding this comment

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

These props could be inherited from the base jenkins-button class.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Well but the original yui outline button had been bold, but if you want we can change it but IMHO it makes more sense bold.
image
vs
image

font-size: var(--font-size-xs);
&::before {

Check warning on line 83 in src/main/scss/components/_buttons.scss

View check run for this annotation

ci.jenkins.io / Stylelint

rule-empty-line-before

ERROR: Expected empty line before rule (rule-empty-line-before)
background: transparent !important;
}

&:not(:disabled) {
&:hover {
border: 2px solid var(--accent-color) !important;
Copy link
Contributor

@janfaracik janfaracik Dec 18, 2024

Choose a reason for hiding this comment

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

This wouldn't work if paired with colour modifiers. We've been using currentColor in our other button modifiers to inherit the colour from modifiers.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

hmm are you sure
image
however I added jenkins-button--outline[class*="color"]

Copy link
Contributor Author

Choose a reason for hiding this comment

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

jenkins-button jenkins-button--outline jenkins-!-success-color
image
:hover
image

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Copy link
Contributor

Choose a reason for hiding this comment

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

Heya, I'm travelling today but I'll take a look as soon as I can :)

Copy link
Contributor Author

Choose a reason for hiding this comment

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

good traveling and MCAAHNY

Copy link
Contributor

Choose a reason for hiding this comment

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

Thanks, hope you had a good time too :)

image
.jenkins-button--outline {
  color: var(--color, var(--text-color-secondary)) !important;
  --button-background--hover: color-mix(in srgb, var(--color, var(--text-color-secondary)) 15%, transparent);
  --button-background--active: color-mix(in srgb, var(--color, var(--text-color-secondary)) 20%, transparent);
  --button-box-shadow--focus: color-mix(in srgb, var(--color, var(--text-color-secondary)) 10%, transparent);

  &::before {
    background: transparent;
    border: 2px solid var(--color, var(--text-color-secondary));
    opacity: 1 !important;
  }

  &:hover {
    &::before {
      background: var(--button-background--hover) !important;
    }
  }

  &:active {
    &::before {
      background: var(--button-background--active) !important;
    }
  }
}

.jenkins-button[class*="color"] {
  background: transparent;
  color: var(--color) !important;

  &::before {
    --button-background: currentColor; // changed this
    opacity: 0.1;
  }

How is something like this? The buttons styling is a little confusing (and more complex than it needs to be as modern CSS wasn't available when it was originally written, I do wanna tidy up this file)

I’m not totally sure about adding an outline button to core - I feel our default/secondary style already covers the same ground. Any thoughts on using it as a local class, using a prefix like {plugin-name}- instead of jenkins-?

Any thoughts @jenkinsci/sig-ux ?

color: var(--accent-color) !important;
}

&:active,
&:focus-visible {
&::before {
opacity: 0.8;
}

&::after {
box-shadow: 0 0 0 0.33rem var(--accent-color);
opacity: 0.2;
}
}
}
}

.jenkins-button--tertiary {
&::before {
background: transparent;
Expand Down
Loading