-
-
Notifications
You must be signed in to change notification settings - Fork 91
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
[feature request] Make vue-autosuggest fully compatible with BEM #96
Comments
I'm going to be honest with you that I have never actually worked with BEM before so I'm actually quite surprised it's so close to BEM convention. Close, but no cigar. This looks like a good PR for outsiders who don't necessarily need to understand the codebase. PR'd against the 2.0 branch if you were up for contributing. If you're interested, a PR with BEM standards, as well as prefix customization would be welcome! |
@darrenjennings |
Can I play devil's advocate here? I wonder if the missing feature is just to be able to override two things:
By providing these two features and not changing the existing class names, consumers will have the ability to define classes that follow BEM convention or any other convention they choose, while not introducing a breaking change for existing users. I understand that this change would be in a major release and breaking changes are acceptable, but I still think minimizing them when possible is ideal. If the belief is that the majority of consumers want BEM classes, then the change makes sense. But if only a few do, this is a breaking a change that only really benefits a few so that they won't have to provide their classes via configuration. |
@scottadamsmith thanks for the feedback, always appreciated. Class prefix customization will be fixed by #97. Originally, I did not want to add any classnames on any element, but the "rubber to the road" truth was that I needed them for query selecting and accessibility. I believe this to still be an acceptable architecture, but ideally we need to solve use cases like users coming from bootstrap, or tailwind. I don't like prop explosion so I'm less likely to go with solutions like #90.
This lib is small enough that I'm willing to "break" more things, so that new users can benefit, while alleviating the punishment on existing users with a nice changelog/migration guide. My goal is to break as many features as possible in 2.0 in an attempt to make it more intuitive for new users, while (hopefully) increasing the longevity of vue-autosuggest. Going forward, I think we should accept BEM defaults, allow to customize via prefix and append new classnames via v-bind props, similar to how the vue-autosuggest/src/Autosuggest.vue Line 8 in b825be2
|
Closed by 2.0.0 Was an oversight now that I'm reviewing, I did not add ability for class to be added |
It's great that
vue-autosuggest
follow the BEM convention, but it would be even greater if it followed the BEM convention fully ;)autosuggest__results_item-${index}
should beautosuggest__results-item--${index}
autosuggest__results_item-highlighted
should beautosuggest__results-item--highlighted
autosuggest__results_item
shoud beautosuggest__results-item
autosuggest__results_title
should be-
autosuggest__results-title``autosuggest__results_title_${this.section.name}
should beautosuggest__results-title--${this.section.name}
autosuggest__input-open
should beautosuggest__input--open
<ul>
element doesn't have a class. Let's give it aautosuggest__results-list
class.The text was updated successfully, but these errors were encountered: