Module: ActsAsPurchasable
- Extended by:
- ActiveSupport::Concern
- Defined in:
- app/models/concerns/acts_as_purchasable.rb
Defined Under Namespace
Modules: ActiveRecord, ClassMethods
Instance Method Summary
collapse
Instance Method Details
#declined!(order = nil, order_item = nil) ⇒ Object
121
122
123
124
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 121
def declined!(order = nil, order_item = nil)
after_decline(order, order_item) if self.respond_to?(:after_decline)
save!
end
|
#price ⇒ Object
51
52
53
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 51
def price
self[:price] || 0
end
|
#price=(value) ⇒ Object
If I have a column type of Integer, and I’m passed a non-Integer, convert it here
56
57
58
59
60
61
62
63
64
65
66
67
68
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 56
def price=(value)
integer_column = ((column_for_attribute('price').try(:type) rescue nil) == :integer)
if integer_column == false
super
elsif value.kind_of?(Integer)
super
elsif value.kind_of?(String) && !value.include?('.')
super
else
super((value.to_f * 100.0).to_i)
end
end
|
#purchased!(order = nil, order_item = nil) ⇒ Object
116
117
118
119
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 116
def purchased!(order = nil, order_item = nil)
after_purchase(order, order_item) if self.respond_to?(:after_purchase)
save!
end
|
#purchased? ⇒ Boolean
84
85
86
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 84
def purchased?
@is_purchased ||= orders.any? { |order| order.purchased? }
end
|
#purchased_at ⇒ Object
88
89
90
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 88
def purchased_at
@purchased_at ||= orders.map { |order| order.purchased_at if order.purchased? }.compact.sort.first
end
|
#purchased_by?(user) ⇒ Boolean
92
93
94
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 92
def purchased_by?(user)
orders.any? { |order| order.purchased? && order.user_id == user.id }
end
|
#purchased_download_url ⇒ Object
Override me if this is a digital purchase.
127
128
129
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 127
def purchased_download_url
false
end
|
#purchased_order ⇒ Object
100
101
102
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 100
def purchased_order
purchased_orders.first
end
|
#purchased_orders ⇒ Object
96
97
98
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 96
def purchased_orders
orders.select { |order| order.purchased? }
end
|
#quantity_enabled? ⇒ Boolean
104
105
106
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 104
def quantity_enabled?
self.respond_to?(:quantity_enabled) ? quantity_enabled == true : false
end
|
#quantity_remaining ⇒ Object
108
109
110
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 108
def quantity_remaining
(quantity_max - quantity_purchased) rescue 0
end
|
#seller ⇒ Object
78
79
80
81
82
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 78
def seller
if EffectiveOrders.stripe_connect_enabled
raise 'acts_as_purchasable object requires the seller be defined to return the User selling this item. This is only a requirement when using StripeConnect.'
end
end
|
#sold_out? ⇒ Boolean
112
113
114
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 112
def sold_out?
quantity_enabled? ? (quantity_remaining == 0) : false
end
|
#tax_exempt ⇒ Object
74
75
76
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 74
def tax_exempt
self[:tax_exempt] || false
end
|
#title ⇒ Object
70
71
72
|
# File 'app/models/concerns/acts_as_purchasable.rb', line 70
def title
self[:title] || to_s
end
|