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

Switch to custom properties for colorizing buttons #30500

Closed
wants to merge 1 commit into from

Conversation

MartijnCuppens
Copy link
Member

No description provided.

@MartijnCuppens MartijnCuppens force-pushed the master-mc-btn-custom-properties branch from be1c401 to 4a26947 Compare April 2, 2020 17:02
@MartijnCuppens MartijnCuppens force-pushed the master-mc-btn-custom-properties branch from 4a26947 to f1297ef Compare April 11, 2020 18:39
Comment on lines +77 to +89
&:focus,
&.focus {
color: var(--btn-accent-contrast-color);
background-color: var(--btn-accent-color);
border-color: var(--btn-accent-color);
}

&.active,
&:active {
color: var(--btn-accent-contrast-color);
background-color: var(--btn-accent-color);
border-color: var(--btn-accent-color);
}
Copy link
Member

Choose a reason for hiding this comment

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

Those are the same, can't we have a single selector stack?

@ffoodd
Copy link
Member

ffoodd commented Apr 14, 2020

Looks very promising, makes a lot of sense.

@MartijnCuppens
Copy link
Member Author

We need to fix #29422 (comment) first, since the focus states also need to change for inputs, otherwise we 'll have inconsistent focus styles.

@mdo mdo changed the base branch from master to main June 16, 2020 20:03
Comment on lines +67 to +90
.btn-outline {
color: var(--btn-accent-color);
background-color: transparent;
border-color: currentColor;

&:hover {
background-color: var(--btn-accent-color);
border-color: var(--btn-accent-color);
}

&:focus,
&.focus {
color: var(--btn-accent-contrast-color);
background-color: var(--btn-accent-color);
border-color: var(--btn-accent-color);
}

&.active,
&:active {
color: var(--btn-accent-contrast-color);
background-color: var(--btn-accent-color);
border-color: var(--btn-accent-color);
}
}
Copy link

Choose a reason for hiding this comment

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

If I am not mistaken, the approach would be something like,

.btn {
  --btn-color: default here;
  --btn-background-color: default here;
  --btn-border-color: currentColor;

  color: var(--btn-color);
  background-color: var(--btn-background-color);
  border-color: var(--btn-border-color);
}

.btn-outline {
  --btn-color: change me;
  --btn-background-color: change me;
  --btn-border-color: change me;

  &:hover {
     --btn-color: change me;
     --btn-background-color: change me;
     --btn-border-color: change me;
  }

  &:focus,
  &.focus {
      --btn-color: default here;
      --btn-background-color: default here;
      --btn-border-color: currentColor;
  }

  &.active,
  &:active {
      --btn-color: change me;
      --btn-background-color: change me;
      --btn-border-color: change me;
  }
}

the idea is that you focus more on swapping the values than overriding styles.

At least that is how I understand it.

border-color: currentColor;

&:hover {
background-color: var(--btn-accent-color);
Copy link
Contributor

Choose a reason for hiding this comment

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

If we put here --btn-accent-color for hover background-color and for color library user can't make these values different without styles overwrite or setting own selectors with variables values.

For example I want to set color as red, but background-color as green
I will need to write:

.btn-outline {
  --btn-accent-color: red;
  &:hover {
    --btn-accent-color: green;
  }
}

I think better do config just with set of variables without writing new nested selectors. What do you think?
And, btw, isn't there color will be the same as background color or not?

Copy link
Contributor

@ydmitry ydmitry Sep 23, 2020

Choose a reason for hiding this comment

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

If we use approach similar to #31708 with placing in SCSS styles only SCSS variables, but in SCSS variables set CSS variables, we could do:

// Styles
.btn-outline {
  color: $btn-color;
  &:hover {
     background-color: $btn-hover-bg-color;
  }
}

// Default variables, will do the same as in PR
$btn-color: var(--btn-accent-color) !default;
$btn-hover-bg-color: var(--btn-accent-color) !default;

// In application can changed to e.g.:
$btn-color: var(--btn-color);
$btn-hover-bg-color: var(--btn-hover-bg-color);

// In application custom styles - setting variant without knowing selectors structure
.btn-custom {
  --btn-color: red;
  --btn-hover-color-bg: green;
}

@each $color, $value in $theme-colors {
.btn-outline-#{$color} {
@include button-outline-variant($value);
--btn-accent-color: #{$value};

Choose a reason for hiding this comment

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

I'm a bit confused by the fact that the variables are set here. The nice thing about CSS variables are that they cascade through the DOM hierarchy, so that devs can set these e.g. at the :root or some other ascendant of a button, and every button (and other element that was configured in the ancestor) below that ancestor will use the same theme - without having to use any descendant selectors for .btn etc.

But if the variable is set here on the .btn element, then it seems that wouldn't work, because it would always override what was set in an ancestor. So to make it work, define a theme for all descendant Bootstrap components at an ancestor element, it seems we'd have to use specific descendant selectors like .btn again to override the variables. That kind of defeats the purpose of the variables mostly.

How I imagine it, components like .btn would only read variables, and they are set e.g. on :root or any ancestor by devs (and Bootstrap can provide defaults on those and integrate them there with the Sass variables).

Copy link
Contributor

@ydmitry ydmitry Sep 30, 2020

Choose a reason for hiding this comment

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

I have the same impression, looks like CSS custom properties here used to refactor code in a cool way, not to increase customization capabilities and flexibility...

So, it's improves only internal Bootstrap development experience, decreases bundles size, provides some additional usages of modifiers, but not improves customization.

@XhmikosR
Copy link
Member

@MartijnCuppens can you rebase this please?

@mdo
Copy link
Member

mdo commented Apr 22, 2021

Closing as stale and with hella conflicts 😅

@mdo mdo closed this Apr 22, 2021
@XhmikosR XhmikosR deleted the master-mc-btn-custom-properties branch May 13, 2021 16:47
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants