-
Notifications
You must be signed in to change notification settings - Fork 140
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
Transforming inputs? #483
Comments
Stripping away whitespace from a string is a convenience because you'll almost always want to do it. Especially with user input. That's why we do it by default. Why not transform the values in the |
The payoff would be:
e.g. compare: class Task < ActiveInteraction::Base
time :start
def execute
p adjusted_start # "start" is never used; we only ever need "adjusted_start"
foo
end
private
def adjusted_start # have to introduce a new transformation helper
start.beginning_of_day # this computation may be expensive
end
def foo
p adjusted_start
end
end vs. class Task < ActiveInteraction::Base
time :start, transform: :beginning_of_day
def execute
p start # now, it's clear which param we refer to
foo
end
private
def foo
p start # the transformed value is memoized and we get it instantly
end
end |
yeees this would be also way more readable instead of putting this into execute ❤️ |
Can you do this with callbacks? https://github.com/AaronLasseigne/active_interaction/tree/a7dc3769bb6b771856615db42f96c5d4812bb8ac#callbacks set_callback :execute, :before, -> { start = start.beginning_of_day } I haven't written Ruby in a while so the details may not be quite right, but I think the overall idea should work. |
I experienced that limitation myself as well. Callbacks could be an alternative, however there are no callbacks when form object is used in class SomeController
def new
form = Form.new(x: params[:x])
end
end Personally I would prefer to add new callback e.g. Alternatively if filters are processed outside of |
Another option is to have a generic option for all filters to manipulate data. That overlaps a little bit with class Task < ActiveInteraction::Base
time :start, transform: -> { _1.beginning_of_day }
end Part that requires some thinking is do we want to deal with invalid inputs as part of transformation and when transformation should be performed before, during, or after filter. |
Related: Rails 7.1 now has the normalize feature in ActiveRecord models which is conceptually identical. class User < ActiveRecord::Base
normalizes :email, with: -> email { email&.downcase&.strip }
end When the lambda is just a single method call, we could use symbols for brevity: string :name, transform: :downcase |
Is there way to write a custom filter meet the needs? |
First, thanks for maintaining this gem, I love it! 🎉
I like that we can do things like
string :name, strip: true
which transforms the input by stripping it.I think it would be useful to be able to define an arbitrary transformation lambda when the input is defined.
For example, this would snap all time inputs to the beginning of the day, and force variable names into the proper format:
This would certainly DRY up a lot of our code.
The text was updated successfully, but these errors were encountered: