-
Notifications
You must be signed in to change notification settings - Fork 237
/
.htmlvalidate.js
94 lines (82 loc) · 3.21 KB
/
.htmlvalidate.js
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
const { defineConfig } = require('html-validate')
module.exports = defineConfig({
extends: ['html-validate:recommended'],
rules: {
// Allow components to set boolean attributes with empty values
// e.g. using `params.attributes` to set <fieldset hidden="">
'attribute-boolean-style': 'off',
// Allow for multiple buttons in the same form to have the same name
// (as in the cookie banner examples)
'form-dup-name': [
'error',
{ shared: ['radio', 'checkbox', 'submit', 'button'] }
],
// Flags most of our page titles because we append "- GOV.UK Design System"
// to all of them.
'long-title': 'off',
// Allow for conditional comments (used in header for fallback png)
'no-conditional-comment': 'off',
// Allow inline styles for testing purposes
'no-inline-style': 'off',
// Allow implicit type="button" (without attribute) until released:
// https://github.com/alphagov/govuk-frontend/pull/4113
'no-implicit-button-type': 'off',
// Allow for explicit roles on regions that have implict roles
// We do this to better support AT with older versions of IE that
// have partial support for HTML5 semantic elements
'no-redundant-role': 'off',
// More hassle than it's worth 👾
'no-trailing-whitespace': 'off',
// Allow use of roles where there are native elements that would give
// us that role automatically, e.g. <section> instead of
// <div role="region">
//
// This is mainly needed for links styled as buttons, but we do this
// in the cookie banner and notification banner too
'prefer-native-element': 'off',
// HTML Validate is opinionated about IDs beginning with a letter and
// only containing letters, numbers, underscores and dashes – which is
// more restrictive than the spec allows.
//
// Relax the rule to allow anything that is valid according to the
// spec.
'valid-id': ['error', { relaxed: true }],
// Flags our back to top anchor (views/layouts/_generic.njk#L27) for not
// having descriptive text. Automated accessibility testing doesn't flag,
// so turning this off until we review our navigation.
'wcag/h30': 'off',
// Flags the form in views/layouts/layout-example.njk#L35 when the example
// code does not have a submit button. This is because we wrap our
// examples in <form> elements to disable browser validation:
// https://github.com/alphagov/govuk-design-system/pull/522
'wcag/h32': 'off'
},
elements: [
'html5',
{
// Allow textarea autocomplete attribute to be street-address
// (html-validate only allows on/off in default rules)
textarea: {
attributes: {
autocomplete: { enum: ['on', 'off', 'street-address'] }
}
},
// Allow buttons to omit the type attribute (defaults to 'submit')
button: {
attributes: {
type: { required: false }
}
},
// We added a summary to fix an accessibility issue, though we could
// probably revisit.
// https://github.com/alphagov/govuk-design-system/pull/301
table: {
attributes: {
summary: {
deprecated: false
}
}
}
}
]
})