Module: Spree::DisplayMoney
- Included in:
- Adjustment, CustomerReturn, LineItem, Order, OrderPromotion, Price, ReturnAuthorization, ReturnItem, Shipment, ShippingRate, StoreCredit, StoreCreditEvent, UserReporting, WishedItem
- Defined in:
- app/models/concerns/spree/display_money.rb
Instance Method Summary collapse
-
#money_methods(*args) ⇒ Object
Takes a list of methods that the base object wants to be able to use to display with Spree::Money, and turns them into display_* methods.
Instance Method Details
#money_methods(*args) ⇒ Object
Takes a list of methods that the base object wants to be able to use to display with Spree::Money, and turns them into display_* methods. Intended to help clean up some of the presentational logic that exists at the model layer.
Examples
Decorate a method, with the default option of using the base object’s currency
extend Spree::DisplayMoney
money_methods :tax_amount, :price
Decorate a method, but with some additional options
extend Spree::DisplayMoney
money_methods tax_amount: { currency: "CAD", no_cents: true }, :price
Use generated method with the same arguments as in wrapped method
def tax_amount(order, country)
display_tax_amount(order, country)
23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
# File 'app/models/concerns/spree/display_money.rb', line 23 def money_methods(*args) args.each do |money_method| money_method = { money_method => {} } unless money_method.is_a? Hash money_method.each do |method_name, opts| define_method("display_#{method_name}") do |**args_list| default_opts = respond_to?(:currency) ? { currency: currency } : {} amount = args_list.blank? ? send(method_name) : send(method_name, **args_list) Spree::Money.new(amount, default_opts.merge(opts).merge(args_list.slice(:currency))) end end end end |