-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
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: bind to style with object, array and string merging/override support #236
Conversation
7c0edb4
to
a464b5c
Compare
@calebporzio this has been update with latest master changes and is ready for you to check out 👍 |
@calebporzio any idea when this PR might be integrated? I'm aware it's a chunky one but it does bring support for a feature you mentioned just not having time to tackle. |
I would also really like to see this functionality in Alpine. In my case I am using it for a color picker to dynamically adjust the selected color background. Here is a CodePen which shows it not working if that helps https://codepen.io/atomgiant/pen/YzyzYxd |
d741b2b
to
a3bc623
Compare
a3bc623
to
5638c7d
Compare
I've cleaned this PR up for review 😄 |
Thanks @HugoDF, but going to hold off on adding "object" syntax for the style attribute for now. May remove the object syntax from the class attributes in v3 - undecided yet. I will put a note in the Roadmap and reference this PR. Thanks for the contribution! |
@calebporzio would you be able to clear up the thoughts around removing object support from the <input :class="{'input-valid': isValid, 'input-invalid': !isValid && isDirty}" /> |
@OwenMelbz the rationale is two fold, first is that it's achievable in userland with a util function that converts objects into an array (or string), second is that it's not implemented exactly in the same way as Vue and that has caused issues. |
Hey @HugoDF I appreciate the "issues caused" would add a complication. So would that mean that if anybody wanted to use the syntax above they would need to create a global function that needs access to the data? Wonder if you could mockup what you mean for a real-world app, would it be something like...? <div x-data="{value: '', isValid: false, isDirty: false}">
<input :class="mergeArrays(inputClasses($data), otherClassLogic())" />
</div>
Thanks! |
Hmm no it would have a similar API
Implementation would then be Alpine agnostic. |
@OwenMelbz one option might be to use the Classnames package to compose the list of class strings. I've put together a small demo here: https://jsfiddle.net/philw_/ydvm8r1h/ Btw I found this issue while looking at the Roadmap, I've never used Alpine before but have been experimenting with adapting the dropdown from the README and have really enjoyed it! |
Closes #213 Adds Vue-style binding support for the "style" attribute.
Style binding supports:
<div style="display: inline" :style="'padding: 10px'"></div>
->display: inline; padding: 10px
applied<div style="display: inline" :style="['display: hidden; width: 200px;', 'height: 20px;']"></div>
->display: hidden; width: 200px; height: 20px;
<div style="padding-top: 0" :style="{display: 'hidden', paddingTop: '15px', borderColor: 'teal'}></div>"
->display: hidden; padding-top: 15px; border-color: teal
Update README with style object/array support.
Unrelated change (to tests): fixes missing assertion calls inSubmitted as #360.class
bind tests (see 6d9e2a0), I'm happy to submit this as a separate PR.