-
Notifications
You must be signed in to change notification settings - Fork 4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat(Dropdown): remove diacritics on filter #2021
feat(Dropdown): remove diacritics on filter #2021
Conversation
src/modules/Dropdown/Dropdown.js
Outdated
@@ -795,7 +795,14 @@ export default class Dropdown extends Component { | |||
filteredOptions = search(filteredOptions, searchQuery) | |||
} else { | |||
const re = new RegExp(_.escapeRegExp(searchQuery), 'i') | |||
filteredOptions = _.filter(filteredOptions, opt => re.test(opt.text)) | |||
filteredOptions = _.filter(filteredOptions, function (opt) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This should just be:
-filteredOptions = _.filter(filteredOptions, opt => re.test(opt.text))
+filteredOptions = _.filter(filteredOptions, opt => re.test(_.deburr(opt.text)))
See inline comment on |
ty for your quick response, i will try to add a test, first time I am doing a pull request so please have patience :) |
Codecov Report
@@ Coverage Diff @@
## master #2021 +/- ##
=======================================
Coverage 99.76% 99.76%
=======================================
Files 148 148
Lines 2556 2556
=======================================
Hits 2550 2550
Misses 6 6
Continue to review full report at Codecov.
|
src/modules/Dropdown/Dropdown.js
Outdated
@@ -795,7 +795,8 @@ export default class Dropdown extends Component { | |||
filteredOptions = search(filteredOptions, searchQuery) | |||
} else { | |||
const re = new RegExp(_.escapeRegExp(searchQuery), 'i') | |||
filteredOptions = _.filter(filteredOptions, opt => re.test(opt.text)) | |||
// remove diacritics on search | |||
filteredOptions = _.filter(filteredOptions, opt => re.test(opt.text ? _.deburr(opt.text): opt.text)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
|
||
wrapper | ||
.find('.selected') | ||
.should.contain.text('FLOREŞTI') |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks great. We can end the test here as one assertion is enough to prove the feature.
Skipping the additional arrow down behaviors will make this test stronger. This way, the filter after diacritics
test doesn't fail if the arrow down behavior changes, but only if the search filter behavior changes. 👍
Awesome, congrats on your first PR :) I left a couple more comments, then I think we're ready to go here. |
Be sure to run
|
hey i've made the changes, i hope they are good, thank you soooo much for your help, i am going to brag all day to my work colleagues :))) good job on this library 👍 |
Thanks! Nice work, brag away my friend :) |
* remove diacritics on filter * change to arrow function * use lodash _.deburr instead * added a test for filter after diacritics * remove unnecessary ternary check * remove unnecessary tests check on filter diacritics
Released in |
* remove diacritics on filter * change to arrow function * use lodash _.deburr instead * added a test for filter after diacritics * remove unnecessary ternary check * remove unnecessary tests check on filter diacritics
I really need this feature, can you guys help me?