ensl.org/app/assets/stylesheets/components/_forms.scss

343 lines
6.4 KiB
SCSS
Raw Normal View History

2014-04-06 14:14:03 +00:00
/*
Forms
*/
form {
.inline {
float: left;
display: inline-block;
width: auto;
margin-bottom: em(20);
input {
margin-bottom: 0;
}
}
.fields {
> .field_with_errors:first-child,
> label {
padding: em(11) 0;
line-height: em(16);
}
2014-04-06 14:14:03 +00:00
> .field_with_errors {
2014-04-06 14:14:03 +00:00
input,
textarea {
border: $input-border-width solid $flash-error;
2014-04-06 14:14:03 +00:00
&:hover,
&:focus {
border-color: $flash-error;
}
2014-04-06 14:14:03 +00:00
&:focus {
color: $input-text;
}
}
}
2014-04-06 14:14:03 +00:00
.select-wrapper {
2014-04-18 00:07:07 +00:00
$select-padding: em(7);
border-radius: $input-border-radius;
background-color: $input-primary;
border: $input-border-colour solid $input-border-width;
position: relative;
display: inline-block;
margin-right: em(10);
2014-04-17 20:26:25 +00:00
float: left;
max-width: 100%;
select {
@include appearance(none);
font-size: $input-font-size;
font-family: $open-sans;
float: left;
display: block;
width: auto;
position: relative;
line-height: em(22);
vertical-align: middle;
max-height: em(36);
margin-left: 0;
border: 0;
2014-04-18 00:07:07 +00:00
margin: 0;
padding: $select-padding em(50) $select-padding $input-padding;
font-size: $input-font-size;
max-width: 100%;
option {
font-size: $input-font-size;
}
&:focus {
outline: none;
}
}
&:after {
font-family: $fontawesome;
pointer-events: none;
content: $fa-var-chevron-down;
font-weight: normal;
font-style: normal;
position: absolute;
2014-04-18 00:07:07 +00:00
top: 0;
right: 0;
text-align: center;
padding-top: em(6);
width: em(36);
height: em(32);
border-left: $input-border-width solid $input-border-colour;
color: $input-border-colour;
}
&:hover {
border: $input-border-width solid lighten($input-secondary, 20%);
2014-04-18 00:07:07 +00:00
&:after {
border-left: $input-border-width solid lighten($input-secondary, 20%);
2014-04-18 00:07:07 +00:00
color: $base-font-color;
}
}
&:focus {
border: $input-border-width solid $input-secondary;
color: $input-secondary;
}
}
input[type=text],
input[type=password],
input[type=email],
textarea {
border-radius: $input-border-radius;
background-color: $input-primary;
color: $input-text;
font-size: $input-font-size;
padding: 0 $input-padding;
height: em(40);
border: $input-border-colour solid $input-border-width;
&:hover {
border: $input-border-width solid lighten($input-secondary, 20%);
}
&:focus {
border: $input-border-width solid $input-secondary;
outline: none;
}
&[disabled] {
&:hover {
border-color: $input-border-colour;
cursor: not-allowed;
}
}
}
textarea {
padding: $input-padding;
font-family: $open-sans;
}
2014-04-27 01:35:13 +00:00
.inputs label.checkbox,
> label.checkbox {
position: relative;
width: em(40);
height: em(40);
overflow: hidden;
&:before {
@include box-sizing(border-box);
content: "";
display: block;
border-radius: $input-border-radius;
width: em(40);
height: em(40);
padding: $input-padding;
background-color: $input-primary;
border: $input-border-colour solid $input-border-width;
margin: 0;
}
&:hover {
&:before {
border: $input-border-width solid lighten($input-secondary, 20%);
}
}
}
input[type=checkbox] {
display: none;
&:checked {
& + label.checkbox:before {
content: $fa-var-check;
pointer-events: none;
font-family: $fontawesome;
font-weight: normal;
font-style: normal;
color: $light-blue;
}
}
}
textarea {
height: auto;
width: 100%;
}
2014-04-06 14:14:03 +00:00
}
.controls {
margin-bottom: em(20);
button,
input[type=submit] {
@include button($button-primary);
border-radius: $input-border-radius;
border: $input-border-width solid $button-primary;
margin-bottom: 0;
outline: none;
}
}
}
2014-04-06 14:14:03 +00:00
form.dark {
.fields {
2014-04-06 14:14:03 +00:00
input {
color: white;
background: $input-dark-background-colour;
border: $input-dark-border-colour solid $input-dark-border-width;
2014-04-06 14:14:03 +00:00
&:hover {
border: $input-dark-border-width solid $input-dark-border-hover-colour;
2014-04-06 14:14:03 +00:00
}
&:focus {
border: $input-dark-border-width solid $input-dark-border-focus-colour;
}
&:-webkit-autofill {
-webkit-text-fill-color: white !important;
-webkit-box-shadow: 0 0 0px 1000px $input-dark-background-colour inset;
2014-04-06 14:14:03 +00:00
}
}
}
.controls {
margin-bottom: 20px;
2014-04-06 14:14:03 +00:00
button,
input {
2014-04-18 00:07:07 +00:00
background-color: $dark-blue;
2014-04-06 14:14:03 +00:00
}
}
}
2014-04-06 14:14:03 +00:00
form.square {
@include span-columns(12);
margin: em(20) 0;
.horizontal {
@include span-columns(12);
margin-bottom: em(20);
&.small {
@include span-columns(6);
}
2014-04-06 14:14:03 +00:00
&.medium {
@include span-columns(9);
}
2014-04-06 14:14:03 +00:00
&.large {
@include span-columns(12);
}
> .field_with_errors:first-child,
> label,
> .label {
@include span-columns(3);
padding: em(11) 0;
line-height: em(16);
&.checkbox {
width: em(40);
padding: 0;
}
}
input[type=text],
input[type=password],
input[type=email],
textarea {
@include span-columns(9);
}
2014-04-17 20:26:25 +00:00
.inputs {
@include span-columns(9);
input[type=text],
input[type=password],
input[type=email] {
width: 100%;
}
}
&.wide {
> .field_with_errors {
width: 100%;
}
label {
width: 100%;
}
textarea,
.mceLayout {
width: 100%;
}
}
}
.controls {
@include span-columns(9);
@include shift(3);
2014-04-17 20:26:25 +00:00
&.inline {
margin-left: 0;
width: auto;
}
2014-04-06 14:14:03 +00:00
}
}
2014-04-13 11:16:51 +00:00
form.search {
.query {
@include span-columns(7 of 9);
2014-04-13 11:16:51 +00:00
input {
width: 100%;
}
}
.controls {
@include span-columns(2 of 9);
2014-04-13 11:16:51 +00:00
@include shift(0);
@include omega;
input {
width: 100%;
}
}
}