/
_input.scss
61 lines (52 loc) · 1.99 KB
/
_input.scss
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
// @page Pattern Library/Forms
// @name Inputs
//
// @description
// Our standard input styling across the website. This is specifically for text, email, password, search etc. type inputs.
//
// #### Best practices
// * Specifying an appropriate [type attribute](https://developer.mozilla.org/en/docs/Web/HTML/Element/Input#attr-type) (e.g. type="tel" for telephone number fields) will not only control what input is displayed, but also helps mobile devices select a keyboard layout suitable for entering that type of data.
// * Where appropriate use the [autocomplete attribute](https://developer.mozilla.org/en/docs/Web/HTML/Element/Input#attr-autocomplete) to make it easier for the browser to fill in fields on the users behalf, saving them time on lengthy forms.
//
// @state .us-form-input--large - Larger input style.
// @state .us-form-input--blocked - Fluid input style.
// @state .us-form-input--error - Visual feedback for when the input has an error.
// @state .us-form-input--success - Visual feedback for when success needs to be communicated to the user.
// @state .us-form-input--disabled - Inactive state for form inputs that can't be interacted with.
//
// @markup
// <input class="us-form-input {$modifiers}" type="text" placeholder="Placeholder">
$input-placeholder-color: $c-inputgrey !default;
.us-form-input {
@extend %base-form-element;
@extend %input-background--normalise;
@include placeholder($input-placeholder-color);
@include input-sizing();
outline: 0;
box-shadow: none;
&:focus {
@include placeholder(darken($input-placeholder-color, 15%));
}
@if $media-query-legacy-support {
.ie8 & {
height: auto;
}
}
}
.us-form-input.large,
.us-form-input--large {
@include input-sizing(large);
}
.us-form-input--blocked {
width: 100%;
}
.us-form-input--error {
@extend %base-form-element--error;
}
.us-form-input--success {
@extend %base-form-element--success;
}
.us-form-input:disabled,
.us-form-input--disabled {
@include form-element-disabled;
}