-
-
Notifications
You must be signed in to change notification settings - Fork 996
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
Optiongroup children should be indented #1474
Comments
I guess I could use attribute selector but that doesn't seem right either: .multiselect[group-values],
.multiselect[group-label],
.multiselect[group-select] {
//My custom CSS
} EDIT: Nvm, these attr shouldn't even be rendered in the DOM in the first place, I created a wrapper component and forgot to set |
I've added the class in my wrapper component using the code bellow.
|
I've indented the options though this styling rule:
To ensure that only the selectors with groups would be indented, I've also added a class called
|
@shentao Can I open a PR for this or is there a reason why the option inside an optiongroup wouldn't be indented ? |
Adding the indentation (as much as I like it) would impact existing styling. I would personally recommend the solution suggested above with a custom CSS rule. If it could be added as an optional change then I think it’s okay. But I would refer to @mattelen @akki-jat if they would like to merge that. |
@shentao Thanks for your reply. Any change will have impact, it might need to be release in a minor/major instead of a patch release as to not affect existing user. The main problem with the custom CSS is for other library using depending on vue-multiselect. For exemple, I use I could contribute a PR to that package or override the style in all my Laravel Nova project, but the best would be to fix it in |
@mrleblanc101 I would suggest adding proper classes so if anyone wants to overwrite the styles for the group parent and the children can do that and default styles will be the same as those are now |
If you're ok with that I can open a PR, although I strongly feel that |
@mrleblanc101 We can decide the one default style right, in the end we need to provide the capability to change it as the user wants. So for now we can keep it as it is but yes in the next major version we can try to make an indented style default one as I think it is better UX. |
Do you want me to open 2 PR. |
@mrleblanc101 I think create one PR for the new class, and for the new default but the PR for the new default might take some time to merge in, as this would be something we can look at changing in V4. In the meantime we want to release another update of V2, and get the Vue 3 compatible version of V3 published as stable. TIA |
Currently, it's difficult to understand the relation between optiongroup children and their parent as the is no indentation.
The parent has a light grey background, but it's that it's a parent-children relationship.
I think the optiongroup children should be indented just like in regular select.
I could do this with custom style, but optiongroup children are not nested inside their parent in the HTML and the children have no specific class, only the optiongroup parent has a class.
If I add padding to all element, then remove the padding for the optiongroup parent, this will affect my other multiselect that do not have optiongroup. There is no global class on the component to know if it has optiongroup or not.
What it should be:
or
The text was updated successfully, but these errors were encountered: