-
-
Notifications
You must be signed in to change notification settings - Fork 344
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]: Allow for any attribute to be added to the config of filters #2000
Comments
So - custom classes for the input, that's a feature that is in the works, and should be out in a few versions time. Very good point in terms of allowing a wider range of attributes to be merged in though, and something I'll definitely look at for the next release, with NumberFilter as the first target, as some of the others do have more specific matching built in, so it'd have to be NumberFilter specific to start with. |
So having looked at the approach for this, blacklisting at this stage on a more global level, probably isn't viable. However, for NumberFilter, I'm doing some testing:
Now for a release, I would need to ensure that any of the alternative filter behaviours etc are also ignored, such as where debounce etc are used. Then in the "components.tools.filters.number.blade.php"
Which so far seems to be working, I will just need to do some further testing, and ensure that other approaches aren't impacted |
Self reminder to review this again |
So before we can make this a global feature, we need to:
Otherwise, yes, absolutely, and I've added this to the to-do list. |
So it's looking possible that I'll add in a Rather than using the config approach, and then slowly migrate (in a non breaking way) any existing config options that are an input attribute, into this. This should allow the same approach for the majority of the filters, as config for NumberRange filter for example actually does config related things. |
Just a note that this is still in the works! |
This is fully in-progress, and should be in one of the next releases |
This is still progressing well, but I'm aware that I still need to write the tests and docs. It is likely that I'll release this in several stages, covering a chunk of filter types in each release, to try and get the feature out for at least some filters sooner rather than later. |
@khwadj - several of the filters now support this behaviour in the development branch Complete
In Progress Special Note
Excluded
|
Overview
As I'm working with NumberFilters (see issue #1999), I realized that the attributes that would be placed on the input are hardcoded in the view for that filter.
A few attributes are allowed in each filter view, and are pulled from the filter's config.
Detailed explanation
Example: NumberFilter
resources/views/components/tools/filters/number.blade.php
This means that the user cannot define other valid attributes for a number input (ex: step, maxlength) without locally overwriting this view.
The user cannot define any custom attribute either, from which they would benefit for whatever reason they might have.
Notes
Proposed solution:
Simply iterates on the config item and set every key in it. It's the developer's responsibility to add attributes that make sense.
resources/views/components/tools/filters/number.blade.php
In addition, it could be interesting the implement a blacklist of config keys to avoid breaking stuff: id, class, type, wire:key.
Views/Traits/Core/HasConfig.php
Finally, it might be worth allowing the user to add custom classes to their input on top of other attributes, but this is arguably another feature.
The text was updated successfully, but these errors were encountered: