govuk_tech_docs 2.4.2 → 3.1.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of govuk_tech_docs might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/.github/ISSUE_TEMPLATE.md +13 -0
- data/.github/pull_request_template.md +14 -1
- data/.github/workflows/publish.yaml +76 -0
- data/.github/workflows/test.yaml +23 -0
- data/.nvmrc +1 -1
- data/CHANGELOG.md +39 -0
- data/README.md +15 -1
- data/lib/assets/javascripts/_modules/search.js +59 -66
- data/lib/assets/javascripts/_modules/table-of-contents.js +0 -1
- data/lib/assets/javascripts/_vendor/jquery.js +2 -5
- data/lib/assets/javascripts/_vendor/lodash.js +5 -3
- data/lib/assets/stylesheets/modules/_search.scss +51 -73
- data/lib/assets/stylesheets/modules/_technical-documentation.scss +0 -4
- data/lib/assets/stylesheets/modules/_toc.scss +0 -3
- data/lib/govuk_tech_docs/api_reference/api_reference_renderer.rb +10 -0
- data/lib/govuk_tech_docs/api_reference/templates/api_reference_full.html.erb +2 -2
- data/lib/govuk_tech_docs/api_reference/templates/operation.html.erb +1 -1
- data/lib/govuk_tech_docs/api_reference/templates/parameters.html.erb +1 -1
- data/lib/govuk_tech_docs/api_reference/templates/responses.html.erb +1 -1
- data/lib/govuk_tech_docs/api_reference/templates/schema.html.erb +2 -2
- data/lib/govuk_tech_docs/contribution_banner.rb +8 -2
- data/lib/govuk_tech_docs/version.rb +1 -1
- data/lib/govuk_tech_docs.rb +3 -1
- data/lib/source/layouts/_header.erb +3 -3
- data/lib/source/layouts/_search.erb +0 -7
- data/lib/source/layouts/core.erb +1 -1
- data/lib/source/search/index.html.erb +31 -0
- data/node_modules/govuk-frontend/govuk/all.js +272 -75
- data/node_modules/govuk-frontend/govuk/components/accordion/_index.scss +275 -98
- data/node_modules/govuk-frontend/govuk/components/accordion/accordion.js +169 -65
- data/node_modules/govuk-frontend/govuk/components/button/_index.scss +3 -4
- data/node_modules/govuk-frontend/govuk/components/button/button.js +2 -2
- data/node_modules/govuk-frontend/govuk/components/character-count/character-count.js +3 -3
- data/node_modules/govuk-frontend/govuk/components/checkboxes/_index.scss +14 -0
- data/node_modules/govuk-frontend/govuk/components/checkboxes/checkboxes.js +8 -10
- data/node_modules/govuk-frontend/govuk/components/cookie-banner/_index.scss +0 -2
- data/node_modules/govuk-frontend/govuk/components/details/_index.scss +2 -1
- data/node_modules/govuk-frontend/govuk/components/details/details.js +2 -2
- data/node_modules/govuk-frontend/govuk/components/error-message/_index.scss +1 -0
- data/node_modules/govuk-frontend/govuk/components/error-summary/error-summary.js +2 -2
- data/node_modules/govuk-frontend/govuk/components/file-upload/_index.scss +1 -0
- data/node_modules/govuk-frontend/govuk/components/footer/_index.scss +6 -37
- data/node_modules/govuk-frontend/govuk/components/header/_index.scss +10 -4
- data/node_modules/govuk-frontend/govuk/components/header/header.js +4 -4
- data/node_modules/govuk-frontend/govuk/components/hint/_index.scss +1 -3
- data/node_modules/govuk-frontend/govuk/components/input/_index.scss +1 -1
- data/node_modules/govuk-frontend/govuk/components/notification-banner/notification-banner.js +499 -2
- data/node_modules/govuk-frontend/govuk/components/panel/_index.scss +13 -1
- data/node_modules/govuk-frontend/govuk/components/radios/_index.scss +14 -0
- data/node_modules/govuk-frontend/govuk/components/radios/radios.js +4 -4
- data/node_modules/govuk-frontend/govuk/components/select/_index.scss +1 -1
- data/node_modules/govuk-frontend/govuk/components/skip-link/_index.scss +13 -0
- data/node_modules/govuk-frontend/govuk/components/skip-link/skip-link.js +1108 -0
- data/node_modules/govuk-frontend/govuk/components/summary-list/_index.scss +15 -23
- data/node_modules/govuk-frontend/govuk/components/tabs/_index.scss +2 -2
- data/node_modules/govuk-frontend/govuk/components/tabs/tabs.js +2 -2
- data/node_modules/govuk-frontend/govuk/components/tag/_index.scss +0 -5
- data/node_modules/govuk-frontend/govuk/components/textarea/_index.scss +1 -1
- data/node_modules/govuk-frontend/govuk/core/_all.scss +0 -1
- data/node_modules/govuk-frontend/govuk/core/_global-styles.scss +0 -6
- data/node_modules/govuk-frontend/govuk/core/_links.scss +0 -6
- data/node_modules/govuk-frontend/govuk/core/_lists.scss +0 -6
- data/node_modules/govuk-frontend/govuk/core/_section-break.scss +0 -6
- data/node_modules/govuk-frontend/govuk/core/_typography.scss +0 -6
- data/node_modules/govuk-frontend/govuk/helpers/_colour.scss +2 -2
- data/node_modules/govuk-frontend/govuk/helpers/_spacing.scss +22 -4
- data/node_modules/govuk-frontend/govuk/objects/_all.scss +1 -0
- data/node_modules/govuk-frontend/govuk/objects/_main-wrapper.scss +15 -30
- data/node_modules/govuk-frontend/govuk/{core → objects}/_template.scss +1 -5
- data/node_modules/govuk-frontend/govuk/overrides/_all.scss +1 -0
- data/node_modules/govuk-frontend/govuk/overrides/_display.scss +0 -6
- data/node_modules/govuk-frontend/govuk/overrides/_spacing.scss +0 -6
- data/node_modules/govuk-frontend/govuk/overrides/_text-align.scss +14 -0
- data/node_modules/govuk-frontend/govuk/overrides/_typography.scss +0 -6
- data/node_modules/govuk-frontend/govuk/overrides/_width.scss +0 -6
- data/node_modules/govuk-frontend/govuk/settings/_colours-organisations.scss +3 -0
- data/node_modules/govuk-frontend/govuk/settings/_measurements.scss +0 -10
- data/node_modules/govuk-frontend/govuk/tools/_all.scss +0 -1
- data/package-lock.json +6 -6
- data/package.json +1 -1
- metadata +13 -10
- data/.travis.yml +0 -19
- data/CONTRIBUTING.md +0 -12
- data/node_modules/govuk-frontend/govuk/tools/_iff.scss +0 -17
@@ -1,7 +1,7 @@
|
|
1
1
|
(function (global, factory) {
|
2
2
|
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
|
3
|
-
typeof define === 'function' && define.amd ? define('GOVUKFrontend', factory) :
|
4
|
-
(global.GOVUKFrontend = factory());
|
3
|
+
typeof define === 'function' && define.amd ? define('GOVUKFrontend.Header', factory) :
|
4
|
+
(global.GOVUKFrontend = global.GOVUKFrontend || {}, global.GOVUKFrontend.Header = factory());
|
5
5
|
}(this, (function () { 'use strict';
|
6
6
|
|
7
7
|
(function(undefined) {
|
@@ -1033,7 +1033,7 @@ Header.prototype.init = function () {
|
|
1033
1033
|
return
|
1034
1034
|
}
|
1035
1035
|
|
1036
|
-
this.syncState(this.$menu.classList.contains('govuk-header__navigation--open'));
|
1036
|
+
this.syncState(this.$menu.classList.contains('govuk-header__navigation-list--open'));
|
1037
1037
|
this.$menuButton.addEventListener('click', this.handleMenuButtonClick.bind(this));
|
1038
1038
|
};
|
1039
1039
|
|
@@ -1057,7 +1057,7 @@ Header.prototype.syncState = function (isVisible) {
|
|
1057
1057
|
* sync the accessibility state and menu button state
|
1058
1058
|
*/
|
1059
1059
|
Header.prototype.handleMenuButtonClick = function () {
|
1060
|
-
var isVisible = this.$menu.classList.toggle('govuk-header__navigation--open');
|
1060
|
+
var isVisible = this.$menu.classList.toggle('govuk-header__navigation-list--open');
|
1061
1061
|
this.syncState(isVisible);
|
1062
1062
|
};
|
1063
1063
|
|
@@ -2,8 +2,6 @@
|
|
2
2
|
.govuk-hint {
|
3
3
|
@include govuk-font($size: 19);
|
4
4
|
|
5
|
-
display: block;
|
6
|
-
|
7
5
|
margin-bottom: govuk-spacing(3);
|
8
6
|
|
9
7
|
color: $govuk-secondary-text-colour;
|
@@ -39,6 +37,6 @@
|
|
39
37
|
|
40
38
|
// Reduces visual spacing of legend when there is a hint
|
41
39
|
.govuk-fieldset__legend + .govuk-hint {
|
42
|
-
margin-top:
|
40
|
+
margin-top: govuk-spacing(-1);
|
43
41
|
}
|
44
42
|
}
|
data/node_modules/govuk-frontend/govuk/components/notification-banner/notification-banner.js
CHANGED
@@ -1,9 +1,506 @@
|
|
1
1
|
(function (global, factory) {
|
2
2
|
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
|
3
|
-
typeof define === 'function' && define.amd ? define('GOVUKFrontend', factory) :
|
4
|
-
(global.GOVUKFrontend = factory());
|
3
|
+
typeof define === 'function' && define.amd ? define('GOVUKFrontend.NotificationBanner', factory) :
|
4
|
+
(global.GOVUKFrontend = global.GOVUKFrontend || {}, global.GOVUKFrontend.NotificationBanner = factory());
|
5
5
|
}(this, (function () { 'use strict';
|
6
6
|
|
7
|
+
(function(undefined) {
|
8
|
+
|
9
|
+
// Detection from https://github.com/Financial-Times/polyfill-service/blob/master/packages/polyfill-library/polyfills/Window/detect.js
|
10
|
+
var detect = ('Window' in this);
|
11
|
+
|
12
|
+
if (detect) return
|
13
|
+
|
14
|
+
// Polyfill from https://cdn.polyfill.io/v2/polyfill.js?features=Window&flags=always
|
15
|
+
if ((typeof WorkerGlobalScope === "undefined") && (typeof importScripts !== "function")) {
|
16
|
+
(function (global) {
|
17
|
+
if (global.constructor) {
|
18
|
+
global.Window = global.constructor;
|
19
|
+
} else {
|
20
|
+
(global.Window = global.constructor = new Function('return function Window() {}')()).prototype = this;
|
21
|
+
}
|
22
|
+
}(this));
|
23
|
+
}
|
24
|
+
|
25
|
+
})
|
26
|
+
.call('object' === typeof window && window || 'object' === typeof self && self || 'object' === typeof global && global || {});
|
27
|
+
|
28
|
+
(function(undefined) {
|
29
|
+
|
30
|
+
// Detection from https://github.com/Financial-Times/polyfill-service/blob/master/packages/polyfill-library/polyfills/Document/detect.js
|
31
|
+
var detect = ("Document" in this);
|
32
|
+
|
33
|
+
if (detect) return
|
34
|
+
|
35
|
+
// Polyfill from https://cdn.polyfill.io/v2/polyfill.js?features=Document&flags=always
|
36
|
+
if ((typeof WorkerGlobalScope === "undefined") && (typeof importScripts !== "function")) {
|
37
|
+
|
38
|
+
if (this.HTMLDocument) { // IE8
|
39
|
+
|
40
|
+
// HTMLDocument is an extension of Document. If the browser has HTMLDocument but not Document, the former will suffice as an alias for the latter.
|
41
|
+
this.Document = this.HTMLDocument;
|
42
|
+
|
43
|
+
} else {
|
44
|
+
|
45
|
+
// Create an empty function to act as the missing constructor for the document object, attach the document object as its prototype. The function needs to be anonymous else it is hoisted and causes the feature detect to prematurely pass, preventing the assignments below being made.
|
46
|
+
this.Document = this.HTMLDocument = document.constructor = (new Function('return function Document() {}')());
|
47
|
+
this.Document.prototype = document;
|
48
|
+
}
|
49
|
+
}
|
50
|
+
|
51
|
+
|
52
|
+
})
|
53
|
+
.call('object' === typeof window && window || 'object' === typeof self && self || 'object' === typeof global && global || {});
|
54
|
+
|
55
|
+
(function(undefined) {
|
56
|
+
|
57
|
+
// Detection from https://github.com/Financial-Times/polyfill-service/blob/master/packages/polyfill-library/polyfills/Element/detect.js
|
58
|
+
var detect = ('Element' in this && 'HTMLElement' in this);
|
59
|
+
|
60
|
+
if (detect) return
|
61
|
+
|
62
|
+
// Polyfill from https://cdn.polyfill.io/v2/polyfill.js?features=Element&flags=always
|
63
|
+
(function () {
|
64
|
+
|
65
|
+
// IE8
|
66
|
+
if (window.Element && !window.HTMLElement) {
|
67
|
+
window.HTMLElement = window.Element;
|
68
|
+
return;
|
69
|
+
}
|
70
|
+
|
71
|
+
// create Element constructor
|
72
|
+
window.Element = window.HTMLElement = new Function('return function Element() {}')();
|
73
|
+
|
74
|
+
// generate sandboxed iframe
|
75
|
+
var vbody = document.appendChild(document.createElement('body'));
|
76
|
+
var frame = vbody.appendChild(document.createElement('iframe'));
|
77
|
+
|
78
|
+
// use sandboxed iframe to replicate Element functionality
|
79
|
+
var frameDocument = frame.contentWindow.document;
|
80
|
+
var prototype = Element.prototype = frameDocument.appendChild(frameDocument.createElement('*'));
|
81
|
+
var cache = {};
|
82
|
+
|
83
|
+
// polyfill Element.prototype on an element
|
84
|
+
var shiv = function (element, deep) {
|
85
|
+
var
|
86
|
+
childNodes = element.childNodes || [],
|
87
|
+
index = -1,
|
88
|
+
key, value, childNode;
|
89
|
+
|
90
|
+
if (element.nodeType === 1 && element.constructor !== Element) {
|
91
|
+
element.constructor = Element;
|
92
|
+
|
93
|
+
for (key in cache) {
|
94
|
+
value = cache[key];
|
95
|
+
element[key] = value;
|
96
|
+
}
|
97
|
+
}
|
98
|
+
|
99
|
+
while (childNode = deep && childNodes[++index]) {
|
100
|
+
shiv(childNode, deep);
|
101
|
+
}
|
102
|
+
|
103
|
+
return element;
|
104
|
+
};
|
105
|
+
|
106
|
+
var elements = document.getElementsByTagName('*');
|
107
|
+
var nativeCreateElement = document.createElement;
|
108
|
+
var interval;
|
109
|
+
var loopLimit = 100;
|
110
|
+
|
111
|
+
prototype.attachEvent('onpropertychange', function (event) {
|
112
|
+
var
|
113
|
+
propertyName = event.propertyName,
|
114
|
+
nonValue = !cache.hasOwnProperty(propertyName),
|
115
|
+
newValue = prototype[propertyName],
|
116
|
+
oldValue = cache[propertyName],
|
117
|
+
index = -1,
|
118
|
+
element;
|
119
|
+
|
120
|
+
while (element = elements[++index]) {
|
121
|
+
if (element.nodeType === 1) {
|
122
|
+
if (nonValue || element[propertyName] === oldValue) {
|
123
|
+
element[propertyName] = newValue;
|
124
|
+
}
|
125
|
+
}
|
126
|
+
}
|
127
|
+
|
128
|
+
cache[propertyName] = newValue;
|
129
|
+
});
|
130
|
+
|
131
|
+
prototype.constructor = Element;
|
132
|
+
|
133
|
+
if (!prototype.hasAttribute) {
|
134
|
+
// <Element>.hasAttribute
|
135
|
+
prototype.hasAttribute = function hasAttribute(name) {
|
136
|
+
return this.getAttribute(name) !== null;
|
137
|
+
};
|
138
|
+
}
|
139
|
+
|
140
|
+
// Apply Element prototype to the pre-existing DOM as soon as the body element appears.
|
141
|
+
function bodyCheck() {
|
142
|
+
if (!(loopLimit--)) clearTimeout(interval);
|
143
|
+
if (document.body && !document.body.prototype && /(complete|interactive)/.test(document.readyState)) {
|
144
|
+
shiv(document, true);
|
145
|
+
if (interval && document.body.prototype) clearTimeout(interval);
|
146
|
+
return (!!document.body.prototype);
|
147
|
+
}
|
148
|
+
return false;
|
149
|
+
}
|
150
|
+
if (!bodyCheck()) {
|
151
|
+
document.onreadystatechange = bodyCheck;
|
152
|
+
interval = setInterval(bodyCheck, 25);
|
153
|
+
}
|
154
|
+
|
155
|
+
// Apply to any new elements created after load
|
156
|
+
document.createElement = function createElement(nodeName) {
|
157
|
+
var element = nativeCreateElement(String(nodeName).toLowerCase());
|
158
|
+
return shiv(element);
|
159
|
+
};
|
160
|
+
|
161
|
+
// remove sandboxed iframe
|
162
|
+
document.removeChild(vbody);
|
163
|
+
}());
|
164
|
+
|
165
|
+
})
|
166
|
+
.call('object' === typeof window && window || 'object' === typeof self && self || 'object' === typeof global && global || {});
|
167
|
+
|
168
|
+
(function(undefined) {
|
169
|
+
|
170
|
+
// Detection from https://github.com/Financial-Times/polyfill-service/blob/master/packages/polyfill-library/polyfills/Object/defineProperty/detect.js
|
171
|
+
var detect = (
|
172
|
+
// In IE8, defineProperty could only act on DOM elements, so full support
|
173
|
+
// for the feature requires the ability to set a property on an arbitrary object
|
174
|
+
'defineProperty' in Object && (function() {
|
175
|
+
try {
|
176
|
+
var a = {};
|
177
|
+
Object.defineProperty(a, 'test', {value:42});
|
178
|
+
return true;
|
179
|
+
} catch(e) {
|
180
|
+
return false
|
181
|
+
}
|
182
|
+
}())
|
183
|
+
);
|
184
|
+
|
185
|
+
if (detect) return
|
186
|
+
|
187
|
+
// Polyfill from https://cdn.polyfill.io/v2/polyfill.js?features=Object.defineProperty&flags=always
|
188
|
+
(function (nativeDefineProperty) {
|
189
|
+
|
190
|
+
var supportsAccessors = Object.prototype.hasOwnProperty('__defineGetter__');
|
191
|
+
var ERR_ACCESSORS_NOT_SUPPORTED = 'Getters & setters cannot be defined on this javascript engine';
|
192
|
+
var ERR_VALUE_ACCESSORS = 'A property cannot both have accessors and be writable or have a value';
|
193
|
+
|
194
|
+
Object.defineProperty = function defineProperty(object, property, descriptor) {
|
195
|
+
|
196
|
+
// Where native support exists, assume it
|
197
|
+
if (nativeDefineProperty && (object === window || object === document || object === Element.prototype || object instanceof Element)) {
|
198
|
+
return nativeDefineProperty(object, property, descriptor);
|
199
|
+
}
|
200
|
+
|
201
|
+
if (object === null || !(object instanceof Object || typeof object === 'object')) {
|
202
|
+
throw new TypeError('Object.defineProperty called on non-object');
|
203
|
+
}
|
204
|
+
|
205
|
+
if (!(descriptor instanceof Object)) {
|
206
|
+
throw new TypeError('Property description must be an object');
|
207
|
+
}
|
208
|
+
|
209
|
+
var propertyString = String(property);
|
210
|
+
var hasValueOrWritable = 'value' in descriptor || 'writable' in descriptor;
|
211
|
+
var getterType = 'get' in descriptor && typeof descriptor.get;
|
212
|
+
var setterType = 'set' in descriptor && typeof descriptor.set;
|
213
|
+
|
214
|
+
// handle descriptor.get
|
215
|
+
if (getterType) {
|
216
|
+
if (getterType !== 'function') {
|
217
|
+
throw new TypeError('Getter must be a function');
|
218
|
+
}
|
219
|
+
if (!supportsAccessors) {
|
220
|
+
throw new TypeError(ERR_ACCESSORS_NOT_SUPPORTED);
|
221
|
+
}
|
222
|
+
if (hasValueOrWritable) {
|
223
|
+
throw new TypeError(ERR_VALUE_ACCESSORS);
|
224
|
+
}
|
225
|
+
Object.__defineGetter__.call(object, propertyString, descriptor.get);
|
226
|
+
} else {
|
227
|
+
object[propertyString] = descriptor.value;
|
228
|
+
}
|
229
|
+
|
230
|
+
// handle descriptor.set
|
231
|
+
if (setterType) {
|
232
|
+
if (setterType !== 'function') {
|
233
|
+
throw new TypeError('Setter must be a function');
|
234
|
+
}
|
235
|
+
if (!supportsAccessors) {
|
236
|
+
throw new TypeError(ERR_ACCESSORS_NOT_SUPPORTED);
|
237
|
+
}
|
238
|
+
if (hasValueOrWritable) {
|
239
|
+
throw new TypeError(ERR_VALUE_ACCESSORS);
|
240
|
+
}
|
241
|
+
Object.__defineSetter__.call(object, propertyString, descriptor.set);
|
242
|
+
}
|
243
|
+
|
244
|
+
// OK to define value unconditionally - if a getter has been specified as well, an error would be thrown above
|
245
|
+
if ('value' in descriptor) {
|
246
|
+
object[propertyString] = descriptor.value;
|
247
|
+
}
|
248
|
+
|
249
|
+
return object;
|
250
|
+
};
|
251
|
+
}(Object.defineProperty));
|
252
|
+
})
|
253
|
+
.call('object' === typeof window && window || 'object' === typeof self && self || 'object' === typeof global && global || {});
|
254
|
+
|
255
|
+
(function(undefined) {
|
256
|
+
|
257
|
+
// Detection from https://github.com/Financial-Times/polyfill-service/blob/master/packages/polyfill-library/polyfills/Event/detect.js
|
258
|
+
var detect = (
|
259
|
+
(function(global) {
|
260
|
+
|
261
|
+
if (!('Event' in global)) return false;
|
262
|
+
if (typeof global.Event === 'function') return true;
|
263
|
+
|
264
|
+
try {
|
265
|
+
|
266
|
+
// In IE 9-11, the Event object exists but cannot be instantiated
|
267
|
+
new Event('click');
|
268
|
+
return true;
|
269
|
+
} catch(e) {
|
270
|
+
return false;
|
271
|
+
}
|
272
|
+
}(this))
|
273
|
+
);
|
274
|
+
|
275
|
+
if (detect) return
|
276
|
+
|
277
|
+
// Polyfill from https://cdn.polyfill.io/v2/polyfill.js?features=Event&flags=always
|
278
|
+
(function () {
|
279
|
+
var unlistenableWindowEvents = {
|
280
|
+
click: 1,
|
281
|
+
dblclick: 1,
|
282
|
+
keyup: 1,
|
283
|
+
keypress: 1,
|
284
|
+
keydown: 1,
|
285
|
+
mousedown: 1,
|
286
|
+
mouseup: 1,
|
287
|
+
mousemove: 1,
|
288
|
+
mouseover: 1,
|
289
|
+
mouseenter: 1,
|
290
|
+
mouseleave: 1,
|
291
|
+
mouseout: 1,
|
292
|
+
storage: 1,
|
293
|
+
storagecommit: 1,
|
294
|
+
textinput: 1
|
295
|
+
};
|
296
|
+
|
297
|
+
// This polyfill depends on availability of `document` so will not run in a worker
|
298
|
+
// However, we asssume there are no browsers with worker support that lack proper
|
299
|
+
// support for `Event` within the worker
|
300
|
+
if (typeof document === 'undefined' || typeof window === 'undefined') return;
|
301
|
+
|
302
|
+
function indexOf(array, element) {
|
303
|
+
var
|
304
|
+
index = -1,
|
305
|
+
length = array.length;
|
306
|
+
|
307
|
+
while (++index < length) {
|
308
|
+
if (index in array && array[index] === element) {
|
309
|
+
return index;
|
310
|
+
}
|
311
|
+
}
|
312
|
+
|
313
|
+
return -1;
|
314
|
+
}
|
315
|
+
|
316
|
+
var existingProto = (window.Event && window.Event.prototype) || null;
|
317
|
+
window.Event = Window.prototype.Event = function Event(type, eventInitDict) {
|
318
|
+
if (!type) {
|
319
|
+
throw new Error('Not enough arguments');
|
320
|
+
}
|
321
|
+
|
322
|
+
var event;
|
323
|
+
// Shortcut if browser supports createEvent
|
324
|
+
if ('createEvent' in document) {
|
325
|
+
event = document.createEvent('Event');
|
326
|
+
var bubbles = eventInitDict && eventInitDict.bubbles !== undefined ? eventInitDict.bubbles : false;
|
327
|
+
var cancelable = eventInitDict && eventInitDict.cancelable !== undefined ? eventInitDict.cancelable : false;
|
328
|
+
|
329
|
+
event.initEvent(type, bubbles, cancelable);
|
330
|
+
|
331
|
+
return event;
|
332
|
+
}
|
333
|
+
|
334
|
+
event = document.createEventObject();
|
335
|
+
|
336
|
+
event.type = type;
|
337
|
+
event.bubbles = eventInitDict && eventInitDict.bubbles !== undefined ? eventInitDict.bubbles : false;
|
338
|
+
event.cancelable = eventInitDict && eventInitDict.cancelable !== undefined ? eventInitDict.cancelable : false;
|
339
|
+
|
340
|
+
return event;
|
341
|
+
};
|
342
|
+
if (existingProto) {
|
343
|
+
Object.defineProperty(window.Event, 'prototype', {
|
344
|
+
configurable: false,
|
345
|
+
enumerable: false,
|
346
|
+
writable: true,
|
347
|
+
value: existingProto
|
348
|
+
});
|
349
|
+
}
|
350
|
+
|
351
|
+
if (!('createEvent' in document)) {
|
352
|
+
window.addEventListener = Window.prototype.addEventListener = Document.prototype.addEventListener = Element.prototype.addEventListener = function addEventListener() {
|
353
|
+
var
|
354
|
+
element = this,
|
355
|
+
type = arguments[0],
|
356
|
+
listener = arguments[1];
|
357
|
+
|
358
|
+
if (element === window && type in unlistenableWindowEvents) {
|
359
|
+
throw new Error('In IE8 the event: ' + type + ' is not available on the window object. Please see https://github.com/Financial-Times/polyfill-service/issues/317 for more information.');
|
360
|
+
}
|
361
|
+
|
362
|
+
if (!element._events) {
|
363
|
+
element._events = {};
|
364
|
+
}
|
365
|
+
|
366
|
+
if (!element._events[type]) {
|
367
|
+
element._events[type] = function (event) {
|
368
|
+
var
|
369
|
+
list = element._events[event.type].list,
|
370
|
+
events = list.slice(),
|
371
|
+
index = -1,
|
372
|
+
length = events.length,
|
373
|
+
eventElement;
|
374
|
+
|
375
|
+
event.preventDefault = function preventDefault() {
|
376
|
+
if (event.cancelable !== false) {
|
377
|
+
event.returnValue = false;
|
378
|
+
}
|
379
|
+
};
|
380
|
+
|
381
|
+
event.stopPropagation = function stopPropagation() {
|
382
|
+
event.cancelBubble = true;
|
383
|
+
};
|
384
|
+
|
385
|
+
event.stopImmediatePropagation = function stopImmediatePropagation() {
|
386
|
+
event.cancelBubble = true;
|
387
|
+
event.cancelImmediate = true;
|
388
|
+
};
|
389
|
+
|
390
|
+
event.currentTarget = element;
|
391
|
+
event.relatedTarget = event.fromElement || null;
|
392
|
+
event.target = event.target || event.srcElement || element;
|
393
|
+
event.timeStamp = new Date().getTime();
|
394
|
+
|
395
|
+
if (event.clientX) {
|
396
|
+
event.pageX = event.clientX + document.documentElement.scrollLeft;
|
397
|
+
event.pageY = event.clientY + document.documentElement.scrollTop;
|
398
|
+
}
|
399
|
+
|
400
|
+
while (++index < length && !event.cancelImmediate) {
|
401
|
+
if (index in events) {
|
402
|
+
eventElement = events[index];
|
403
|
+
|
404
|
+
if (indexOf(list, eventElement) !== -1 && typeof eventElement === 'function') {
|
405
|
+
eventElement.call(element, event);
|
406
|
+
}
|
407
|
+
}
|
408
|
+
}
|
409
|
+
};
|
410
|
+
|
411
|
+
element._events[type].list = [];
|
412
|
+
|
413
|
+
if (element.attachEvent) {
|
414
|
+
element.attachEvent('on' + type, element._events[type]);
|
415
|
+
}
|
416
|
+
}
|
417
|
+
|
418
|
+
element._events[type].list.push(listener);
|
419
|
+
};
|
420
|
+
|
421
|
+
window.removeEventListener = Window.prototype.removeEventListener = Document.prototype.removeEventListener = Element.prototype.removeEventListener = function removeEventListener() {
|
422
|
+
var
|
423
|
+
element = this,
|
424
|
+
type = arguments[0],
|
425
|
+
listener = arguments[1],
|
426
|
+
index;
|
427
|
+
|
428
|
+
if (element._events && element._events[type] && element._events[type].list) {
|
429
|
+
index = indexOf(element._events[type].list, listener);
|
430
|
+
|
431
|
+
if (index !== -1) {
|
432
|
+
element._events[type].list.splice(index, 1);
|
433
|
+
|
434
|
+
if (!element._events[type].list.length) {
|
435
|
+
if (element.detachEvent) {
|
436
|
+
element.detachEvent('on' + type, element._events[type]);
|
437
|
+
}
|
438
|
+
delete element._events[type];
|
439
|
+
}
|
440
|
+
}
|
441
|
+
}
|
442
|
+
};
|
443
|
+
|
444
|
+
window.dispatchEvent = Window.prototype.dispatchEvent = Document.prototype.dispatchEvent = Element.prototype.dispatchEvent = function dispatchEvent(event) {
|
445
|
+
if (!arguments.length) {
|
446
|
+
throw new Error('Not enough arguments');
|
447
|
+
}
|
448
|
+
|
449
|
+
if (!event || typeof event.type !== 'string') {
|
450
|
+
throw new Error('DOM Events Exception 0');
|
451
|
+
}
|
452
|
+
|
453
|
+
var element = this, type = event.type;
|
454
|
+
|
455
|
+
try {
|
456
|
+
if (!event.bubbles) {
|
457
|
+
event.cancelBubble = true;
|
458
|
+
|
459
|
+
var cancelBubbleEvent = function (event) {
|
460
|
+
event.cancelBubble = true;
|
461
|
+
|
462
|
+
(element || window).detachEvent('on' + type, cancelBubbleEvent);
|
463
|
+
};
|
464
|
+
|
465
|
+
this.attachEvent('on' + type, cancelBubbleEvent);
|
466
|
+
}
|
467
|
+
|
468
|
+
this.fireEvent('on' + type, event);
|
469
|
+
} catch (error) {
|
470
|
+
event.target = element;
|
471
|
+
|
472
|
+
do {
|
473
|
+
event.currentTarget = element;
|
474
|
+
|
475
|
+
if ('_events' in element && typeof element._events[type] === 'function') {
|
476
|
+
element._events[type].call(element, event);
|
477
|
+
}
|
478
|
+
|
479
|
+
if (typeof element['on' + type] === 'function') {
|
480
|
+
element['on' + type].call(element, event);
|
481
|
+
}
|
482
|
+
|
483
|
+
element = element.nodeType === 9 ? element.parentWindow : element.parentNode;
|
484
|
+
} while (element && !event.cancelBubble);
|
485
|
+
}
|
486
|
+
|
487
|
+
return true;
|
488
|
+
};
|
489
|
+
|
490
|
+
// Add the DOMContentLoaded Event
|
491
|
+
document.attachEvent('onreadystatechange', function() {
|
492
|
+
if (document.readyState === 'complete') {
|
493
|
+
document.dispatchEvent(new Event('DOMContentLoaded', {
|
494
|
+
bubbles: true
|
495
|
+
}));
|
496
|
+
}
|
497
|
+
});
|
498
|
+
}
|
499
|
+
}());
|
500
|
+
|
501
|
+
})
|
502
|
+
.call('object' === typeof window && window || 'object' === typeof self && self || 'object' === typeof global && global || {});
|
503
|
+
|
7
504
|
function NotificationBanner ($module) {
|
8
505
|
this.$module = $module;
|
9
506
|
}
|
@@ -12,7 +12,19 @@
|
|
12
12
|
text-align: center;
|
13
13
|
|
14
14
|
@include govuk-media-query($until: tablet) {
|
15
|
-
padding: govuk-spacing(
|
15
|
+
padding: govuk-spacing(3) - $govuk-border-width;
|
16
|
+
|
17
|
+
// This is an if-all-else-fails attempt to stop long words from overflowing the container
|
18
|
+
// on very narrow viewports by forcing them to break and wrap instead. This
|
19
|
+
// overflowing is more likely to happen when user increases text size on a mobile eg. using
|
20
|
+
// iOS Safari text resize controls.
|
21
|
+
//
|
22
|
+
// The overflowing is a particular problem with the panel component since it uses white
|
23
|
+
// text: when the text overflows the container, it is invisible on the white (page)
|
24
|
+
// background. When the text in our other components overflow, the user might have to scroll
|
25
|
+
// horizontally to view it but the the text remains legible.
|
26
|
+
overflow-wrap: break-word;
|
27
|
+
word-wrap: break-word; // Support IE (autoprefixer doesn't add this as it's not a prefix)
|
16
28
|
}
|
17
29
|
}
|
18
30
|
|
@@ -121,6 +121,20 @@
|
|
121
121
|
// Focused state
|
122
122
|
.govuk-radios__input:focus + .govuk-radios__label:before {
|
123
123
|
border-width: 4px;
|
124
|
+
|
125
|
+
// When colours are overridden, the yellow box-shadow becomes invisible
|
126
|
+
// which means the focus state is less obvious. By adding a transparent
|
127
|
+
// outline, which becomes solid (text-coloured) in that context, we ensure
|
128
|
+
// the focus remains clearly visible.
|
129
|
+
outline: $govuk-focus-width solid transparent;
|
130
|
+
outline-offset: 1px;
|
131
|
+
|
132
|
+
// When in an explicit forced-color mode, we can use the Highlight system
|
133
|
+
// color for the outline to better match focus states of native controls
|
134
|
+
@media screen and (forced-colors: active), (-ms-high-contrast: active) {
|
135
|
+
outline-color: Highlight;
|
136
|
+
}
|
137
|
+
|
124
138
|
box-shadow: 0 0 0 $govuk-radios-focus-width $govuk-focus-colour;
|
125
139
|
}
|
126
140
|
|
@@ -1,7 +1,7 @@
|
|
1
1
|
(function (global, factory) {
|
2
2
|
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
|
3
|
-
typeof define === 'function' && define.amd ? define('GOVUKFrontend', factory) :
|
4
|
-
(global.GOVUKFrontend = factory());
|
3
|
+
typeof define === 'function' && define.amd ? define('GOVUKFrontend.Radios', factory) :
|
4
|
+
(global.GOVUKFrontend = global.GOVUKFrontend || {}, global.GOVUKFrontend.Radios = factory());
|
5
5
|
}(this, (function () { 'use strict';
|
6
6
|
|
7
7
|
(function(undefined) {
|
@@ -1056,7 +1056,7 @@ Radios.prototype.init = function () {
|
|
1056
1056
|
|
1057
1057
|
// Skip radios without data-aria-controls attributes, or where the
|
1058
1058
|
// target element does not exist.
|
1059
|
-
if (!target ||
|
1059
|
+
if (!target || !document.getElementById(target)) {
|
1060
1060
|
return
|
1061
1061
|
}
|
1062
1062
|
|
@@ -1101,7 +1101,7 @@ Radios.prototype.syncAllConditionalReveals = function () {
|
|
1101
1101
|
* @param {HTMLInputElement} $input Radio input
|
1102
1102
|
*/
|
1103
1103
|
Radios.prototype.syncConditionalRevealWithInputState = function ($input) {
|
1104
|
-
var $target = document.
|
1104
|
+
var $target = document.getElementById($input.getAttribute('aria-controls'));
|
1105
1105
|
|
1106
1106
|
if ($target && $target.classList.contains('govuk-radios__conditional')) {
|
1107
1107
|
var inputIsChecked = $input.checked;
|
@@ -33,4 +33,17 @@
|
|
33
33
|
}
|
34
34
|
}
|
35
35
|
}
|
36
|
+
|
37
|
+
.govuk-skip-link-focused-element {
|
38
|
+
&:focus {
|
39
|
+
// Remove the native visible focus indicator when the element is programmatically focused.
|
40
|
+
//
|
41
|
+
// We set the focus on the linked element (this is usually the <main> element) when the skip
|
42
|
+
// link is activated to improve screen reader announcements. However, we remove the visible
|
43
|
+
// focus indicator from the linked element because the user cannot interact with it.
|
44
|
+
//
|
45
|
+
// A related discussion: https://github.com/w3c/wcag/issues/1001
|
46
|
+
outline: none;
|
47
|
+
}
|
48
|
+
}
|
36
49
|
}
|