Skip to content

Commit

Permalink
Use consistent padding for input and select elements
Browse files Browse the repository at this point in the history
Only apply extra top padding to textareas where it is needed.

Also removed unnecessary floating label background for non-textareas (supersedes twbs#39480).
  • Loading branch information
theodorejb committed Jan 30, 2024
1 parent 1edcce4 commit ad2005a
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 7 deletions.
7 changes: 3 additions & 4 deletions scss/_variables.scss
Expand Up @@ -1072,10 +1072,9 @@ $form-floating-height: add(3.5rem, $input-height-border) !defau
$form-floating-line-height: 1.3125 !default;
$form-floating-padding-x: $input-padding-x !default;
$form-floating-padding-y: 1rem !default;
$form-floating-input-padding-t: 1.625rem !default;
$form-floating-input-padding-b: .625rem !default;
$form-floating-select-padding-t: 1.25rem !default;
$form-floating-select-padding-b: .25rem !default;
$form-floating-input-padding-t: 1.25rem !default;
$form-floating-input-padding-b: .25rem !default;
$form-floating-textarea-padding-t: 1.625rem !default;
$form-floating-label-height: 1.5em !default;
$form-floating-label-opacity: .65 !default;
$form-floating-label-transform: scale(.85) translateY(-.5rem) translateX(.15rem) !default;
Expand Down
21 changes: 18 additions & 3 deletions scss/forms/_floating-labels.scss
Expand Up @@ -47,8 +47,8 @@
}

> .form-select {
padding-top: $form-floating-select-padding-t;
padding-bottom: $form-floating-select-padding-b;
padding-top: $form-floating-input-padding-t;
padding-bottom: $form-floating-input-padding-b;
}

> .form-control:focus,
Expand All @@ -65,11 +65,26 @@
z-index: -1;
height: $form-floating-label-height;
content: "";
background-color: $input-bg;
@include border-radius($input-border-radius);
}
}
}
> textarea.form-control {
// textareas require additional top padding to prevent label from overlapping text
&:focus,
&:not(:placeholder-shown) {
padding-top: $form-floating-textarea-padding-t;
}
// Duplicated because `:-webkit-autofill` invalidates other selectors when grouped
&:-webkit-autofill {
padding-top: $form-floating-textarea-padding-t;
}

// set textarea label background so it will remain legible when text is scrolled
~ label::after {
background-color: $input-bg;
}
}
// Duplicated because `:-webkit-autofill` invalidates other selectors when grouped
> .form-control:-webkit-autofill {
~ label {
Expand Down

0 comments on commit ad2005a

Please sign in to comment.