2009-01-14 12:46:01 +01:00
|
|
|
# A GroupOrder represents an Order placed by an Ordergroup.
|
2009-01-06 11:49:19 +01:00
|
|
|
class GroupOrder < ActiveRecord::Base
|
2011-06-19 15:30:33 +02:00
|
|
|
|
|
|
|
attr_accessor :group_order_articles_attributes
|
|
|
|
|
2009-01-06 11:49:19 +01:00
|
|
|
belongs_to :order
|
2013-03-10 19:39:59 +01:00
|
|
|
belongs_to :ordergroup, :with_deleted => true
|
2009-01-06 11:49:19 +01:00
|
|
|
has_many :group_order_articles, :dependent => :destroy
|
|
|
|
has_many :order_articles, :through => :group_order_articles
|
|
|
|
belongs_to :updated_by, :class_name => "User", :foreign_key => "updated_by_user_id"
|
|
|
|
|
|
|
|
validates_presence_of :order_id
|
2009-01-14 12:46:01 +01:00
|
|
|
validates_presence_of :ordergroup_id
|
2009-01-06 11:49:19 +01:00
|
|
|
validates_numericality_of :price
|
2009-01-14 12:46:01 +01:00
|
|
|
validates_uniqueness_of :ordergroup_id, :scope => :order_id # order groups can only order once per order
|
2009-01-06 11:49:19 +01:00
|
|
|
|
2012-09-30 21:15:55 +02:00
|
|
|
scope :in_open_orders, joins(:order).merge(Order.open)
|
|
|
|
scope :in_finished_orders, joins(:order).merge(Order.finished_not_closed)
|
2011-06-19 15:30:33 +02:00
|
|
|
|
|
|
|
# Generate some data for the javascript methods in ordering view
|
|
|
|
def load_data
|
|
|
|
data = {}
|
|
|
|
data[:available_funds] = ordergroup.get_available_funds(self)
|
|
|
|
|
2011-06-19 19:56:04 +02:00
|
|
|
# load prices and other stuff....
|
2011-06-19 15:30:33 +02:00
|
|
|
data[:order_articles] = {}
|
2013-01-26 15:18:35 +01:00
|
|
|
order.articles_grouped_by_category.each do |article_category, order_articles|
|
|
|
|
order_articles.each do |order_article|
|
2013-03-12 11:26:14 +01:00
|
|
|
|
|
|
|
# Get the result of last time ordering, if possible
|
|
|
|
goa = group_order_articles.detect { |goa| goa.order_article_id == order_article.id }
|
|
|
|
|
|
|
|
# Build hash with relevant data
|
2013-01-26 15:18:35 +01:00
|
|
|
data[:order_articles][order_article.id] = {
|
|
|
|
:price => order_article.article.fc_price,
|
|
|
|
:unit => order_article.article.unit_quantity,
|
2013-03-12 11:26:14 +01:00
|
|
|
:quantity => (goa ? goa.quantity : 0),
|
|
|
|
:others_quantity => order_article.quantity - (goa ? goa.quantity : 0),
|
|
|
|
:used_quantity => (goa ? goa.result(:quantity) : 0),
|
|
|
|
:tolerance => (goa ? goa.result(:tolerance) : 0),
|
|
|
|
:others_tolerance => order_article.tolerance - (goa ? goa.result(:tolerance) : 0),
|
|
|
|
:used_tolerance => (goa ? goa.result(:tolerance) : 0),
|
|
|
|
:total_price => (goa ? goa.total_price : 0),
|
2013-01-26 15:18:35 +01:00
|
|
|
:missing_units => order_article.missing_units,
|
|
|
|
:quantity_available => (order.stockit? ? order_article.article.quantity_available : 0)
|
|
|
|
}
|
|
|
|
end
|
2011-06-19 15:30:33 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
data
|
|
|
|
end
|
|
|
|
|
|
|
|
def save_group_order_articles
|
|
|
|
for order_article in order.order_articles
|
|
|
|
# Find the group_order_article, create a new one if necessary...
|
|
|
|
group_order_article = group_order_articles.find_or_create_by_order_article_id(order_article.id)
|
|
|
|
|
|
|
|
# Get ordered quantities and update group_order_articles/_quantities...
|
|
|
|
quantities = group_order_articles_attributes.fetch(order_article.id.to_s, {:quantity => 0, :tolerance => 0})
|
|
|
|
group_order_article.update_quantities(quantities[:quantity].to_i, quantities[:tolerance].to_i)
|
|
|
|
|
|
|
|
# Also update results for the order_article
|
|
|
|
logger.debug "[save_group_order_articles] update order_article.results!"
|
|
|
|
order_article.update_results!
|
|
|
|
end
|
|
|
|
|
|
|
|
# set attributes to nil to avoid and infinite loop of
|
|
|
|
end
|
|
|
|
|
|
|
|
# Updates the "price" attribute.
|
|
|
|
def update_price!
|
2012-12-16 21:46:24 +01:00
|
|
|
total = group_order_articles.includes(:order_article => [:article, :article_price]).to_a.sum(&:total_price)
|
2009-01-29 01:57:51 +01:00
|
|
|
update_attribute(:price, total)
|
2009-01-06 11:49:19 +01:00
|
|
|
end
|
|
|
|
|
2011-06-19 15:30:33 +02:00
|
|
|
|
|
|
|
# Save GroupOrder and updates group_order_articles/quantities accordingly
|
|
|
|
def save_ordering!
|
|
|
|
transaction do
|
|
|
|
save!
|
|
|
|
save_group_order_articles
|
|
|
|
update_price!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2009-01-06 11:49:19 +01:00
|
|
|
end
|
2011-05-07 21:55:24 +02:00
|
|
|
|