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.

Files changed (85) hide show
  1. checksums.yaml +4 -4
  2. data/.github/ISSUE_TEMPLATE.md +13 -0
  3. data/.github/pull_request_template.md +14 -1
  4. data/.github/workflows/publish.yaml +76 -0
  5. data/.github/workflows/test.yaml +23 -0
  6. data/.nvmrc +1 -1
  7. data/CHANGELOG.md +39 -0
  8. data/README.md +15 -1
  9. data/lib/assets/javascripts/_modules/search.js +59 -66
  10. data/lib/assets/javascripts/_modules/table-of-contents.js +0 -1
  11. data/lib/assets/javascripts/_vendor/jquery.js +2 -5
  12. data/lib/assets/javascripts/_vendor/lodash.js +5 -3
  13. data/lib/assets/stylesheets/modules/_search.scss +51 -73
  14. data/lib/assets/stylesheets/modules/_technical-documentation.scss +0 -4
  15. data/lib/assets/stylesheets/modules/_toc.scss +0 -3
  16. data/lib/govuk_tech_docs/api_reference/api_reference_renderer.rb +10 -0
  17. data/lib/govuk_tech_docs/api_reference/templates/api_reference_full.html.erb +2 -2
  18. data/lib/govuk_tech_docs/api_reference/templates/operation.html.erb +1 -1
  19. data/lib/govuk_tech_docs/api_reference/templates/parameters.html.erb +1 -1
  20. data/lib/govuk_tech_docs/api_reference/templates/responses.html.erb +1 -1
  21. data/lib/govuk_tech_docs/api_reference/templates/schema.html.erb +2 -2
  22. data/lib/govuk_tech_docs/contribution_banner.rb +8 -2
  23. data/lib/govuk_tech_docs/version.rb +1 -1
  24. data/lib/govuk_tech_docs.rb +3 -1
  25. data/lib/source/layouts/_header.erb +3 -3
  26. data/lib/source/layouts/_search.erb +0 -7
  27. data/lib/source/layouts/core.erb +1 -1
  28. data/lib/source/search/index.html.erb +31 -0
  29. data/node_modules/govuk-frontend/govuk/all.js +272 -75
  30. data/node_modules/govuk-frontend/govuk/components/accordion/_index.scss +275 -98
  31. data/node_modules/govuk-frontend/govuk/components/accordion/accordion.js +169 -65
  32. data/node_modules/govuk-frontend/govuk/components/button/_index.scss +3 -4
  33. data/node_modules/govuk-frontend/govuk/components/button/button.js +2 -2
  34. data/node_modules/govuk-frontend/govuk/components/character-count/character-count.js +3 -3
  35. data/node_modules/govuk-frontend/govuk/components/checkboxes/_index.scss +14 -0
  36. data/node_modules/govuk-frontend/govuk/components/checkboxes/checkboxes.js +8 -10
  37. data/node_modules/govuk-frontend/govuk/components/cookie-banner/_index.scss +0 -2
  38. data/node_modules/govuk-frontend/govuk/components/details/_index.scss +2 -1
  39. data/node_modules/govuk-frontend/govuk/components/details/details.js +2 -2
  40. data/node_modules/govuk-frontend/govuk/components/error-message/_index.scss +1 -0
  41. data/node_modules/govuk-frontend/govuk/components/error-summary/error-summary.js +2 -2
  42. data/node_modules/govuk-frontend/govuk/components/file-upload/_index.scss +1 -0
  43. data/node_modules/govuk-frontend/govuk/components/footer/_index.scss +6 -37
  44. data/node_modules/govuk-frontend/govuk/components/header/_index.scss +10 -4
  45. data/node_modules/govuk-frontend/govuk/components/header/header.js +4 -4
  46. data/node_modules/govuk-frontend/govuk/components/hint/_index.scss +1 -3
  47. data/node_modules/govuk-frontend/govuk/components/input/_index.scss +1 -1
  48. data/node_modules/govuk-frontend/govuk/components/notification-banner/notification-banner.js +499 -2
  49. data/node_modules/govuk-frontend/govuk/components/panel/_index.scss +13 -1
  50. data/node_modules/govuk-frontend/govuk/components/radios/_index.scss +14 -0
  51. data/node_modules/govuk-frontend/govuk/components/radios/radios.js +4 -4
  52. data/node_modules/govuk-frontend/govuk/components/select/_index.scss +1 -1
  53. data/node_modules/govuk-frontend/govuk/components/skip-link/_index.scss +13 -0
  54. data/node_modules/govuk-frontend/govuk/components/skip-link/skip-link.js +1108 -0
  55. data/node_modules/govuk-frontend/govuk/components/summary-list/_index.scss +15 -23
  56. data/node_modules/govuk-frontend/govuk/components/tabs/_index.scss +2 -2
  57. data/node_modules/govuk-frontend/govuk/components/tabs/tabs.js +2 -2
  58. data/node_modules/govuk-frontend/govuk/components/tag/_index.scss +0 -5
  59. data/node_modules/govuk-frontend/govuk/components/textarea/_index.scss +1 -1
  60. data/node_modules/govuk-frontend/govuk/core/_all.scss +0 -1
  61. data/node_modules/govuk-frontend/govuk/core/_global-styles.scss +0 -6
  62. data/node_modules/govuk-frontend/govuk/core/_links.scss +0 -6
  63. data/node_modules/govuk-frontend/govuk/core/_lists.scss +0 -6
  64. data/node_modules/govuk-frontend/govuk/core/_section-break.scss +0 -6
  65. data/node_modules/govuk-frontend/govuk/core/_typography.scss +0 -6
  66. data/node_modules/govuk-frontend/govuk/helpers/_colour.scss +2 -2
  67. data/node_modules/govuk-frontend/govuk/helpers/_spacing.scss +22 -4
  68. data/node_modules/govuk-frontend/govuk/objects/_all.scss +1 -0
  69. data/node_modules/govuk-frontend/govuk/objects/_main-wrapper.scss +15 -30
  70. data/node_modules/govuk-frontend/govuk/{core → objects}/_template.scss +1 -5
  71. data/node_modules/govuk-frontend/govuk/overrides/_all.scss +1 -0
  72. data/node_modules/govuk-frontend/govuk/overrides/_display.scss +0 -6
  73. data/node_modules/govuk-frontend/govuk/overrides/_spacing.scss +0 -6
  74. data/node_modules/govuk-frontend/govuk/overrides/_text-align.scss +14 -0
  75. data/node_modules/govuk-frontend/govuk/overrides/_typography.scss +0 -6
  76. data/node_modules/govuk-frontend/govuk/overrides/_width.scss +0 -6
  77. data/node_modules/govuk-frontend/govuk/settings/_colours-organisations.scss +3 -0
  78. data/node_modules/govuk-frontend/govuk/settings/_measurements.scss +0 -10
  79. data/node_modules/govuk-frontend/govuk/tools/_all.scss +0 -1
  80. data/package-lock.json +6 -6
  81. data/package.json +1 -1
  82. metadata +13 -10
  83. data/.travis.yml +0 -19
  84. data/CONTRIBUTING.md +0 -12
  85. 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: -(govuk-spacing(1));
40
+ margin-top: govuk-spacing(-1);
43
41
  }
44
42
  }
@@ -54,7 +54,7 @@
54
54
  }
55
55
 
56
56
  .govuk-input--error {
57
- border: $govuk-border-width-form-element-error solid $govuk-error-colour;
57
+ border-color: $govuk-error-colour;
58
58
 
59
59
  &:focus {
60
60
  border-color: $govuk-input-border-colour;
@@ -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(6) - $govuk-border-width;
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 || !$module.querySelector('#' + 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.querySelector('#' + $input.getAttribute('aria-controls'));
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;
@@ -40,7 +40,7 @@
40
40
  }
41
41
 
42
42
  .govuk-select--error {
43
- border: $govuk-border-width-form-element-error solid $govuk-error-colour;
43
+ border-color: $govuk-error-colour;
44
44
 
45
45
  &:focus {
46
46
  border-color: $govuk-input-border-colour;
@@ -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
  }