Comments (5)
Should be doable if we scan for inclusion of that module. Also, would require adapting the tests.
from futurism.
I was thinking:
def transformed_options
require_relative "shims/deep_transform_values" unless options.respond_to? :deep_transform_values
options.deep_transform_values do |value|
if value.is_a?(ActiveRecord::Base) && !value.new_record?
value.to_global_id.to_s
else
value
end
end
end
becomes:
def transformed_options
require_relative "shims/deep_transform_values" unless options.respond_to? :deep_transform_values
options.deep_transform_values do |value|
if value.respond_to?(:to_global_id) && !value.try(:new_record?)
value.to_global_id.to_s
else
value
end
end
end
I can write some tests for this too
from futurism.
Yep, could go with duck typing, here are some other options:
https://stackoverflow.com/a/28667632
from futurism.
I'm going to do a PR tomorrow.
I'm currently preferring duck typing instead of ancestors, looking for specific classes/included modules, etc. Maybe it's just personal preference, but a) we do duck typing just a few lines above, and if we would have not pegged it to a specific class, this just would have been supported out of the box. The specific module could change, there could be other abstractions that implement a similar interface, etc.
from futurism.
I'm fine with it, just wanted to provide options.
from futurism.
Related Issues (20)
- Pass contextual arguments to the futurize yield block HOT 3
- Add Rails 7 to appraisals
- Reuse debounce from CableReady 5 utils.js
- Custom built in elements appear to be broken on mobile safari (again)
- Move from ActionController::Renderer to ActionView::PartialRenderer
- Introduce `unless` to bypass futurism completely
- Empty placeholder not falling back to eager loading anymore HOT 5
- Futurize inline templates HOT 2
- GlobalID errors HOT 13
- Set extends: :div by default to reduce boilerplate? HOT 1
- Use Application::Channel and not ActionCable::Channel::Base HOT 2
- Running installer on clean Rails 5.2 fails with TypeError: no implicit conversion of nil into String HOT 6
- Move configuration options to `Configuration` class
- Use non-expiring SGIDs
- Use locate_many to avoid N+1 HOT 1
- Optionally allow broadcasting after each partial is generated HOT 7
- Adapt for Turbo HOT 3
- Better Error Handling if routes are not "recognized"
- Name collision if your project uses `Element` HOT 4
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from futurism.