app/controllers/accepts_controller.rb
class AcceptsController < ApplicationController
before_action :set_accept, only: [:show, :edit, :update, :destroy]
before_action :check_policy, only: [:index, :new, :create]
before_action :get_basket, only: [:index, :create]
# GET /accepts
# GET /accepts.json
def index
if request.format.text?
@accepts = Accept.order('accepts.created_at DESC').page(params[:page]).per(65534)
else
if params[:accept]
@query = params[:accept][:item_identifier].to_s.strip
item = Item.where(item_identifier: @query).first if @query.present?
end
if item
@accepts = Accept.order('accepts.created_at DESC').where(item_id: item.id).page(params[:page])
elsif @basket
@accepts = @basket.accepts.order('accepts.created_at DESC').page(params[:page])
else
@accepts = Accept.order('accepts.created_at DESC').page(params[:page])
end
end
respond_to do |format|
format.html # index.html.erb
format.js { @accept = Accept.new }
format.text
end
end
# GET /accepts/1
# GET /accepts/1.json
def show
respond_to do |format|
format.html # show.html.erb
end
end
# GET /new
def new
@basket = Basket.new
@basket.user = current_user
@basket.save!
@accept = Accept.new
@accepts = []
end
# GET /accepts/new
# GET /accepts/1/edit
def edit
end
# POST /accepts
# POST /accepts.json
def create
unless @basket
access_denied
return
end
@accept = Accept.new(accept_params)
@accept.basket = @basket
@accept.librarian = current_user
flash[:message] = ''
if @accept.item_identifier.blank?
flash[:message] << t('accept.enter_item_identifier') if @accept.item_identifier.blank?
else
item = Item.where(item_identifier: @accept.item_identifier.to_s.strip).first
end
@accept.item = item
respond_to do |format|
if @accept.save
flash[:message] << t('accept.successfully_accepted', model: t('activerecord.models.accept'))
format.html { redirect_to accepts_url(basket_id: @basket.id) }
format.json { render json: @accept, status: :created, location: @accept }
format.js { redirect_to accepts_url(basket_id: @basket.id, format: :js) }
else
@accepts = @basket.accepts.page(params[:page])
format.html { render action: "index" }
format.json { render json: @accept.errors, status: :unprocessable_entity }
format.js { render action: "index" }
end
end
end
# PUT /accepts/1
# PUT /accepts/1.json
def update
respond_to do |format|
if @accept.update(accept_params)
format.html { redirect_to @accept, notice: t('controller.successfully_updated', model: t('activerecord.models.accept')) }
format.json { head :no_content }
else
format.html { render action: "edit" }
format.json { render json: @accept.errors, status: :unprocessable_entity }
end
end
end
# DELETE /accepts/1
# DELETE /accepts/1.json
def destroy
@accept.destroy
respond_to do |format|
format.html { redirect_to accepts_url, notice: t('controller.successfully_deleted', model: t('activerecord.models.accept')) }
format.json { head :no_content }
end
end
private
def set_accept
@accept = Accept.find(params[:id])
authorize @accept
end
def check_policy
authorize Accept
end
def accept_params
params.require(:accept).permit(:item_identifier, :librarian_id, :item_id)
end
end