govuk_publishing_components 21.58.0 → 21.60.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +31 -6
- data/app/assets/javascripts/component_guide/accessibility-test.js +21 -21
- data/app/assets/javascripts/component_guide/filter-components.js +19 -19
- data/app/assets/javascripts/component_guide/visual-regression.js +38 -37
- data/app/assets/javascripts/govuk_publishing_components/components/checkboxes.js +2 -2
- data/app/assets/javascripts/govuk_publishing_components/components/details.js +5 -3
- data/app/assets/javascripts/govuk_publishing_components/components/step-by-step-nav.js +4 -4
- data/app/assets/javascripts/govuk_publishing_components/lib/auto-track-event.js +31 -0
- data/app/assets/javascripts/govuk_publishing_components/lib/cookie-functions.js +24 -24
- data/app/assets/javascripts/govuk_publishing_components/lib/govspeak/youtube-link-enhancement.js +17 -17
- data/app/assets/stylesheets/component_guide/application.scss +15 -15
- data/app/assets/stylesheets/govuk_publishing_components/components/_action-link.scss +0 -8
- data/app/assets/stylesheets/govuk_publishing_components/components/_breadcrumbs.scss +1 -1
- data/app/assets/stylesheets/govuk_publishing_components/components/_checkboxes.scss +4 -0
- data/app/assets/stylesheets/govuk_publishing_components/components/_cookie-banner.scss +1 -8
- data/app/assets/stylesheets/govuk_publishing_components/components/_feedback.scss +0 -1
- data/app/assets/stylesheets/govuk_publishing_components/components/_govspeak-html-publication.scss +4 -5
- data/app/assets/stylesheets/govuk_publishing_components/components/_heading.scss +3 -8
- data/app/assets/stylesheets/govuk_publishing_components/components/_image-card.scss +1 -1
- data/app/assets/stylesheets/govuk_publishing_components/components/_input.scss +1 -1
- data/app/assets/stylesheets/govuk_publishing_components/components/_inverse-header.scss +5 -8
- data/app/assets/stylesheets/govuk_publishing_components/components/_radio.scss +4 -0
- data/app/assets/stylesheets/govuk_publishing_components/components/_related-navigation.scss +2 -2
- data/app/assets/stylesheets/govuk_publishing_components/components/_search.scss +0 -1
- data/app/assets/stylesheets/govuk_publishing_components/components/_step-by-step-nav-header.scss +0 -5
- data/app/assets/stylesheets/govuk_publishing_components/components/_step-by-step-nav-related.scss +1 -4
- data/app/assets/stylesheets/govuk_publishing_components/components/_step-by-step-nav.scss +8 -12
- data/app/assets/stylesheets/govuk_publishing_components/components/_table.scss +21 -24
- data/app/assets/stylesheets/govuk_publishing_components/components/_tabs.scss +4 -8
- data/app/assets/stylesheets/govuk_publishing_components/components/govspeak/_attachment.scss +2 -0
- data/app/assets/stylesheets/govuk_publishing_components/components/govspeak/_button.scss +1 -4
- data/app/assets/stylesheets/govuk_publishing_components/components/govspeak/_charts.scss +6 -6
- data/app/assets/stylesheets/govuk_publishing_components/components/govspeak/_contact.scss +2 -0
- data/app/assets/stylesheets/govuk_publishing_components/components/govspeak/_footnotes.scss +2 -0
- data/app/assets/stylesheets/govuk_publishing_components/components/govspeak/_highlight-answer.scss +2 -0
- data/app/assets/stylesheets/govuk_publishing_components/components/govspeak/_place.scss +1 -1
- data/app/assets/stylesheets/govuk_publishing_components/components/govspeak/_typography.scss +2 -0
- data/app/assets/stylesheets/govuk_publishing_components/components/helpers/_markdown-typography.scss +1 -1
- data/app/assets/stylesheets/govuk_publishing_components/components/print/_govspeak.scss +2 -0
- data/app/assets/stylesheets/govuk_publishing_components/components/print/_step-by-step-nav-header.scss +0 -4
- data/app/assets/stylesheets/govuk_publishing_components/components/print/_step-by-step-nav.scss +2 -10
- data/app/controllers/govuk_publishing_components/audit_controller.rb +52 -0
- data/app/controllers/govuk_publishing_components/component_guide_controller.rb +2 -2
- data/app/models/govuk_publishing_components/audit_applications.rb +117 -0
- data/app/models/govuk_publishing_components/audit_comparer.rb +198 -0
- data/app/models/govuk_publishing_components/audit_components.rb +158 -0
- data/app/views/govuk_publishing_components/audit/show.html.erb +258 -0
- data/app/views/govuk_publishing_components/component_guide/index.html.erb +7 -1
- data/app/views/govuk_publishing_components/components/_breadcrumbs.html.erb +1 -1
- data/app/views/govuk_publishing_components/components/_image_card.html.erb +1 -1
- data/app/views/govuk_publishing_components/components/_machine_readable_metadata.html.erb +1 -1
- data/app/views/govuk_publishing_components/components/_radio.html.erb +13 -5
- data/app/views/govuk_publishing_components/components/_share_links.html.erb +9 -9
- data/app/views/govuk_publishing_components/components/_step_by_step_nav_header.html.erb +2 -2
- data/app/views/govuk_publishing_components/components/docs/checkboxes.yml +4 -0
- data/app/views/govuk_publishing_components/components/docs/govspeak.yml +45 -0
- data/app/views/govuk_publishing_components/components/docs/heading.yml +6 -3
- data/app/views/govuk_publishing_components/components/docs/image_card.yml +13 -1
- data/app/views/govuk_publishing_components/components/docs/radio.yml +4 -0
- data/config/routes.rb +1 -0
- data/lib/govuk_publishing_components/presenters/checkboxes_helper.rb +15 -7
- data/lib/govuk_publishing_components/presenters/heading_helper.rb +21 -1
- data/lib/govuk_publishing_components/presenters/image_card_helper.rb +2 -1
- data/lib/govuk_publishing_components/version.rb +1 -1
- data/node_modules/axe-core/package.json +145 -220
- data/node_modules/govuk-frontend/govuk/all.js +160 -57
- data/node_modules/govuk-frontend/govuk/components/character-count/character-count.js +16 -8
- data/node_modules/govuk-frontend/govuk/components/character-count/macro-options.json +6 -0
- data/node_modules/govuk-frontend/govuk/components/character-count/template.njk +1 -0
- data/node_modules/govuk-frontend/govuk/components/checkboxes/_index.scss +6 -5
- data/node_modules/govuk-frontend/govuk/components/checkboxes/checkboxes.js +68 -21
- data/node_modules/govuk-frontend/govuk/components/date-input/macro-options.json +1 -1
- data/node_modules/govuk-frontend/govuk/components/file-upload/_index.scss +0 -27
- data/node_modules/govuk-frontend/govuk/components/footer/_index.scss +0 -3
- data/node_modules/govuk-frontend/govuk/components/footer/template.njk +1 -1
- data/node_modules/govuk-frontend/govuk/components/header/template.njk +1 -1
- data/node_modules/govuk-frontend/govuk/components/hint/_index.scss +2 -2
- data/node_modules/govuk-frontend/govuk/components/hint/template.njk +2 -2
- data/node_modules/govuk-frontend/govuk/components/input/_index.scss +0 -3
- data/node_modules/govuk-frontend/govuk/components/input/macro-options.json +6 -0
- data/node_modules/govuk-frontend/govuk/components/input/template.njk +1 -0
- data/node_modules/govuk-frontend/govuk/components/radios/radios.js +76 -28
- data/node_modules/govuk-frontend/govuk/components/select/_index.scss +0 -3
- data/node_modules/govuk-frontend/govuk/components/skip-link/_index.scss +1 -0
- data/node_modules/govuk-frontend/govuk/components/textarea/_index.scss +0 -3
- data/node_modules/govuk-frontend/govuk/components/textarea/macro-options.json +6 -0
- data/node_modules/govuk-frontend/govuk/components/textarea/template.njk +1 -0
- data/node_modules/govuk-frontend/govuk/components/warning-text/_index.scss +4 -2
- data/node_modules/govuk-frontend/govuk/helpers/_colour.scss +1 -1
- data/node_modules/govuk-frontend/govuk/settings/_colours-applied.scss +2 -2
- data/node_modules/govuk-frontend/govuk/settings/_colours-palette.scss +1 -1
- data/node_modules/govuk-frontend/govuk/settings/_measurements.scss +4 -1
- data/node_modules/govuk-frontend/package.json +14 -81
- data/node_modules/jquery/package.json +44 -116
- metadata +29 -66
- data/Rakefile +0 -37
@@ -45,7 +45,7 @@
|
|
45
45
|
"name": "autocomplete",
|
46
46
|
"type": "string",
|
47
47
|
"required": false,
|
48
|
-
"description": "Attribute to [identify input purpose](https://www.w3.org/WAI/WCAG21/Understanding/identify-input-purpose.html), for instance \"
|
48
|
+
"description": "Attribute to [identify input purpose](https://www.w3.org/WAI/WCAG21/Understanding/identify-input-purpose.html), for instance \"bday-day\". See [autofill](https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#autofill) for full list of attributes that can be used."
|
49
49
|
},
|
50
50
|
{
|
51
51
|
"name": "pattern",
|
@@ -47,31 +47,4 @@
|
|
47
47
|
box-shadow: inset 0 0 0 4px $govuk-input-border-colour;
|
48
48
|
}
|
49
49
|
}
|
50
|
-
|
51
|
-
.govuk-file-upload--error {
|
52
|
-
// As `upload--error` has border, it needs to have the same padding as
|
53
|
-
// the standard focused element.
|
54
|
-
margin-right: -$component-padding;
|
55
|
-
margin-left: -$component-padding;
|
56
|
-
padding-right: $component-padding;
|
57
|
-
padding-left: $component-padding;
|
58
|
-
border: $govuk-border-width-form-element-error solid $govuk-error-colour;
|
59
|
-
|
60
|
-
&:focus {
|
61
|
-
border-color: $govuk-input-border-colour;
|
62
|
-
// Remove `box-shadow` inherited from `:focus` as `file-upload--error`
|
63
|
-
// already has the thicker border.
|
64
|
-
box-shadow: none;
|
65
|
-
}
|
66
|
-
|
67
|
-
// Repeat `:focus` styles to prevent error styles from being applied when
|
68
|
-
// input button is pressed as this moves the focus to "within".
|
69
|
-
// This can't be set together with `:focus` as all versions of IE fail
|
70
|
-
// to recognise `focus-within` and don't set any styles from the block
|
71
|
-
// when it's a selector.
|
72
|
-
&:focus-within {
|
73
|
-
border-color: $govuk-input-border-colour;
|
74
|
-
box-shadow: none;
|
75
|
-
}
|
76
|
-
}
|
77
50
|
}
|
@@ -210,20 +210,17 @@
|
|
210
210
|
padding: 0;
|
211
211
|
list-style: none;
|
212
212
|
-webkit-column-gap: $govuk-gutter;
|
213
|
-
-moz-column-gap: $govuk-gutter;
|
214
213
|
column-gap: $govuk-gutter; // Support: Columns
|
215
214
|
}
|
216
215
|
|
217
216
|
@include govuk-media-query ($from: desktop) {
|
218
217
|
.govuk-footer__list--columns-2 {
|
219
218
|
-webkit-column-count: 2;
|
220
|
-
-moz-column-count: 2;
|
221
219
|
column-count: 2; // Support: Columns
|
222
220
|
}
|
223
221
|
|
224
222
|
.govuk-footer__list--columns-3 {
|
225
223
|
-webkit-column-count: 3;
|
226
|
-
-moz-column-count: 3;
|
227
224
|
column-count: 3; // Support: Columns
|
228
225
|
}
|
229
226
|
}
|
@@ -16,7 +16,7 @@
|
|
16
16
|
// is unlikely that the default or govuk-label--s class would be used in this
|
17
17
|
// case.
|
18
18
|
|
19
|
-
// This adjustment will not work in browsers that do not support :not().
|
19
|
+
// This adjustment will not work in browsers that do not support :not().
|
20
20
|
// Users with these browsers will see the default size margin (5px larger).
|
21
21
|
|
22
22
|
.govuk-label:not(.govuk-label--m):not(.govuk-label--l):not(.govuk-label--xl) + .govuk-hint {
|
@@ -30,7 +30,7 @@
|
|
30
30
|
// it is unlikely that the default or govuk-fieldset__legend--s class would be
|
31
31
|
// used in this case.
|
32
32
|
|
33
|
-
// This adjustment will not work in browsers that do not support :not().
|
33
|
+
// This adjustment will not work in browsers that do not support :not().
|
34
34
|
// Users with these browsers will see the default size margin (5px larger).
|
35
35
|
|
36
36
|
.govuk-fieldset__legend:not(.govuk-fieldset__legend--m):not(.govuk-fieldset__legend--l):not(.govuk-fieldset__legend--xl) + .govuk-hint {
|
@@ -1,4 +1,4 @@
|
|
1
|
-
<
|
1
|
+
<div {%- if params.id %} id="{{ params.id }}"{% endif %} class="govuk-hint {%- if params.classes %} {{ params.classes }}{% endif %}"
|
2
2
|
{%- for attribute, value in params.attributes %} {{attribute}}="{{value}}"{% endfor %}>
|
3
3
|
{{ params.html | safe if params.html else params.text }}
|
4
|
-
</
|
4
|
+
</div>
|
@@ -88,6 +88,12 @@
|
|
88
88
|
"required": false,
|
89
89
|
"description": "Attribute to [provide a regular expression pattern](https://www.w3.org/TR/html51/sec-forms.html#the-pattern-attribute), used to match allowed character combinations for the input value."
|
90
90
|
},
|
91
|
+
{
|
92
|
+
"name": "spellcheck",
|
93
|
+
"type": "boolean",
|
94
|
+
"required": false,
|
95
|
+
"description": "Optional field to enable or disable the spellcheck attribute on the input."
|
96
|
+
},
|
91
97
|
{
|
92
98
|
"name": "attributes",
|
93
99
|
"type": "object",
|
@@ -38,6 +38,7 @@
|
|
38
38
|
}) | indent(2) | trim }}
|
39
39
|
{% endif %}
|
40
40
|
<input class="govuk-input {%- if params.classes %} {{ params.classes }}{% endif %} {%- if params.errorMessage %} govuk-input--error{% endif %}" id="{{ params.id }}" name="{{ params.name }}" type="{{ params.type | default('text') }}"
|
41
|
+
{%- if (params.spellcheck === false) or (params.spellcheck === true) %} spellcheck="{{ params.spellcheck }}"{% endif %}
|
41
42
|
{%- if params.value %} value="{{ params.value}}"{% endif %}
|
42
43
|
{%- if describedBy %} aria-describedby="{{ describedBy }}"{% endif %}
|
43
44
|
{%- if params.autocomplete %} autocomplete="{{ params.autocomplete}}"{% endif %}
|
@@ -1030,67 +1030,115 @@ function nodeListForEach (nodes, callback) {
|
|
1030
1030
|
|
1031
1031
|
function Radios ($module) {
|
1032
1032
|
this.$module = $module;
|
1033
|
+
this.$inputs = $module.querySelectorAll('input[type="radio"]');
|
1033
1034
|
}
|
1034
1035
|
|
1036
|
+
/**
|
1037
|
+
* Initialise Radios
|
1038
|
+
*
|
1039
|
+
* Radios can be associated with a 'conditionally revealed' content block – for
|
1040
|
+
* example, a radio for 'Phone' could reveal an additional form field for the
|
1041
|
+
* user to enter their phone number.
|
1042
|
+
*
|
1043
|
+
* These associations are made using a `data-aria-controls` attribute, which is
|
1044
|
+
* promoted to an aria-controls attribute during initialisation.
|
1045
|
+
*
|
1046
|
+
* We also need to restore the state of any conditional reveals on the page (for
|
1047
|
+
* example if the user has navigated back), and set up event handlers to keep
|
1048
|
+
* the reveal in sync with the radio state.
|
1049
|
+
*/
|
1035
1050
|
Radios.prototype.init = function () {
|
1036
1051
|
var $module = this.$module;
|
1037
|
-
var $inputs =
|
1052
|
+
var $inputs = this.$inputs;
|
1038
1053
|
|
1039
|
-
/**
|
1040
|
-
* Loop over all items with [data-controls]
|
1041
|
-
* Check if they have a matching conditional reveal
|
1042
|
-
* If they do, assign attributes.
|
1043
|
-
**/
|
1044
1054
|
nodeListForEach($inputs, function ($input) {
|
1045
|
-
var
|
1055
|
+
var target = $input.getAttribute('data-aria-controls');
|
1046
1056
|
|
1047
|
-
//
|
1048
|
-
//
|
1049
|
-
if (!
|
1057
|
+
// Skip radios without data-aria-controls attributes, or where the
|
1058
|
+
// target element does not exist.
|
1059
|
+
if (!target || !$module.querySelector('#' + target)) {
|
1050
1060
|
return
|
1051
1061
|
}
|
1052
1062
|
|
1053
|
-
//
|
1054
|
-
|
1063
|
+
// Promote the data-aria-controls attribute to a aria-controls attribute
|
1064
|
+
// so that the relationship is exposed in the AOM
|
1065
|
+
$input.setAttribute('aria-controls', target);
|
1055
1066
|
$input.removeAttribute('data-aria-controls');
|
1056
|
-
|
1057
|
-
|
1067
|
+
});
|
1068
|
+
|
1069
|
+
// When the page is restored after navigating 'back' in some browsers the
|
1070
|
+
// state of form controls is not restored until *after* the DOMContentLoaded
|
1071
|
+
// event is fired, so we need to sync after the pageshow event in browsers
|
1072
|
+
// that support it.
|
1073
|
+
if ('onpageshow' in window) {
|
1074
|
+
window.addEventListener('pageshow', this.syncAllConditionalReveals.bind(this));
|
1075
|
+
} else {
|
1076
|
+
window.addEventListener('DOMContentLoaded', this.syncAllConditionalReveals.bind(this));
|
1077
|
+
}
|
1078
|
+
|
1079
|
+
// Although we've set up handlers to sync state on the pageshow or
|
1080
|
+
// DOMContentLoaded event, init could be called after those events have fired,
|
1081
|
+
// for example if they are added to the page dynamically, so sync now too.
|
1082
|
+
this.syncAllConditionalReveals();
|
1058
1083
|
|
1059
1084
|
// Handle events
|
1060
1085
|
$module.addEventListener('click', this.handleClick.bind(this));
|
1061
1086
|
};
|
1062
1087
|
|
1063
|
-
|
1064
|
-
|
1088
|
+
/**
|
1089
|
+
* Sync the conditional reveal states for all inputs in this $module.
|
1090
|
+
*/
|
1091
|
+
Radios.prototype.syncAllConditionalReveals = function () {
|
1092
|
+
nodeListForEach(this.$inputs, this.syncConditionalRevealWithInputState.bind(this));
|
1093
|
+
};
|
1065
1094
|
|
1066
|
-
|
1095
|
+
/**
|
1096
|
+
* Sync conditional reveal with the input state
|
1097
|
+
*
|
1098
|
+
* Synchronise the visibility of the conditional reveal, and its accessible
|
1099
|
+
* state, with the input's checked state.
|
1100
|
+
*
|
1101
|
+
* @param {HTMLInputElement} $input Radio input
|
1102
|
+
*/
|
1103
|
+
Radios.prototype.syncConditionalRevealWithInputState = function ($input) {
|
1104
|
+
var $target = document.querySelector('#' + $input.getAttribute('aria-controls'));
|
1105
|
+
|
1106
|
+
if ($target && $target.classList.contains('govuk-radios__conditional')) {
|
1067
1107
|
var inputIsChecked = $input.checked;
|
1068
1108
|
|
1069
1109
|
$input.setAttribute('aria-expanded', inputIsChecked);
|
1070
|
-
|
1071
|
-
$content.classList.toggle('govuk-radios__conditional--hidden', !inputIsChecked);
|
1110
|
+
$target.classList.toggle('govuk-radios__conditional--hidden', !inputIsChecked);
|
1072
1111
|
}
|
1073
1112
|
};
|
1074
1113
|
|
1114
|
+
/**
|
1115
|
+
* Click event handler
|
1116
|
+
*
|
1117
|
+
* Handle a click within the $module – if the click occurred on a radio, sync
|
1118
|
+
* the state of the conditional reveal for all radio buttons in the same form
|
1119
|
+
* with the same name (because checking one radio could have un-checked a radio
|
1120
|
+
* in another $module)
|
1121
|
+
*
|
1122
|
+
* @param {MouseEvent} event Click event
|
1123
|
+
*/
|
1075
1124
|
Radios.prototype.handleClick = function (event) {
|
1076
1125
|
var $clickedInput = event.target;
|
1077
|
-
|
1126
|
+
|
1127
|
+
// Ignore clicks on things that aren't radio buttons
|
1078
1128
|
if ($clickedInput.type !== 'radio') {
|
1079
1129
|
return
|
1080
1130
|
}
|
1081
|
-
|
1082
|
-
//
|
1083
|
-
//
|
1084
|
-
// We also only want radios which have aria-controls, as they support conditional reveals.
|
1131
|
+
|
1132
|
+
// We only need to consider radios with conditional reveals, which will have
|
1133
|
+
// aria-controls attributes.
|
1085
1134
|
var $allInputs = document.querySelectorAll('input[type="radio"][aria-controls]');
|
1135
|
+
|
1086
1136
|
nodeListForEach($allInputs, function ($input) {
|
1087
|
-
// Only inputs with the same form owner should change.
|
1088
1137
|
var hasSameFormOwner = ($input.form === $clickedInput.form);
|
1089
|
-
|
1090
|
-
// In radios, only radios with the same name will affect each other.
|
1091
1138
|
var hasSameName = ($input.name === $clickedInput.name);
|
1139
|
+
|
1092
1140
|
if (hasSameName && hasSameFormOwner) {
|
1093
|
-
this.
|
1141
|
+
this.syncConditionalRevealWithInputState($input);
|
1094
1142
|
}
|
1095
1143
|
}.bind(this));
|
1096
1144
|
};
|
@@ -11,6 +11,12 @@
|
|
11
11
|
"required": true,
|
12
12
|
"description": "The name of the textarea, which is submitted with the form data."
|
13
13
|
},
|
14
|
+
{
|
15
|
+
"name": "spellcheck",
|
16
|
+
"type": "boolean",
|
17
|
+
"required": false,
|
18
|
+
"description": "Optional field to enable or disable the spellcheck attribute on the textarea."
|
19
|
+
},
|
14
20
|
{
|
15
21
|
"name": "rows",
|
16
22
|
"type": "string",
|
@@ -38,6 +38,7 @@
|
|
38
38
|
}) | indent(2) | trim }}
|
39
39
|
{% endif %}
|
40
40
|
<textarea class="govuk-textarea {{- ' govuk-textarea--error' if params.errorMessage }} {{- ' ' + params.classes if params.classes}}" id="{{ params.id }}" name="{{ params.name }}" rows="{%if params.rows %} {{- params.rows -}} {% else %}5{%endif %}"
|
41
|
+
{%- if (params.spellcheck === false) or (params.spellcheck === true) %} spellcheck="{{ params.spellcheck }}"{% endif %}
|
41
42
|
{%- if describedBy %} aria-describedby="{{ describedBy }}"{% endif %}
|
42
43
|
{%- if params.autocomplete %} autocomplete="{{ params.autocomplete}}"{% endif %}
|
43
44
|
{%- for attribute, value in params.attributes %} {{attribute}}="{{value}}"{% endfor %}>{{ params.value }}</textarea>
|
@@ -13,13 +13,15 @@
|
|
13
13
|
.govuk-warning-text__icon {
|
14
14
|
@include govuk-font($size: false, $weight: bold);
|
15
15
|
|
16
|
+
box-sizing: border-box;
|
17
|
+
|
16
18
|
display: inline-block;
|
17
19
|
|
18
20
|
position: absolute;
|
19
21
|
left: 0;
|
20
22
|
|
21
|
-
min-width:
|
22
|
-
min-height:
|
23
|
+
min-width: 35px;
|
24
|
+
min-height: 35px;
|
23
25
|
margin-top: -7px;
|
24
26
|
|
25
27
|
@include govuk-media-query($from: tablet) {
|
@@ -52,7 +52,7 @@
|
|
52
52
|
/// colour will be returned which meets contrast requirements . If you want to
|
53
53
|
/// use the non-websafe version you can set this to `false` but your should
|
54
54
|
/// ensure that you still meets contrast requirements for accessibility - for
|
55
|
-
/// example,
|
55
|
+
/// example, do not use the non-websafe version for text.
|
56
56
|
///
|
57
57
|
/// @return {Colour} Representation of colour for organisation
|
58
58
|
/// @throw if `$organisation` is not a known organisation
|
@@ -52,7 +52,7 @@ $govuk-print-text-colour: #000000 !default;
|
|
52
52
|
|
53
53
|
/// Secondary text colour
|
54
54
|
///
|
55
|
-
/// Used for 'muted' text
|
55
|
+
/// Used in for example 'muted' text and help text.
|
56
56
|
///
|
57
57
|
/// @type Colour
|
58
58
|
/// @access public
|
@@ -90,7 +90,7 @@ $govuk-error-colour: govuk-colour("red") !default;
|
|
90
90
|
|
91
91
|
/// Border colour
|
92
92
|
///
|
93
|
-
/// Used for borders, separators, rules
|
93
|
+
/// Used in for example borders, separators, rules and keylines.
|
94
94
|
///
|
95
95
|
/// @type Colour
|
96
96
|
/// @access public
|
@@ -81,8 +81,11 @@ $govuk-border-width-form-element: 2px !default;
|
|
81
81
|
///
|
82
82
|
/// @type Number
|
83
83
|
/// @access public
|
84
|
+
/// @deprecated Use $govuk-border-width-form-element instead. There should be no
|
85
|
+
/// difference in thickness for inputs in the error state, in order to
|
86
|
+
/// maintain a distinct focus state.
|
84
87
|
|
85
|
-
$govuk-border-width-form-element-error:
|
88
|
+
$govuk-border-width-form-element-error: 2px !default;
|
86
89
|
|
87
90
|
/// Form group border width when in error state
|
88
91
|
///
|
@@ -1,74 +1,23 @@
|
|
1
1
|
{
|
2
|
-
"
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
"rawSpec": "^3.7.0",
|
10
|
-
"spec": ">=3.7.0 <4.0.0",
|
11
|
-
"type": "range"
|
12
|
-
},
|
13
|
-
"/var/lib/jenkins/workspace/ublishing_components_master-N4FWJIUY4CIFHKGZOAAEVVXODRY3YBORQOPIBBXWX72VUPSGJRRQ"
|
14
|
-
]
|
15
|
-
],
|
16
|
-
"_from": "govuk-frontend@>=3.7.0 <4.0.0",
|
17
|
-
"_hasShrinkwrap": false,
|
18
|
-
"_id": "govuk-frontend@3.7.0",
|
19
|
-
"_inCache": true,
|
20
|
-
"_location": "/govuk-frontend",
|
21
|
-
"_nodeVersion": "12.13.1",
|
22
|
-
"_npmOperationalInternal": {
|
23
|
-
"host": "s3://npm-registry-packages",
|
24
|
-
"tmp": "tmp/govuk-frontend_3.7.0_1591023375568_0.08981992062114386"
|
25
|
-
},
|
26
|
-
"_npmUser": {
|
27
|
-
"name": "govuk-patterns-and-tools",
|
28
|
-
"email": "design-system-deploy+npm@digital.cabinet-office.gov.uk"
|
29
|
-
},
|
30
|
-
"_npmVersion": "6.12.1",
|
31
|
-
"_phantomChildren": {},
|
32
|
-
"_requested": {
|
33
|
-
"raw": "govuk-frontend@^3.7.0",
|
34
|
-
"scope": null,
|
35
|
-
"escapedName": "govuk-frontend",
|
36
|
-
"name": "govuk-frontend",
|
37
|
-
"rawSpec": "^3.7.0",
|
38
|
-
"spec": ">=3.7.0 <4.0.0",
|
39
|
-
"type": "range"
|
2
|
+
"name": "govuk-frontend",
|
3
|
+
"description": "GOV.UK Frontend contains the code you need to start building a user interface for government platforms and services.",
|
4
|
+
"version": "3.8.0",
|
5
|
+
"main": "govuk/all.js",
|
6
|
+
"sass": "govuk/all.scss",
|
7
|
+
"engines": {
|
8
|
+
"node": ">= 4.2.0"
|
40
9
|
},
|
41
|
-
"_requiredBy": [
|
42
|
-
"/"
|
43
|
-
],
|
44
|
-
"_resolved": "https://registry.npmjs.org/govuk-frontend/-/govuk-frontend-3.7.0.tgz",
|
45
|
-
"_shasum": "2eb2130c3c9f7c701c7ecdb300cc91106275a414",
|
46
|
-
"_shrinkwrap": null,
|
47
|
-
"_spec": "govuk-frontend@^3.7.0",
|
48
|
-
"_where": "/var/lib/jenkins/workspace/ublishing_components_master-N4FWJIUY4CIFHKGZOAAEVVXODRY3YBORQOPIBBXWX72VUPSGJRRQ",
|
49
10
|
"author": {
|
50
|
-
"name": "GOV.UK Design System Team",
|
51
|
-
"email": "design-system-developers@digital.cabinet-office.gov.uk"
|
52
|
-
|
11
|
+
"name": "GOV.UK Design System Team (Government Digital Service)",
|
12
|
+
"email": "design-system-developers@digital.cabinet-office.gov.uk"
|
13
|
+
},
|
14
|
+
"repository": {
|
15
|
+
"type": "git",
|
16
|
+
"url": "https://github.com/alphagov/govuk-frontend.git"
|
53
17
|
},
|
54
18
|
"bugs": {
|
55
19
|
"url": "https://github.com/alphagov/govuk-frontend/issues"
|
56
20
|
},
|
57
|
-
"dependencies": {},
|
58
|
-
"description": "GOV.UK Frontend contains the code you need to start building a user interface for government platforms and services.",
|
59
|
-
"devDependencies": {},
|
60
|
-
"directories": {},
|
61
|
-
"dist": {
|
62
|
-
"integrity": "sha512-G3bqoKGGF8YQ18UJH9tTARrwB8i7iPwN1xc8RXwWyx91q0p/Xl10uNywZLkzGWcJDzEz1vwmBTTL3SLDU/KxNg==",
|
63
|
-
"shasum": "2eb2130c3c9f7c701c7ecdb300cc91106275a414",
|
64
|
-
"tarball": "https://registry.npmjs.org/govuk-frontend/-/govuk-frontend-3.7.0.tgz",
|
65
|
-
"fileCount": 277,
|
66
|
-
"unpackedSize": 1031388,
|
67
|
-
"npm-signature": "-----BEGIN PGP SIGNATURE-----\r\nVersion: OpenPGP.js v3.0.4\r\nComment: https://openpgpjs.org\r\n\r\nwsFcBAEBCAAQBQJe1RcQCRA9TVsSAnZWagAAVssP/Rgy/zroRGgis6A7IGKr\nLoXiduk2Zl2dSos0glFBxVxL2P/2Wn4VPjiHKAu/ldH6wLGhgg601IfBH+ZI\nKBGWayz3j8ZmZLltseD8wks6wIpvg28RemifYDKRFmgZI6i31OwdKLoLvYF5\nF8bf8vzlgOGVHg+TweEKW8hJ2RsjHNZ2sI27Hh/qIRNzcmuQ6Tu6Q1vRtphK\nxwc+KC+DYsHIis/k/h+9C6oo7Ja59U/z1n8EohzYTvZU4J6x64FjAGj6GLl2\nopibQSz84XHPHDo2ZZKlWuoDAYlUmyewnDRsEIwGXGYWvecwHnYwcBx8eU+n\nKxrPX1tDEDkuoBIyc1G14kr07CADbU3DahfD8dFHYd7e8zZYIn731GZN6VH5\n9LuJLROKiz4BucOMn9UPYfSccPLUwVV3iRAC2Uo6UQRsnueA6m0ATeGeTmZo\n1C11kuxdkPAp7CdphHxPkl2LZAjXBAGh6UrGf6FD/kChVf6uqV59FoqgHuHS\nkeUbE1u+RdInWfniHX62W0FTQZD8LbNY8DfDCHZlVALzb7C77O4E2puKlLsK\nkRhj8P50is161A0cKbSeUi56/v4jQdaIkfaWstQalWmi6K5+rt5TxZR09JQL\n7O73z3u14cOKvqiV1IPduNt8bOMKDtrKcioGU8lEUIKtVvPJGgB+GfUcNaf9\nPHrk\r\n=KkMF\r\n-----END PGP SIGNATURE-----\r\n"
|
68
|
-
},
|
69
|
-
"engines": {
|
70
|
-
"node": ">= 4.2.0"
|
71
|
-
},
|
72
21
|
"homepage": "https://frontend.design-system.service.gov.uk/",
|
73
22
|
"keywords": [
|
74
23
|
"govuk",
|
@@ -76,21 +25,5 @@
|
|
76
25
|
"design system",
|
77
26
|
"template"
|
78
27
|
],
|
79
|
-
"license": "MIT"
|
80
|
-
"main": "govuk/all.js",
|
81
|
-
"maintainers": [
|
82
|
-
{
|
83
|
-
"name": "govuk-patterns-and-tools",
|
84
|
-
"email": "design-system-pipeline@digital.cabinet-office.gov.uk"
|
85
|
-
}
|
86
|
-
],
|
87
|
-
"name": "govuk-frontend",
|
88
|
-
"optionalDependencies": {},
|
89
|
-
"readme": "ERROR: No README data found!",
|
90
|
-
"repository": {
|
91
|
-
"type": "git",
|
92
|
-
"url": "git+https://github.com/alphagov/govuk-frontend.git"
|
93
|
-
},
|
94
|
-
"sass": "govuk/all.scss",
|
95
|
-
"version": "3.7.0"
|
28
|
+
"license": "MIT"
|
96
29
|
}
|