Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
A
a11y_autocomplete_element
Manage
Activity
Members
Labels
Plan
Wiki
Custom issue tracker
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Locked files
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Model registry
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Code review analytics
Insights
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
project
a11y_autocomplete_element
Merge requests
!5
Add foxy compatibility
Code
Review changes
Check out branch
Download
Patches
Plain diff
Merged
Add foxy compatibility
issue/a11y_autocomplete_element-3472705:foxy-compatible
into
1.x
Overview
0
Commits
20
Pipelines
2
Changes
8
Merged
Max Pogonowski
requested to merge
issue/a11y_autocomplete_element-3472705:foxy-compatible
into
1.x
8 months ago
Overview
0
Commits
20
Pipelines
2
Changes
8
Expand
0
0
Merge request reports
Compare
1.x
version 13
3dabb3b9
8 months ago
version 12
f940e6a8
8 months ago
version 11
03a855ba
8 months ago
version 10
f642b94a
8 months ago
version 9
6beff5a1
8 months ago
version 8
f8a707bb
8 months ago
version 7
c61e2673
8 months ago
version 6
0d0a9023
8 months ago
version 5
660124a3
8 months ago
version 4
39b78164
8 months ago
version 3
0638c787
8 months ago
version 2
600cc948
8 months ago
version 1
5db0215c
8 months ago
1.x (base)
and
latest version
latest version
3dabb3b9
20 commits,
8 months ago
version 13
3dabb3b9
20 commits,
8 months ago
version 12
f940e6a8
19 commits,
8 months ago
version 11
03a855ba
18 commits,
8 months ago
version 10
f642b94a
17 commits,
8 months ago
version 9
6beff5a1
16 commits,
8 months ago
version 8
f8a707bb
15 commits,
8 months ago
version 7
c61e2673
14 commits,
8 months ago
version 6
0d0a9023
13 commits,
8 months ago
version 5
660124a3
12 commits,
8 months ago
version 4
39b78164
11 commits,
8 months ago
version 3
0638c787
10 commits,
8 months ago
version 2
600cc948
9 commits,
8 months ago
version 1
5db0215c
8 commits,
8 months ago
8 files
+
210
−
3
Inline
Compare changes
Side-by-side
Inline
Show whitespace changes
Show one file at a time
Files
8
Search (e.g. *.vue) (Ctrl+P)
js/a11y-autocomplete.esm.js
0 → 100644
+
115
−
0
Options
/**
* @file
* Initiates a11y_autocomplete.
*/
import
A11yAutocomplete
from
'
@drupal/autocomplete
'
;
((
Drupal
,
once
)
=>
{
/**
* Initialize autocomplete
*
* @param {HTMLSelectElement} el Select element.
*/
const
init
=
el
=>
{
const
setRequired
=
pillsContainer
=>
{
input
.
required
=
el
.
required
&&
!
pillsContainer
.
querySelectorAll
(
'
.a11y-autocomplete__selected-item
'
)
.
length
;
};
const
generatePillForOption
=
(
pillsContainer
,
option
)
=>
{
if
(
pillsContainer
.
querySelector
(
`[data-option="
${
option
.
value
}
"]`
))
{
return
;
}
const
pill
=
document
.
createElement
(
'
div
'
);
pill
.
classList
.
add
(
'
a11y-autocomplete__selected-item
'
);
pill
.
dataset
.
option
=
option
.
value
;
const
close
=
document
.
createElement
(
'
button
'
);
close
.
classList
.
add
(
'
a11y-autocomplete__remove-selected
'
);
close
.
textContent
=
`Remove
${
option
.
textContent
}
`
;
pill
.
textContent
=
option
.
textContent
;
close
.
addEventListener
(
'
click
'
,
()
=>
{
option
.
selected
=
false
;
pill
.
remove
();
setRequired
(
pillsContainer
);
});
pill
.
append
(
close
);
pillsContainer
.
append
(
pill
);
};
const
input
=
document
.
createElement
(
'
input
'
);
input
.
type
=
'
text
'
;
input
.
classList
.
add
(
'
form-text
'
,
'
form-element
'
,
'
form-element--type-text
'
);
const
parent
=
el
.
parentNode
;
el
.
classList
.
add
(
'
visually-hidden
'
);
parent
.
insertBefore
(
input
,
el
);
if
(
el
.
multiple
===
true
)
{
const
pills
=
document
.
createElement
(
'
div
'
);
pills
.
classList
.
add
(
'
a11y-autocomplete__selected-items
'
);
parent
.
insertBefore
(
pills
,
el
);
el
.
querySelectorAll
(
'
option[selected]
'
).
forEach
(
option
=>
{
generatePillForOption
(
pills
,
option
);
});
setRequired
(
pills
);
}
else
{
input
.
value
=
el
.
querySelector
(
`option[value="
${
el
.
value
}
"]`
).
textContent
||
''
;
}
const
items
=
Array
.
from
(
el
.
querySelectorAll
(
'
option
'
)).
reduce
(
(
carry
,
option
)
=>
{
carry
.
push
({
label
:
option
.
textContent
,
value
:
option
.
value
,
});
return
carry
;
},
[],
);
// eslint-disable-next-line no-undef
A11yAutocomplete
(
input
,
{
source
:
items
,
});
let
selectionMade
=
false
;
input
.
addEventListener
(
'
autocomplete-select
'
,
e
=>
{
selectionMade
=
true
;
if
(
el
.
multiple
===
true
)
{
const
option
=
el
.
querySelector
(
`option[value="
${
e
.
detail
.
selected
.
value
}
"]`
,
);
option
.
selected
=
true
;
generatePillForOption
(
parent
.
querySelector
(
'
.a11y-autocomplete__selected-items
'
),
option
,
);
return
;
}
el
.
value
=
e
.
detail
.
selected
.
value
;
input
.
value
=
e
.
detail
.
selected
.
label
;
});
// When we close the autocomplete element, set the value to an empty string if it's a multi-value item. If it's a
// single value field, set it to the selected item label.
input
.
addEventListener
(
'
autocomplete-close
'
,
()
=>
{
if
(
!
selectionMade
)
{
return
;
}
selectionMade
=
false
;
if
(
el
.
multiple
===
true
)
{
input
.
value
=
''
;
input
.
required
=
false
;
return
;
}
input
.
value
=
el
.
querySelector
(
`option[value="
${
el
.
value
}
"]`
).
textContent
||
''
;
});
};
Drupal
.
behaviors
.
a11y_autocomplete_element
=
{
attach
(
context
)
{
once
(
'
a11y_autocomplete_element
'
,
'
[data-a11y-autocomplete-element]
'
,
context
,
).
forEach
(
init
);
},
};
// eslint-disable-next-line no-undef
})(
Drupal
,
once
);
Loading