2012-06-21 17:19:00 +02:00
|
|
|
class Finance::GroupOrderArticlesController < ApplicationController
|
|
|
|
|
|
|
|
before_filter :authenticate_finance
|
|
|
|
|
|
|
|
layout false # We only use this controller to server js snippets, no need for layout rendering
|
|
|
|
|
|
|
|
def new
|
|
|
|
@order_article = OrderArticle.find(params[:order_article_id])
|
2012-07-27 18:03:46 +02:00
|
|
|
@group_order_article = GroupOrderArticle.new(order_article: @order_article)
|
|
|
|
end
|
|
|
|
|
|
|
|
def create
|
|
|
|
@group_order_article = GroupOrderArticle.new(params[:group_order_article])
|
|
|
|
@order_article = @group_order_article.order_article
|
|
|
|
|
|
|
|
# As we hide group_order_articles with a result of 0, we should not complain, when an existing group_order_article is found
|
|
|
|
goa = GroupOrderArticle.where(group_order_id: @group_order_article.group_order_id,
|
|
|
|
order_article_id: @order_article.id).first
|
|
|
|
|
|
|
|
if goa and goa.update_attributes(params[:group_order_article])
|
|
|
|
@group_order_article = goa
|
|
|
|
|
|
|
|
update_summaries(@group_order_article)
|
|
|
|
render :update
|
|
|
|
|
|
|
|
elsif @group_order_article.save
|
|
|
|
update_summaries(@group_order_article)
|
|
|
|
render :update
|
|
|
|
|
|
|
|
else # Validation failed, show form
|
|
|
|
render :new
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def edit
|
|
|
|
@group_order_article = GroupOrderArticle.find(params[:id])
|
|
|
|
@order_article = @group_order_article.order_article
|
|
|
|
end
|
|
|
|
|
|
|
|
def update
|
|
|
|
@group_order_article = GroupOrderArticle.find(params[:id])
|
|
|
|
@order_article = @group_order_article.order_article
|
|
|
|
|
|
|
|
if @group_order_article.update_attributes(params[:group_order_article])
|
|
|
|
update_summaries(@group_order_article)
|
|
|
|
else
|
|
|
|
render :edit
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def update_result
|
|
|
|
group_order_article = GroupOrderArticle.find(params[:id])
|
|
|
|
@order_article = group_order_article.order_article
|
|
|
|
|
|
|
|
if params[:modifier] == '-'
|
|
|
|
group_order_article.update_attribute :result, group_order_article.result - 1
|
|
|
|
elsif params[:modifier] == '+'
|
|
|
|
group_order_article.update_attribute :result, group_order_article.result + 1
|
|
|
|
end
|
|
|
|
|
|
|
|
update_summaries(group_order_article)
|
|
|
|
|
|
|
|
render :update
|
|
|
|
end
|
|
|
|
|
|
|
|
def destroy
|
|
|
|
group_order_article = GroupOrderArticle.find(params[:id])
|
2013-09-17 14:19:46 +02:00
|
|
|
# only destroy if quantity and tolerance was zero already, so that we don't
|
|
|
|
# lose what the user ordered, if any
|
|
|
|
if group_order_article.quantity > 0 or group_order_article.tolerance >0
|
|
|
|
group_order_article.update_attribute(:result, 0)
|
|
|
|
else
|
|
|
|
group_order_article.destroy
|
|
|
|
end
|
2012-07-27 18:03:46 +02:00
|
|
|
update_summaries(group_order_article)
|
|
|
|
@order_article = group_order_article.order_article
|
|
|
|
|
|
|
|
render :update
|
|
|
|
end
|
|
|
|
|
|
|
|
protected
|
|
|
|
|
|
|
|
def update_summaries(group_order_article)
|
|
|
|
# Update the price attribute of new GroupOrder
|
|
|
|
group_order_article.group_order.update_price!
|
|
|
|
# Update units_to_order of order_article
|
|
|
|
group_order_article.order_article.update_results! if group_order_article.order_article.article.is_a?(StockArticle)
|
2012-06-21 17:19:00 +02:00
|
|
|
end
|
|
|
|
end
|