tap/app/controllers/orders_controller.rb

82 lines
2.2 KiB
Ruby
Raw Normal View History

2014-11-06 17:56:00 +00:00
class OrdersController < ApplicationController
2015-02-12 13:39:58 +00:00
include ActionView::Helpers::NumberHelper
2015-04-03 23:44:28 +00:00
include ApplicationHelper
2015-02-12 13:39:58 +00:00
2015-01-06 19:18:01 +00:00
load_and_authorize_resource
2014-11-25 14:27:12 +00:00
def new
init
2015-02-12 13:39:58 +00:00
@order = @user.orders.build
products = (@user.products.for_sale.select("products.*", "sum(order_items.count) as count").group(:product_id).order("count desc") | Product.for_sale)
2015-07-01 21:51:26 +00:00
@order.g_order_items products
2014-11-06 17:56:00 +00:00
end
def create
init
@order = @user.orders.build order_params
2014-12-04 18:28:21 +00:00
if @order.save
2015-04-03 23:44:28 +00:00
message = "#{@order.to_sentence} ordered. Enjoy it!"
flash[:success] = message
slack_notification(@user, message)
2014-12-04 18:28:21 +00:00
redirect_to root_path
else
@order.g_order_items Product.for_sale
2014-12-04 18:28:21 +00:00
render 'new'
2014-11-25 14:27:12 +00:00
end
2014-11-23 20:12:31 +00:00
end
def destroy
order = Order.find(params[:id])
if order.created_at > 5.minutes.ago
2015-03-10 10:37:48 +00:00
order.cancel
flash[:success] = "Order has been removed."
else
flash[:error] = "This order has been placed too long ago, it can't be removed. Please contact a sysadmin."
end
2015-02-12 13:39:58 +00:00
redirect_to root_path
end
def overview
2015-06-30 20:30:34 +00:00
@users = User.members.publik.order(:uid)
2014-12-06 11:03:08 +00:00
end
def quickpay
user = User.find(params[:user_id])
order = user.orders.build
2015-02-10 07:33:51 +00:00
order.order_items << OrderItem.new(count: 1, product: user.dagschotel, order: order)
if order.save
flash[:success] = "Quick pay succeeded. #{view_context.link_to("Undo", [user, order], method: :delete)}."
else
flash[:error] = order.errors.full_messages.first
end
redirect_to root_path
end
2014-11-10 01:30:42 +00:00
private
def init
@user = User.find(params[:user_id])
if @user.koelkast?
flash[:error] = "Koelkast can't order things."
redirect_to root_path
end
2015-06-30 20:30:34 +00:00
if @user.private && current_user != @user
flash[:error] = "You can't order stuff for this person."
redirect_to root_path
end
2015-03-19 13:59:37 +00:00
unless current_user.koelkast? || current_user.admin? || current_user == @user
flash[:error] = "Please don't order stuff for other people"
redirect_to root_path
end
end
2014-11-10 01:30:42 +00:00
def order_params
2015-03-10 10:37:48 +00:00
params.require(:order).permit(order_items_attributes: [:count, :price, product_attributes: [:id]])
2014-11-10 01:30:42 +00:00
end
2014-11-06 17:56:00 +00:00
end