1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-22 11:52:21 +01:00
fab-manager/app/controllers/api/events_controller.rb

104 lines
3.8 KiB
Ruby
Raw Normal View History

2019-01-17 09:53:28 +01:00
# frozen_string_literal: true
# API Controller for resources of type Event
2015-05-05 03:10:25 +02:00
class API::EventsController < API::ApiController
2019-01-17 09:53:28 +01:00
before_action :set_event, only: %i[show update destroy]
2015-05-05 03:10:25 +02:00
def index
@events = policy_scope(Event)
@page = params[:page]
2017-09-25 15:48:21 +02:00
@scope = params[:scope]
# filters
2016-08-11 11:07:49 +02:00
@events = @events.joins(:category).where('categories.id = :category', category: params[:category_id]) if params[:category_id]
@events = @events.joins(:event_themes).where('event_themes.id = :theme', theme: params[:theme_id]) if params[:theme_id]
@events = @events.where('age_range_id = :age_range', age_range: params[:age_range_id]) if params[:age_range_id]
2019-01-17 09:53:28 +01:00
if current_user&.admin?
@events = case params[:scope]
when 'future'
@events.where('availabilities.start_at >= ?', DateTime.current).order('availabilities.start_at DESC')
2019-01-17 09:53:28 +01:00
when 'future_asc'
@events.where('availabilities.start_at >= ?', DateTime.current).order('availabilities.start_at ASC')
2019-01-17 09:53:28 +01:00
when 'passed'
@events.where('availabilities.start_at < ?', DateTime.current).order('availabilities.start_at DESC')
2019-01-17 09:53:28 +01:00
else
@events.order('availabilities.start_at DESC')
end
2017-09-25 15:48:21 +02:00
end
# paginate
@events = @events.page(@page).per(12)
2015-05-05 03:10:25 +02:00
end
# GET /events/upcoming/:limit
def upcoming
limit = params[:limit]
@events = Event.includes(:event_image, :event_files, :availability, :category)
.where('events.nb_total_places != -1 OR events.nb_total_places IS NULL')
.where('availabilities.start_at >= ?', DateTime.current)
.order('availabilities.start_at ASC').references(:availabilities)
.limit(limit)
2015-05-05 03:10:25 +02:00
end
2019-01-17 09:53:28 +01:00
def show; end
2015-05-05 03:10:25 +02:00
def create
authorize Event
@event = Event.new(event_params.permit!)
if @event.save
render :show, status: :created, location: @event
else
render json: @event.errors, status: :unprocessable_entity
end
end
def update
authorize Event
begin
if @event.update(event_params.permit!)
render :show, status: :ok, location: @event
else
render json: @event.errors, status: :unprocessable_entity
end
rescue ActiveRecord::RecordNotDestroyed => e
if e.record.class.name == 'EventPriceCategory'
2019-01-17 09:53:28 +01:00
render json: { error: ["#{e.record.price_category.name}: #{t('events.error_deleting_reserved_price')}"] },
status: :unprocessable_entity
else
2019-01-17 09:53:28 +01:00
render json: { error: [t('events.other_error')] }, status: :unprocessable_entity
end
2015-05-05 03:10:25 +02:00
end
2015-05-05 03:10:25 +02:00
end
def destroy
authorize Event
2016-03-23 18:39:41 +01:00
if @event.safe_destroy
2015-05-05 03:10:25 +02:00
head :no_content
else
head :unprocessable_entity
end
end
private
2019-01-17 09:53:28 +01:00
# Use callbacks to share common setup or constraints between actions.
def set_event
@event = Event.find(params[:id])
end
2015-05-05 03:10:25 +02:00
2019-01-17 09:53:28 +01:00
# Never trust parameters from the scary internet, only allow the white list through.
def event_params
# handle general properties
event_preparams = params.required(:event).permit(:title, :description, :start_date, :start_time, :end_date, :end_time,
:amount, :nb_total_places, :availability_id, :all_day, :recurrence,
:recurrence_end_at, :category_id, :event_theme_ids, :age_range_id,
event_theme_ids: [],
event_image_attributes: [:attachment],
event_files_attributes: %i[id attachment _destroy],
2019-01-21 11:26:42 +01:00
event_price_categories_attributes: %i[id price_category_id amount _destroy])
2019-01-17 09:53:28 +01:00
EventService.process_params(event_preparams)
end
2015-05-05 03:10:25 +02:00
end