summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEvgeny Zinoviev <me@ch1p.io>2022-01-05 18:48:19 +0300
committerEvgeny Zinoviev <me@ch1p.io>2022-01-05 18:48:19 +0300
commit5ce977959b12a1e220cefe27031f847213dab47f (patch)
tree8a7d06d27c11da2639e96c22e997a20d50d85545
parentbb0df53678c5b61c6adcf9c7939920f4ff5c11f3 (diff)
fix for accented characters (#8)HEADmaster
-rw-r--r--autocomplete.js16
1 files changed, 14 insertions, 2 deletions
diff --git a/autocomplete.js b/autocomplete.js
index aa2ad12..82a5d6c 100644
--- a/autocomplete.js
+++ b/autocomplete.js
@@ -67,7 +67,9 @@ class Autocomplete {
createItem(lookup, item) {
let label;
if (this.options.highlightTyped) {
- const idx = item.label.toLowerCase().indexOf(lookup.toLowerCase());
+ const idx = removeDiacritics(item.label)
+ .toLowerCase()
+ .indexOf(removeDiacritics(lookup).toLowerCase());
const className = Array.isArray(this.options.highlightClass) ? this.options.highlightClass.join(' ')
: (typeof this.options.highlightClass == 'string' ? this.options.highlightClass : '');
label = item.label.substring(0, idx)
@@ -109,7 +111,7 @@ class Autocomplete {
value: this.options.value ? entry[this.options.value] : entry
};
- if (item.label.toLowerCase().indexOf(lookup.toLowerCase()) >= 0) {
+ if (removeDiacritics(item.label).toLowerCase().indexOf(removeDiacritics(lookup).toLowerCase()) >= 0) {
items.appendChild(this.createItem(lookup, item));
if (this.options.maximumItems > 0 && ++count >= this.options.maximumItems)
break;
@@ -156,3 +158,13 @@ function ce(html) {
function insertAfter(elem, refElem) {
return refElem.parentNode.insertBefore(elem, refElem.nextSibling);
}
+
+/**
+ * @param {String} str
+ * @returns {String}
+ */
+function removeDiacritics(str) {
+ return str
+ .normalize('NFD')
+ .replace(/[\u0300-\u036f]/g, '');
+} \ No newline at end of file