desy-html 13.0.1 → 13.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/docs/ds/_ds.example.checkboxes.njk +1 -1
- package/docs/ds/_ds.example.date-input.njk +3 -3
- package/docs/ds/_ds.example.file-upload.njk +1 -1
- package/docs/ds/_ds.example.input-group.njk +1 -1
- package/docs/ds/_ds.example.input.njk +5 -5
- package/docs/ds/_ds.example.radios.njk +1 -1
- package/docs/ds/_ds.example.searchbar.njk +1 -1
- package/docs/ds/_ds.example.select.njk +5 -5
- package/docs/ds/_ds.example.textarea.njk +7 -7
- package/docs/index.html +4 -0
- package/package.json +1 -1
- package/src/js/aria/MenuNavigation.js +12 -3
- package/src/templates/components/character-count/_examples.character-count.njk +3 -15
- package/src/templates/components/checkboxes/_examples.checkboxes.njk +67 -86
- package/src/templates/components/date-input/_examples.date-input.njk +15 -15
- package/src/templates/components/datepicker/_examples.datepicker.njk +7 -6
- package/src/templates/components/datepicker/_template.datepicker.njk +0 -1
- package/src/templates/components/description-list/_examples.description-list.njk +2 -2
- package/src/templates/components/dialog/_examples.dialog.njk +2 -2
- package/src/templates/components/dropdown/_examples.dropdown.njk +3 -3
- package/src/templates/components/error-message/_examples.error-message.njk +4 -2
- package/src/templates/components/fieldset/_examples.fieldset.njk +2 -29
- package/src/templates/components/file-upload/_examples.file-upload.njk +4 -15
- package/src/templates/components/header-advanced/_template.header-advanced.njk +1 -0
- package/src/templates/components/input/_examples.input.njk +9 -45
- package/src/templates/components/input-group/_examples.input-group.njk +19 -18
- package/src/templates/components/item/_examples.item.njk +1 -0
- package/src/templates/components/media-object/_examples.media-object.njk +6 -5
- package/src/templates/components/menubar/_template.menubar.njk +2 -2
- package/src/templates/components/modal/_examples.modal.njk +1 -1
- package/src/templates/components/notification/_examples.notification.njk +8 -2
- package/src/templates/components/pill/_examples.pill.njk +2 -1
- package/src/templates/components/radios/_examples.radios.njk +56 -91
- package/src/templates/components/searchbar/_examples.searchbar.njk +2 -1
- package/src/templates/components/select/_examples.select.njk +3 -29
- package/src/templates/components/status-item/_examples.status-item.njk +1 -0
- package/src/templates/components/textarea/_examples.textarea.njk +3 -14
- package/src/templates/components/tree/_examples.tree.njk +2 -2
|
@@ -119,7 +119,7 @@
|
|
|
119
119
|
}
|
|
120
120
|
},
|
|
121
121
|
"errorMessage": {
|
|
122
|
-
"text": "
|
|
122
|
+
"text": "Aqui va un mensaje de error"
|
|
123
123
|
},
|
|
124
124
|
"items": [
|
|
125
125
|
{
|
|
@@ -159,7 +159,7 @@
|
|
|
159
159
|
"text": "Por ejemplo, 31 3 1980"
|
|
160
160
|
},
|
|
161
161
|
"errorMessage": {
|
|
162
|
-
"text": "
|
|
162
|
+
"text": "Aqui va un mensaje de error"
|
|
163
163
|
},
|
|
164
164
|
"items": [
|
|
165
165
|
{
|
|
@@ -199,7 +199,7 @@
|
|
|
199
199
|
"text": "Por ejemplo, 31 3 1980"
|
|
200
200
|
},
|
|
201
201
|
"errorMessage": {
|
|
202
|
-
"text": "
|
|
202
|
+
"text": "Aqui va un mensaje de error"
|
|
203
203
|
},
|
|
204
204
|
"items": [
|
|
205
205
|
{
|
|
@@ -46,7 +46,7 @@
|
|
|
46
46
|
"text": "Tu foto puede estar en tus Imágenes, Fotos, Descargas o el Escritorio. O en una aplicación como Fotos."
|
|
47
47
|
},
|
|
48
48
|
"errorMessage": {
|
|
49
|
-
"text": "Error
|
|
49
|
+
"text": "Error message goes here"
|
|
50
50
|
},
|
|
51
51
|
"classes": "text-sm lg:text-base"
|
|
52
52
|
}) }}
|
|
@@ -45,7 +45,7 @@
|
|
|
45
45
|
"id": "input-14",
|
|
46
46
|
"name": "test-name",
|
|
47
47
|
"errorMessage": {
|
|
48
|
-
"text": "
|
|
48
|
+
"text": "Mensaje de error"
|
|
49
49
|
},
|
|
50
50
|
"classes": "w-full"
|
|
51
51
|
}) }}
|
|
@@ -61,7 +61,7 @@
|
|
|
61
61
|
"id": "input-15",
|
|
62
62
|
"name": "test-name",
|
|
63
63
|
"errorMessage": {
|
|
64
|
-
"text": "
|
|
64
|
+
"text": "Mensaje de error"
|
|
65
65
|
},
|
|
66
66
|
"classes": "w-full"
|
|
67
67
|
}) }}
|
|
@@ -117,7 +117,7 @@
|
|
|
117
117
|
"id": "input-24",
|
|
118
118
|
"name": "test-name",
|
|
119
119
|
"errorMessage": {
|
|
120
|
-
"text": "
|
|
120
|
+
"text": "Mensaje de error",
|
|
121
121
|
"classes": "text-sm"
|
|
122
122
|
},
|
|
123
123
|
"classes": "c-input--sm w-full"
|
|
@@ -136,7 +136,7 @@
|
|
|
136
136
|
"id": "input-25",
|
|
137
137
|
"name": "test-name",
|
|
138
138
|
"errorMessage": {
|
|
139
|
-
"text": "
|
|
139
|
+
"text": "Mensaje de error",
|
|
140
140
|
"classes": "text-sm"
|
|
141
141
|
},
|
|
142
142
|
"classes": "c-input--sm w-full"
|
|
@@ -156,7 +156,7 @@
|
|
|
156
156
|
"id": "classes-applied-b",
|
|
157
157
|
"name": "classes-applied-b",
|
|
158
158
|
"errorMessage": {
|
|
159
|
-
"text": "Error
|
|
159
|
+
"text": "Error message goes here",
|
|
160
160
|
"classes": "order-1 w-full pt-sm"
|
|
161
161
|
},
|
|
162
162
|
"classes": "lg:flex-1"
|
|
@@ -84,7 +84,7 @@
|
|
|
84
84
|
"text": "Label"
|
|
85
85
|
},
|
|
86
86
|
"errorMessage": {
|
|
87
|
-
"text": "
|
|
87
|
+
"text": "Mensaje de error"
|
|
88
88
|
},
|
|
89
89
|
"items": [
|
|
90
90
|
{
|
|
@@ -114,7 +114,7 @@
|
|
|
114
114
|
"text": "Hint texto descriptivo"
|
|
115
115
|
},
|
|
116
116
|
"errorMessage": {
|
|
117
|
-
"text": "
|
|
117
|
+
"text": "Mensaje de error"
|
|
118
118
|
},
|
|
119
119
|
"items": [
|
|
120
120
|
{
|
|
@@ -224,7 +224,7 @@
|
|
|
224
224
|
"classes": "text-sm"
|
|
225
225
|
},
|
|
226
226
|
"errorMessage": {
|
|
227
|
-
"text": "
|
|
227
|
+
"text": "Mensaje de error",
|
|
228
228
|
"classes": "text-sm"
|
|
229
229
|
},
|
|
230
230
|
"items": [
|
|
@@ -257,7 +257,7 @@
|
|
|
257
257
|
"classes": "text-sm"
|
|
258
258
|
},
|
|
259
259
|
"errorMessage": {
|
|
260
|
-
"text": "
|
|
260
|
+
"text": "Mensaje de error",
|
|
261
261
|
"classes": "text-sm"
|
|
262
262
|
},
|
|
263
263
|
"items": [
|
|
@@ -366,7 +366,7 @@
|
|
|
366
366
|
"classes": "lg:flex lg:flex-wrap lg:items-center lg:gap-x-base"
|
|
367
367
|
},
|
|
368
368
|
"errorMessage": {
|
|
369
|
-
"text": "Error
|
|
369
|
+
"text": "Error message goes here",
|
|
370
370
|
"classes": "order-1 w-full pt-sm"
|
|
371
371
|
},
|
|
372
372
|
"items": [
|
|
@@ -46,7 +46,7 @@
|
|
|
46
46
|
"id": "input-14",
|
|
47
47
|
"name": "test-name",
|
|
48
48
|
"errorMessage": {
|
|
49
|
-
"text": "
|
|
49
|
+
"text": "Mensaje de error"
|
|
50
50
|
},
|
|
51
51
|
"classes": "w-full"
|
|
52
52
|
}) }}
|
|
@@ -62,7 +62,7 @@
|
|
|
62
62
|
"id": "input-15",
|
|
63
63
|
"name": "test-name",
|
|
64
64
|
"errorMessage": {
|
|
65
|
-
"text": "
|
|
65
|
+
"text": "Mensaje de error"
|
|
66
66
|
},
|
|
67
67
|
"classes": "w-full"
|
|
68
68
|
}) }}
|
|
@@ -116,7 +116,7 @@
|
|
|
116
116
|
"id": "input-14",
|
|
117
117
|
"name": "test-name",
|
|
118
118
|
"errorMessage": {
|
|
119
|
-
"text": "
|
|
119
|
+
"text": "Mensaje de error"
|
|
120
120
|
},
|
|
121
121
|
"maxlength": 10,
|
|
122
122
|
"classes": "w-full"
|
|
@@ -133,7 +133,7 @@
|
|
|
133
133
|
"id": "input-15",
|
|
134
134
|
"name": "test-name",
|
|
135
135
|
"errorMessage": {
|
|
136
|
-
"text": "
|
|
136
|
+
"text": "Mensaje de error"
|
|
137
137
|
},
|
|
138
138
|
"maxlength": 10,
|
|
139
139
|
"classes": "w-full"
|
|
@@ -190,7 +190,7 @@
|
|
|
190
190
|
"id": "input-24",
|
|
191
191
|
"name": "test-name",
|
|
192
192
|
"errorMessage": {
|
|
193
|
-
"text": "
|
|
193
|
+
"text": "Mensaje de error",
|
|
194
194
|
"classes": "text-sm"
|
|
195
195
|
},
|
|
196
196
|
"classes": "text-sm w-full"
|
|
@@ -209,7 +209,7 @@
|
|
|
209
209
|
"id": "input-25",
|
|
210
210
|
"name": "test-name",
|
|
211
211
|
"errorMessage": {
|
|
212
|
-
"text": "
|
|
212
|
+
"text": "Mensaje de error",
|
|
213
213
|
"classes": "text-sm"
|
|
214
214
|
},
|
|
215
215
|
"classes": "text-sm w-full"
|
|
@@ -229,7 +229,7 @@
|
|
|
229
229
|
"id": "classes-applied-b",
|
|
230
230
|
"name": "classes-applied-b",
|
|
231
231
|
"errorMessage": {
|
|
232
|
-
"text": "Error
|
|
232
|
+
"text": "Error message goes here",
|
|
233
233
|
"classes": "order-1 w-full pt-sm"
|
|
234
234
|
},
|
|
235
235
|
"classes": "lg:flex-1"
|
package/docs/index.html
CHANGED
|
@@ -39,6 +39,10 @@
|
|
|
39
39
|
|
|
40
40
|
<h2>Changelog (English)</h2>
|
|
41
41
|
<p>What's new in the latest version of desy-html</p>
|
|
42
|
+
<h3>v.13.0.2</h3>
|
|
43
|
+
<ul class="text-sm">
|
|
44
|
+
<li>Accesibility fixes in most of the component examples.</li>
|
|
45
|
+
</ul>
|
|
42
46
|
<h3>v.13.0.1</h3>
|
|
43
47
|
<ul class="text-sm">
|
|
44
48
|
<li>Removed backstop npm script entries as they are not used.</li>
|
package/package.json
CHANGED
|
@@ -35,7 +35,10 @@ export function MenuNavigation(aria) {
|
|
|
35
35
|
const getElement = element.parentElement.parentElement.parentElement.parentElement.querySelector('button');
|
|
36
36
|
getElement.classList.add('c-menu-navigation__button--primary', 'c-menu-navigation__button--has-selection');
|
|
37
37
|
getElement.setAttribute('aria-current', 'true');
|
|
38
|
-
|
|
38
|
+
const mainSpan = getElement.querySelector('span:not(.sr-only)');
|
|
39
|
+
if (mainSpan) {
|
|
40
|
+
mainSpan.innerHTML = `<strong class="font-bold">${mainSpan.textContent}</strong>`;
|
|
41
|
+
}
|
|
39
42
|
element.innerHTML = `<strong class="font-bold">${element.textContent}</strong>`;
|
|
40
43
|
}
|
|
41
44
|
})
|
|
@@ -97,7 +100,10 @@ export function MenuNavigation(aria) {
|
|
|
97
100
|
const getElementParent = link.parentElement.parentElement.parentElement.parentElement.querySelector('button');
|
|
98
101
|
getElementParent.classList.remove('c-menu-navigation__button--primary', 'c-menu-navigation__button--has-selection');
|
|
99
102
|
getElementParent.removeAttribute('aria-current');
|
|
100
|
-
|
|
103
|
+
const mainSpanParent2 = getElementParent.querySelector('span:not(.sr-only)');
|
|
104
|
+
if (mainSpanParent2) {
|
|
105
|
+
mainSpanParent2.innerHTML = mainSpanParent2.textContent;
|
|
106
|
+
}
|
|
101
107
|
link.removeAttribute('aria-current');
|
|
102
108
|
link.innerHTML = `${link.textContent}`;
|
|
103
109
|
}
|
|
@@ -107,7 +113,10 @@ export function MenuNavigation(aria) {
|
|
|
107
113
|
const getElementParent = link.parentElement.parentElement.parentElement.parentElement.querySelector('button');
|
|
108
114
|
getElementParent.classList.add('c-menu-navigation__button--primary', 'c-menu-navigation__button--has-selection');
|
|
109
115
|
getElementParent.setAttribute('aria-current', 'true');
|
|
110
|
-
|
|
116
|
+
const mainSpanParent = getElementParent.querySelector('span:not(.sr-only)');
|
|
117
|
+
if (mainSpanParent) {
|
|
118
|
+
mainSpanParent.innerHTML = `<strong class="font-bold">${mainSpanParent.textContent}</strong>`;
|
|
119
|
+
}
|
|
111
120
|
}
|
|
112
121
|
});
|
|
113
122
|
};
|
|
@@ -63,6 +63,7 @@
|
|
|
63
63
|
},
|
|
64
64
|
{
|
|
65
65
|
"name": "con valor por defecto excediendo el límite",
|
|
66
|
+
"description": "Por accesibilidad, los mensajes de error deben incluir la palabra \"error\", para que no recaiga tan sólo en el color el hecho de que es un mensaje de error.",
|
|
66
67
|
"data": {
|
|
67
68
|
"id": "exceeding-characters",
|
|
68
69
|
"name": "exceeding",
|
|
@@ -72,7 +73,7 @@
|
|
|
72
73
|
"text": "Dirección completa"
|
|
73
74
|
},
|
|
74
75
|
"errorMessage": {
|
|
75
|
-
"text": "
|
|
76
|
+
"text": "Por favor, no exceder el límite máximo. Error en el campo."
|
|
76
77
|
}
|
|
77
78
|
}
|
|
78
79
|
},
|
|
@@ -88,19 +89,6 @@
|
|
|
88
89
|
"rows": 8
|
|
89
90
|
}
|
|
90
91
|
},
|
|
91
|
-
{
|
|
92
|
-
"name": "con label como encabezado",
|
|
93
|
-
"description": "Utiliza el parámetro <code>'isPageheading': true</code> para que el label esté dentro de un encabezado. Usa el parámetro <code>'headingLevel'</code> para establecer el nivel del encabezado. Por ejemplo: <code>'headingLevel': 3</code> creará un encabezado <code><h3></code>. Si no se establece un <code>'headingLevel'</code>, por defecto usará un <code><h1></code>.",
|
|
94
|
-
"data": {
|
|
95
|
-
"id": "textarea-with-page-heading",
|
|
96
|
-
"name": "address",
|
|
97
|
-
"maxlength": 250,
|
|
98
|
-
"label": {
|
|
99
|
-
"text": "Esto es un label dentro de un encabezado <h1>",
|
|
100
|
-
"isPageHeading": true
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
},
|
|
104
92
|
{
|
|
105
93
|
"name": "con contador de palabras",
|
|
106
94
|
"data": {
|
|
@@ -139,7 +127,7 @@
|
|
|
139
127
|
"name": "classes-applied-b",
|
|
140
128
|
"maxlength": 250,
|
|
141
129
|
"errorMessage": {
|
|
142
|
-
"text": "
|
|
130
|
+
"text": "Esto es un mensaje de error",
|
|
143
131
|
"classes": "order-1 w-full pt-sm"
|
|
144
132
|
},
|
|
145
133
|
"classes": "lg:flex-1"
|
|
@@ -1,37 +1,65 @@
|
|
|
1
1
|
{% from "components/checkboxes/_macro.checkboxes.njk" import componentCheckboxes %}
|
|
2
|
+
{% from "components/fieldset/_macro.fieldset.njk" import componentFieldset %}
|
|
2
3
|
{% from "components/input/_macro.input.njk" import componentInput %}
|
|
3
4
|
|
|
4
5
|
{% macro telefonoContent(id='id') %}
|
|
5
|
-
{
|
|
6
|
-
"
|
|
7
|
-
"text": "
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
6
|
+
{% call componentFieldset({
|
|
7
|
+
"legend": {
|
|
8
|
+
"text": "¿Cuál es tu número de teléfono fijo?",
|
|
9
|
+
"classes": "mb-sm sr-only"
|
|
10
|
+
}
|
|
11
|
+
}) %}
|
|
12
|
+
<div class="c-form-group">
|
|
13
|
+
{{ componentInput({
|
|
14
|
+
"label": {
|
|
15
|
+
"text": "Número de teléfono fijo"
|
|
16
|
+
},
|
|
17
|
+
"id": "telefono-" + id,
|
|
18
|
+
"name": "telefono-name-" + id
|
|
19
|
+
}) }}
|
|
20
|
+
</div>
|
|
21
|
+
{% endcall %}
|
|
12
22
|
{% endmacro %}
|
|
13
23
|
|
|
14
24
|
{% macro mobileContent(id='id') %}
|
|
15
|
-
{
|
|
16
|
-
"
|
|
17
|
-
"text": "
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
25
|
+
{% call componentFieldset({
|
|
26
|
+
"legend": {
|
|
27
|
+
"text": "¿Cuál es tu número de teléfono móvil?",
|
|
28
|
+
"classes": "mb-sm sr-only"
|
|
29
|
+
}
|
|
30
|
+
}) %}
|
|
31
|
+
<div class="c-form-group">
|
|
32
|
+
{{ componentInput({
|
|
33
|
+
"label": {
|
|
34
|
+
"text": "Número de teléfono móvil"
|
|
35
|
+
},
|
|
36
|
+
"id": "mobile-" + id,
|
|
37
|
+
"name": "mobile-name-" + id
|
|
38
|
+
}) }}
|
|
39
|
+
</div>
|
|
40
|
+
{% endcall %}
|
|
22
41
|
{% endmacro %}
|
|
23
42
|
|
|
24
43
|
{% macro mobileErrorContent(id='id') %}
|
|
25
|
-
{
|
|
26
|
-
"
|
|
27
|
-
"text": "
|
|
28
|
-
|
|
29
|
-
"id": "input-with-error-message-" + id,
|
|
30
|
-
"name": "test-name-" + id,
|
|
31
|
-
"errorMessage": {
|
|
32
|
-
"text": "Error: Este campo no puede estar vacío"
|
|
44
|
+
{% call componentFieldset({
|
|
45
|
+
"legend": {
|
|
46
|
+
"text": "¿Cuál es tu número de teléfono móvil?",
|
|
47
|
+
"classes": "mb-sm sr-only"
|
|
33
48
|
}
|
|
34
|
-
|
|
49
|
+
}) %}
|
|
50
|
+
<div class="c-form-group">
|
|
51
|
+
{{ componentInput({
|
|
52
|
+
"label": {
|
|
53
|
+
"text": "Número de teléfono móvil"
|
|
54
|
+
},
|
|
55
|
+
"id": "input-with-error-message-" + id,
|
|
56
|
+
"name": "test-name-" + id,
|
|
57
|
+
"errorMessage": {
|
|
58
|
+
"text": "Este campo no puede estar vacío"
|
|
59
|
+
}
|
|
60
|
+
}) }}
|
|
61
|
+
</div>
|
|
62
|
+
{% endcall %}
|
|
35
63
|
{% endmacro %}
|
|
36
64
|
|
|
37
65
|
{% macro grandchildContent(id='id') %}
|
|
@@ -274,39 +302,6 @@
|
|
|
274
302
|
]
|
|
275
303
|
}
|
|
276
304
|
},
|
|
277
|
-
{
|
|
278
|
-
"name": "con un legend como encabezado",
|
|
279
|
-
"description": "Usa el parámetro <code>'heading'</code> para añadir un encabezado asociado al componente. Usa el parámetro <code>'headingLevel'</code> para establecer el nivel del encabezado. Por ejemplo: <code>'headingLevel': 3</code> creará un encabezado <code><h3></code>.",
|
|
280
|
-
"data": {
|
|
281
|
-
"idPrefix": "legend-as-page-heading",
|
|
282
|
-
"name": "legend-as-page-heading",
|
|
283
|
-
"fieldset": {
|
|
284
|
-
"legend": {
|
|
285
|
-
"text": "¿Cómo prefieres que te contactemos?",
|
|
286
|
-
"classes": "c-h2",
|
|
287
|
-
"isPageHeading": true
|
|
288
|
-
},
|
|
289
|
-
"headingLevel": 2
|
|
290
|
-
},
|
|
291
|
-
"hint": {
|
|
292
|
-
"text": "Si lo deseas puedes seleccionar varios elementos."
|
|
293
|
-
},
|
|
294
|
-
"items": [
|
|
295
|
-
{
|
|
296
|
-
"value": "correo-electronico",
|
|
297
|
-
"text": "Correo electrónico"
|
|
298
|
-
},
|
|
299
|
-
{
|
|
300
|
-
"value": "correp-postal",
|
|
301
|
-
"text": "Correo postal"
|
|
302
|
-
},
|
|
303
|
-
{
|
|
304
|
-
"value": "telefono",
|
|
305
|
-
"text": "Teléfono"
|
|
306
|
-
}
|
|
307
|
-
]
|
|
308
|
-
}
|
|
309
|
-
},
|
|
310
305
|
{
|
|
311
306
|
"name": "con un legend del tamaño de un encabezado h2",
|
|
312
307
|
"data": {
|
|
@@ -322,7 +317,7 @@
|
|
|
322
317
|
"text": "Si lo deseas puedes seleccionar varios elementos."
|
|
323
318
|
},
|
|
324
319
|
"errorMessage": {
|
|
325
|
-
"text": "
|
|
320
|
+
"text": "Tienes que seleccionar al menos una opción. Soluciona el error."
|
|
326
321
|
},
|
|
327
322
|
"items": [
|
|
328
323
|
{
|
|
@@ -342,6 +337,7 @@
|
|
|
342
337
|
},
|
|
343
338
|
{
|
|
344
339
|
"name": "sin fieldset",
|
|
340
|
+
"description": "Usa este ejemplo si vas a escribir tú mismo un fieldset, rodeándolo. Recuerda que el uso de fieldset es necesario por accesibilidad.",
|
|
345
341
|
"data": {
|
|
346
342
|
"idPrefix": "without-fieldset",
|
|
347
343
|
"name": "without-fieldset",
|
|
@@ -363,11 +359,12 @@
|
|
|
363
359
|
},
|
|
364
360
|
{
|
|
365
361
|
"name": "con una sóla opción usando 'aria-describedby' en el input",
|
|
362
|
+
"description": "Por accesibilidad, los mensajes de error deben incluir la palabra \"error\", para que no recaiga tan sólo en el color el hecho de que es un mensaje de error.",
|
|
366
363
|
"data": {
|
|
367
364
|
"idPrefix": "describedby",
|
|
368
365
|
"name": "describedby",
|
|
369
366
|
"errorMessage": {
|
|
370
|
-
"text": "
|
|
367
|
+
"text": "Por favor, debes aceptar los términos y condiciones. Soluciona el error."
|
|
371
368
|
},
|
|
372
369
|
"items": [
|
|
373
370
|
{
|
|
@@ -379,10 +376,11 @@
|
|
|
379
376
|
},
|
|
380
377
|
{
|
|
381
378
|
"name": "con una sóla opción (y pista) usando 'aria-describedby' en el input",
|
|
379
|
+
"description": "Por accesibilidad, los mensajes de error deben incluir la palabra \"error\", para que no recaiga tan sólo en el color el hecho de que es un mensaje de error.",
|
|
382
380
|
"data": {
|
|
383
381
|
"name": "t-and-c-with-hint",
|
|
384
382
|
"errorMessage": {
|
|
385
|
-
"text": "
|
|
383
|
+
"text": "Por favor, debes aceptar los términos y condiciones. Soluciona el error."
|
|
386
384
|
},
|
|
387
385
|
"items": [
|
|
388
386
|
{
|
|
@@ -397,10 +395,11 @@
|
|
|
397
395
|
},
|
|
398
396
|
{
|
|
399
397
|
"name": "con fieldset y mensaje de error",
|
|
398
|
+
"description": "Por accesibilidad, los mensajes de error deben incluir la palabra \"error\", para que no recaiga tan sólo en el color el hecho de que es un mensaje de error.",
|
|
400
399
|
"data": {
|
|
401
400
|
"name": "colours",
|
|
402
401
|
"errorMessage": {
|
|
403
|
-
"text": "
|
|
402
|
+
"text": "Tienes que seleccionar al menos una opción. Soluciona el error."
|
|
404
403
|
},
|
|
405
404
|
"fieldset": {
|
|
406
405
|
"legend": {
|
|
@@ -425,11 +424,12 @@
|
|
|
425
424
|
},
|
|
426
425
|
{
|
|
427
426
|
"name": "con mensaje de error",
|
|
427
|
+
"description": "Por accesibilidad, los mensajes de error deben incluir la palabra \"error\", para que no recaiga tan sólo en el color el hecho de que es un mensaje de error.",
|
|
428
428
|
"data": {
|
|
429
429
|
"idPrefix": "error-message",
|
|
430
430
|
"name": "error-message",
|
|
431
431
|
"errorMessage": {
|
|
432
|
-
"text": "
|
|
432
|
+
"text": "Tienes que seleccionar al menos una opción. Soluciona el error."
|
|
433
433
|
},
|
|
434
434
|
"fieldset": {
|
|
435
435
|
"legend": {
|
|
@@ -454,11 +454,12 @@
|
|
|
454
454
|
},
|
|
455
455
|
{
|
|
456
456
|
"name": "con mensaje de error y pistas en los items",
|
|
457
|
+
"description": "Por accesibilidad, los mensajes de error deben incluir la palabra \"error\", para que no recaiga tan sólo en el color el hecho de que es un mensaje de error.",
|
|
457
458
|
"data": {
|
|
458
459
|
"idPrefix": "error-and-hints",
|
|
459
460
|
"name": "error-and-hints",
|
|
460
461
|
"errorMessage": {
|
|
461
|
-
"text": "
|
|
462
|
+
"text": "Tienes que seleccionar al menos una opción. Soluciona el error."
|
|
462
463
|
},
|
|
463
464
|
"fieldset": {
|
|
464
465
|
"legend": {
|
|
@@ -492,6 +493,7 @@
|
|
|
492
493
|
},
|
|
493
494
|
{
|
|
494
495
|
"name": "con un texto de item muy largo",
|
|
496
|
+
"description": "Por accesibilidad, los mensajes de error deben incluir la palabra \"error\", para que no recaiga tan sólo en el color el hecho de que es un mensaje de error.",
|
|
495
497
|
"data": {
|
|
496
498
|
"idPrefix": "long-option",
|
|
497
499
|
"name": "long-option",
|
|
@@ -499,7 +501,7 @@
|
|
|
499
501
|
"text": "Nullam id dolor id nibh ultricies vehicula ut id elit."
|
|
500
502
|
},
|
|
501
503
|
"errorMessage": {
|
|
502
|
-
"text": "
|
|
504
|
+
"text": "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Soluciona el error."
|
|
503
505
|
},
|
|
504
506
|
"fieldset": {
|
|
505
507
|
"legend": {
|
|
@@ -524,6 +526,7 @@
|
|
|
524
526
|
},
|
|
525
527
|
{
|
|
526
528
|
"name": "con items condicionales",
|
|
529
|
+
"description": "El contenido de cada condicional es una agrupación, y como tal, se deben agrupar con una etiqueta <code><fieldset></code> o bien de una etiqueta <code><div></code> con <code>role=\"group\"</code> que tenga un <code>aria-label</code> o <code>aria-labelledby</code>.",
|
|
527
530
|
"data": {
|
|
528
531
|
"idPrefix": "with-conditional-items",
|
|
529
532
|
"name": "with-conditional-items",
|
|
@@ -558,31 +561,9 @@
|
|
|
558
561
|
]
|
|
559
562
|
}
|
|
560
563
|
},
|
|
561
|
-
{
|
|
562
|
-
"name": "con items condicionales anidados",
|
|
563
|
-
"data": {
|
|
564
|
-
"idPrefix": "with-conditional-nested-items",
|
|
565
|
-
"name": "with-conditional-nested-items",
|
|
566
|
-
"idPrefix": "how-contacted-nested",
|
|
567
|
-
"fieldset": {
|
|
568
|
-
"legend": {
|
|
569
|
-
"text": "¿Cómo quieres que te contactemos?"
|
|
570
|
-
}
|
|
571
|
-
},
|
|
572
|
-
"items": [
|
|
573
|
-
{
|
|
574
|
-
"value": "presencial",
|
|
575
|
-
"text": "Presencial",
|
|
576
|
-
"checked": true,
|
|
577
|
-
"conditional": {
|
|
578
|
-
"html": nestedContent('1').val
|
|
579
|
-
}
|
|
580
|
-
}
|
|
581
|
-
]
|
|
582
|
-
}
|
|
583
|
-
},
|
|
584
564
|
{
|
|
585
565
|
"name": "con item condicional seleccionado",
|
|
566
|
+
"description": "Usa el parámetro <code>'checked': true</code> para mostrar un item condicional seleccionado. El contenido de cada condicional es una agrupación, y como tal, se deben agrupar con una etiqueta <code><fieldset></code> o bien de una etiqueta <code><div></code> con <code>role=\"group\"</code> que tenga un <code>aria-label</code> o <code>aria-labelledby</code>.",
|
|
586
567
|
"data": {
|
|
587
568
|
"idPrefix": "with-conditional-items-checked",
|
|
588
569
|
"name": "with-conditional-items-checked",
|