2016-03-23 18:39:41 +01:00
|
|
|
class API::AvailabilitiesController < API::ApiController
|
2017-02-15 15:41:25 +01:00
|
|
|
include FablabConfiguration
|
|
|
|
|
2016-06-29 17:37:22 +02:00
|
|
|
before_action :authenticate_user!, except: [:public]
|
2017-09-06 15:01:41 +02:00
|
|
|
before_action :set_availability, only: [:show, :update, :destroy, :reservations, :lock]
|
2017-08-24 18:34:18 +02:00
|
|
|
before_action :define_max_visibility, only: [:machine, :trainings, :spaces]
|
2016-03-23 18:39:41 +01:00
|
|
|
respond_to :json
|
|
|
|
|
|
|
|
def index
|
|
|
|
authorize Availability
|
2016-07-13 19:09:07 +02:00
|
|
|
start_date = ActiveSupport::TimeZone[params[:timezone]].parse(params[:start])
|
|
|
|
end_date = ActiveSupport::TimeZone[params[:timezone]].parse(params[:end]).end_of_day
|
2017-02-15 13:18:03 +01:00
|
|
|
@availabilities = Availability.includes(:machines, :tags, :trainings, :spaces).where.not(available_type: 'event')
|
2016-07-13 19:09:07 +02:00
|
|
|
.where('start_at >= ? AND end_at <= ?', start_date, end_date)
|
2017-02-15 15:41:25 +01:00
|
|
|
|
|
|
|
if fablab_spaces_deactivated?
|
|
|
|
@availabilities = @availabilities.where.not(available_type: 'space')
|
|
|
|
end
|
2016-03-23 18:39:41 +01:00
|
|
|
end
|
|
|
|
|
2016-07-13 19:12:16 +02:00
|
|
|
def public
|
|
|
|
start_date = ActiveSupport::TimeZone[params[:timezone]].parse(params[:start])
|
|
|
|
end_date = ActiveSupport::TimeZone[params[:timezone]].parse(params[:end]).end_of_day
|
2017-09-06 17:10:10 +02:00
|
|
|
@reservations = Reservation.includes(:slots, user: [:profile]).references(:slots, :user)
|
|
|
|
.where('slots.start_at >= ? AND slots.end_at <= ?', start_date, end_date)
|
2017-02-28 11:59:48 +01:00
|
|
|
|
|
|
|
# request for 1 single day
|
2016-06-28 18:58:44 +02:00
|
|
|
if in_same_day(start_date, end_date)
|
2017-02-28 11:59:48 +01:00
|
|
|
# trainings, events
|
|
|
|
@training_and_event_availabilities = Availability.includes(:tags, :trainings, :event, :slots).where(available_type: %w(training event))
|
2016-06-28 18:58:44 +02:00
|
|
|
.where('start_at >= ? AND end_at <= ?', start_date, end_date)
|
2017-09-06 17:10:10 +02:00
|
|
|
.where(lock: false)
|
2017-02-28 11:59:48 +01:00
|
|
|
# machines
|
2016-07-14 18:36:52 +02:00
|
|
|
@machine_availabilities = Availability.includes(:tags, :machines).where(available_type: 'machines')
|
2016-06-28 18:58:44 +02:00
|
|
|
.where('start_at >= ? AND end_at <= ?', start_date, end_date)
|
2017-09-06 17:10:10 +02:00
|
|
|
.where(lock: false)
|
2016-06-28 18:58:44 +02:00
|
|
|
@machine_slots = []
|
|
|
|
@machine_availabilities.each do |a|
|
|
|
|
a.machines.each do |machine|
|
2016-07-14 18:36:52 +02:00
|
|
|
if params[:m] and params[:m].include?(machine.id.to_s)
|
2017-03-13 10:21:41 +01:00
|
|
|
((a.end_at - a.start_at)/ApplicationHelper::SLOT_DURATION.minutes).to_i.times do |i|
|
2017-09-06 17:10:10 +02:00
|
|
|
slot = Slot.new(
|
|
|
|
start_at: a.start_at + (i*ApplicationHelper::SLOT_DURATION).minutes,
|
|
|
|
end_at: a.start_at + (i*ApplicationHelper::SLOT_DURATION).minutes + ApplicationHelper::SLOT_DURATION.minutes,
|
|
|
|
availability_id: a.id,
|
|
|
|
availability: a,
|
|
|
|
machine: machine,
|
|
|
|
title: machine.name
|
|
|
|
)
|
2016-07-14 18:36:52 +02:00
|
|
|
slot = verify_machine_is_reserved(slot, @reservations, current_user, '')
|
|
|
|
@machine_slots << slot
|
|
|
|
end
|
2016-06-28 18:58:44 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-02-28 11:59:48 +01:00
|
|
|
|
|
|
|
# spaces
|
|
|
|
@space_availabilities = Availability.includes(:tags, :spaces).where(available_type: 'space')
|
|
|
|
.where('start_at >= ? AND end_at <= ?', start_date, end_date)
|
2017-09-06 17:10:10 +02:00
|
|
|
.where(lock: false)
|
2017-02-28 17:17:43 +01:00
|
|
|
|
|
|
|
if params[:s]
|
|
|
|
@space_availabilities.where(available_id: params[:s])
|
|
|
|
end
|
|
|
|
|
2017-02-28 11:59:48 +01:00
|
|
|
@space_slots = []
|
|
|
|
@space_availabilities.each do |a|
|
|
|
|
space = a.spaces.first
|
2017-03-13 10:21:41 +01:00
|
|
|
((a.end_at - a.start_at)/ApplicationHelper::SLOT_DURATION.minutes).to_i.times do |i|
|
|
|
|
if (a.start_at + (i * ApplicationHelper::SLOT_DURATION).minutes) > Time.now
|
2017-09-06 17:10:10 +02:00
|
|
|
slot = Slot.new(
|
|
|
|
start_at: a.start_at + (i*ApplicationHelper::SLOT_DURATION).minutes,
|
|
|
|
end_at: a.start_at + (i*ApplicationHelper::SLOT_DURATION).minutes + ApplicationHelper::SLOT_DURATION.minutes,
|
|
|
|
availability_id: a.id,
|
|
|
|
availability: a,
|
|
|
|
space: space,
|
|
|
|
title: space.name
|
|
|
|
)
|
2017-02-28 11:59:48 +01:00
|
|
|
slot = verify_space_is_reserved(slot, @reservations, current_user, '')
|
|
|
|
@space_slots << slot
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
@availabilities = [].concat(@training_and_event_availabilities).concat(@machine_slots).concat(@space_slots)
|
|
|
|
|
|
|
|
# request for many days (week or month)
|
2016-06-28 18:58:44 +02:00
|
|
|
else
|
2017-02-28 11:59:48 +01:00
|
|
|
@availabilities = Availability.includes(:tags, :machines, :trainings, :spaces, :event, :slots)
|
2016-06-28 18:58:44 +02:00
|
|
|
.where('start_at >= ? AND end_at <= ?', start_date, end_date)
|
2017-09-06 17:10:10 +02:00
|
|
|
.where(lock: false)
|
2016-06-29 17:37:22 +02:00
|
|
|
@availabilities.each do |a|
|
2017-02-28 16:51:56 +01:00
|
|
|
if a.available_type == 'training' or a.available_type == 'event'
|
2017-02-22 17:29:35 +01:00
|
|
|
a = verify_training_event_is_reserved(a, @reservations, current_user)
|
2017-02-28 16:51:56 +01:00
|
|
|
elsif a.available_type == 'space'
|
2017-09-07 11:44:50 +02:00
|
|
|
a.is_reserved = is_reserved_availability(a, current_user)
|
2016-07-14 18:36:52 +02:00
|
|
|
end
|
2016-06-29 17:37:22 +02:00
|
|
|
end
|
2016-06-28 18:58:44 +02:00
|
|
|
end
|
2016-07-14 18:36:52 +02:00
|
|
|
machine_ids = params[:m] || []
|
|
|
|
@title_filter = {machine_ids: machine_ids.map(&:to_i)}
|
|
|
|
@availabilities = filter_availabilites(@availabilities)
|
2016-07-13 19:12:16 +02:00
|
|
|
end
|
|
|
|
|
2016-03-23 18:39:41 +01:00
|
|
|
def show
|
|
|
|
authorize Availability
|
|
|
|
end
|
|
|
|
|
|
|
|
def create
|
|
|
|
authorize Availability
|
|
|
|
@availability = Availability.new(availability_params)
|
|
|
|
if @availability.save
|
|
|
|
render :show, status: :created, location: @availability
|
|
|
|
else
|
|
|
|
render json: @availability.errors, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def update
|
|
|
|
authorize Availability
|
|
|
|
if @availability.update(availability_params)
|
|
|
|
render :show, status: :ok, location: @availability
|
|
|
|
else
|
|
|
|
render json: @availability.errors, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def destroy
|
|
|
|
authorize Availability
|
|
|
|
if @availability.safe_destroy
|
|
|
|
head :no_content
|
|
|
|
else
|
|
|
|
head :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def machine
|
|
|
|
if params[:member_id]
|
|
|
|
@user = User.find(params[:member_id])
|
|
|
|
else
|
|
|
|
@user = current_user
|
|
|
|
end
|
2016-06-22 12:54:12 +02:00
|
|
|
@current_user_role = current_user.is_admin? ? 'admin' : 'user'
|
2017-02-21 15:41:45 +01:00
|
|
|
@machine = Machine.friendly.find(params[:machine_id])
|
2016-03-23 18:39:41 +01:00
|
|
|
@slots = []
|
2016-06-22 12:54:12 +02:00
|
|
|
@reservations = Reservation.where('reservable_type = ? and reservable_id = ?', @machine.class.to_s, @machine.id).includes(:slots, user: [:profile]).references(:slots, :user).where('slots.start_at > ?', Time.now)
|
2016-03-23 18:39:41 +01:00
|
|
|
if @user.is_admin?
|
2017-09-06 17:10:10 +02:00
|
|
|
@availabilities = @machine.availabilities.includes(:tags)
|
|
|
|
.where("end_at > ? AND available_type = 'machines'", Time.now)
|
|
|
|
.where(lock: false)
|
2016-03-23 18:39:41 +01:00
|
|
|
else
|
2017-08-24 18:34:18 +02:00
|
|
|
end_at = @visi_max_other
|
|
|
|
end_at = @visi_max_year if is_subscription_year(@user)
|
2017-09-06 17:10:10 +02:00
|
|
|
@availabilities = @machine.availabilities.includes(:tags).where("end_at > ? AND end_at < ? AND available_type = 'machines'", Time.now, end_at)
|
|
|
|
.where('availability_tags.tag_id' => @user.tag_ids.concat([nil]))
|
|
|
|
.where(lock: false)
|
2016-03-23 18:39:41 +01:00
|
|
|
end
|
|
|
|
@availabilities.each do |a|
|
2017-03-13 10:21:41 +01:00
|
|
|
((a.end_at - a.start_at)/ApplicationHelper::SLOT_DURATION.minutes).to_i.times do |i|
|
|
|
|
if (a.start_at + (i * ApplicationHelper::SLOT_DURATION).minutes) > Time.now
|
2017-09-06 17:10:10 +02:00
|
|
|
slot = Slot.new(
|
|
|
|
start_at: a.start_at + (i*ApplicationHelper::SLOT_DURATION).minutes,
|
|
|
|
end_at: a.start_at + (i*ApplicationHelper::SLOT_DURATION).minutes + ApplicationHelper::SLOT_DURATION.minutes,
|
|
|
|
availability_id: a.id,
|
|
|
|
availability: a,
|
|
|
|
machine: @machine,
|
|
|
|
title: ''
|
|
|
|
)
|
2016-06-22 12:54:12 +02:00
|
|
|
slot = verify_machine_is_reserved(slot, @reservations, current_user, @current_user_role)
|
2016-03-23 18:39:41 +01:00
|
|
|
@slots << slot
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def trainings
|
|
|
|
if params[:member_id]
|
|
|
|
@user = User.find(params[:member_id])
|
|
|
|
else
|
|
|
|
@user = current_user
|
|
|
|
end
|
|
|
|
@slots = []
|
2016-07-13 18:15:14 +02:00
|
|
|
|
|
|
|
# first, we get the already-made reservations
|
|
|
|
@reservations = @user.reservations.where("reservable_type = 'Training'")
|
|
|
|
@reservations = @reservations.where('reservable_id = :id', id: params[:training_id].to_i) if params[:training_id].is_number?
|
|
|
|
@reservations = @reservations.joins(:slots).where('slots.start_at > ?', Time.now)
|
|
|
|
|
|
|
|
# what is requested?
|
|
|
|
# 1) a single training
|
2016-11-29 15:48:39 +01:00
|
|
|
if params[:training_id].is_number? or (params[:training_id].length > 0 and params[:training_id] != 'all')
|
|
|
|
@availabilities = Training.friendly.find(params[:training_id]).availabilities
|
2016-07-13 18:15:14 +02:00
|
|
|
# 2) all trainings
|
|
|
|
else
|
|
|
|
@availabilities = Availability.trainings
|
|
|
|
end
|
|
|
|
|
|
|
|
# who made the request?
|
|
|
|
# 1) an admin (he can see all future availabilities)
|
2017-02-22 17:29:35 +01:00
|
|
|
if current_user.is_admin?
|
2017-09-06 17:10:10 +02:00
|
|
|
@availabilities = @availabilities.includes(:tags, :slots, trainings: [:machines])
|
|
|
|
.where('availabilities.start_at > ?', Time.now)
|
|
|
|
.where(lock: false)
|
2016-07-13 18:15:14 +02:00
|
|
|
# 2) an user (he cannot see availabilities further than 1 (or 3) months)
|
2016-03-23 18:39:41 +01:00
|
|
|
else
|
2017-08-24 18:34:18 +02:00
|
|
|
end_at = @visi_max_year
|
|
|
|
end_at = @visi_max_year if can_show_slot_plus_three_months(@user)
|
2017-09-06 17:10:10 +02:00
|
|
|
@availabilities = @availabilities.includes(:tags, :slots, :availability_tags, trainings: [:machines])
|
|
|
|
.where('availabilities.start_at > ? AND availabilities.start_at < ?', Time.now, end_at)
|
|
|
|
.where('availability_tags.tag_id' => @user.tag_ids.concat([nil]))
|
|
|
|
.where(lock: false)
|
2016-03-23 18:39:41 +01:00
|
|
|
end
|
2016-07-13 18:15:14 +02:00
|
|
|
|
|
|
|
# finally, we merge the availabilities with the reservations
|
2016-03-23 18:39:41 +01:00
|
|
|
@availabilities.each do |a|
|
2017-02-22 17:29:35 +01:00
|
|
|
a = verify_training_event_is_reserved(a, @reservations, @user)
|
2016-03-23 18:39:41 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-02-23 17:45:55 +01:00
|
|
|
def spaces
|
|
|
|
if params[:member_id]
|
|
|
|
@user = User.find(params[:member_id])
|
|
|
|
else
|
|
|
|
@user = current_user
|
|
|
|
end
|
|
|
|
@current_user_role = current_user.is_admin? ? 'admin' : 'user'
|
|
|
|
@space = Space.friendly.find(params[:space_id])
|
|
|
|
@slots = []
|
2017-09-06 17:10:10 +02:00
|
|
|
@reservations = Reservation.where('reservable_type = ? and reservable_id = ?', @space.class.to_s, @space.id)
|
|
|
|
.includes(:slots, user: [:profile]).references(:slots, :user)
|
|
|
|
.where('slots.start_at > ?', Time.now)
|
2017-08-24 16:53:27 +02:00
|
|
|
if current_user.is_admin?
|
2017-09-06 17:10:10 +02:00
|
|
|
@availabilities = @space.availabilities.includes(:tags)
|
|
|
|
.where("end_at > ? AND available_type = 'space'", Time.now)
|
|
|
|
.where(lock: false)
|
2017-02-23 17:45:55 +01:00
|
|
|
else
|
2017-08-24 18:34:18 +02:00
|
|
|
end_at = @visi_max_other
|
|
|
|
end_at = @visi_max_year if is_subscription_year(@user)
|
2017-09-06 17:10:10 +02:00
|
|
|
@availabilities = @space.availabilities.includes(:tags)
|
|
|
|
.where("end_at > ? AND end_at < ? AND available_type = 'space'", Time.now, end_at)
|
|
|
|
.where('availability_tags.tag_id' => @user.tag_ids.concat([nil]))
|
|
|
|
.where(lock: false)
|
2017-02-23 17:45:55 +01:00
|
|
|
end
|
|
|
|
@availabilities.each do |a|
|
2017-03-13 10:21:41 +01:00
|
|
|
((a.end_at - a.start_at)/ApplicationHelper::SLOT_DURATION.minutes).to_i.times do |i|
|
|
|
|
if (a.start_at + (i * ApplicationHelper::SLOT_DURATION).minutes) > Time.now
|
2017-09-06 17:10:10 +02:00
|
|
|
slot = Slot.new(
|
|
|
|
start_at: a.start_at + (i*ApplicationHelper::SLOT_DURATION).minutes,
|
|
|
|
end_at: a.start_at + (i*ApplicationHelper::SLOT_DURATION).minutes + ApplicationHelper::SLOT_DURATION.minutes,
|
|
|
|
availability_id: a.id,
|
|
|
|
availability: a,
|
|
|
|
space: @space,
|
|
|
|
title: ''
|
|
|
|
)
|
2017-02-27 13:48:35 +01:00
|
|
|
slot = verify_space_is_reserved(slot, @reservations, @user, @current_user_role)
|
2017-02-23 17:45:55 +01:00
|
|
|
@slots << slot
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-02-27 16:15:27 +01:00
|
|
|
@slots.each do |s|
|
2017-02-27 16:35:41 +01:00
|
|
|
if s.is_complete? and not s.is_reserved
|
2017-02-27 16:15:27 +01:00
|
|
|
s.title = t('availabilities.not_available')
|
|
|
|
end
|
|
|
|
end
|
2017-02-23 17:45:55 +01:00
|
|
|
end
|
|
|
|
|
2016-03-23 18:39:41 +01:00
|
|
|
def reservations
|
|
|
|
authorize Availability
|
2017-02-27 16:43:39 +01:00
|
|
|
@reservation_slots = @availability.slots.includes(reservations: [user: [:profile]]).order('slots.start_at ASC')
|
2016-03-23 18:39:41 +01:00
|
|
|
end
|
|
|
|
|
2017-03-02 12:34:28 +01:00
|
|
|
def export_availabilities
|
|
|
|
authorize :export
|
|
|
|
|
|
|
|
export = Export.where({category:'availabilities', export_type: 'index'}).where('created_at > ?', Availability.maximum('updated_at')).last
|
|
|
|
if export.nil? || !FileTest.exist?(export.file)
|
|
|
|
@export = Export.new({category:'availabilities', export_type: 'index', user: current_user})
|
|
|
|
if @export.save
|
|
|
|
render json: {export_id: @export.id}, status: :ok
|
|
|
|
else
|
|
|
|
render json: @export.errors, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
else
|
|
|
|
send_file File.join(Rails.root, export.file), :type => 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet', :disposition => 'attachment'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-09-06 15:01:41 +02:00
|
|
|
def lock
|
|
|
|
authorize @availability
|
|
|
|
if @availability.update_attributes(lock: lock_params)
|
|
|
|
render :show, status: :ok, location: @availability
|
|
|
|
else
|
|
|
|
render json: @availability.errors, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-03-23 18:39:41 +01:00
|
|
|
private
|
|
|
|
def set_availability
|
|
|
|
@availability = Availability.find(params[:id])
|
|
|
|
end
|
|
|
|
|
|
|
|
def availability_params
|
2017-02-15 13:18:03 +01:00
|
|
|
params.require(:availability).permit(:start_at, :end_at, :available_type, :machine_ids, :training_ids, :nb_total_places, machine_ids: [], training_ids: [], space_ids: [], tag_ids: [],
|
2016-03-23 18:39:41 +01:00
|
|
|
:machines_attributes => [:id, :_destroy])
|
|
|
|
end
|
|
|
|
|
2017-09-06 15:01:41 +02:00
|
|
|
def lock_params
|
|
|
|
params.require(:lock)
|
|
|
|
end
|
|
|
|
|
2017-09-07 11:44:50 +02:00
|
|
|
def is_reserved_availability(availability, user)
|
|
|
|
if user
|
|
|
|
reserved_slots = []
|
|
|
|
availability.slots.each do |s|
|
|
|
|
if s.canceled_at.nil?
|
|
|
|
reserved_slots << s
|
|
|
|
end
|
2017-02-28 16:51:56 +01:00
|
|
|
end
|
2017-09-07 11:44:50 +02:00
|
|
|
reserved_slots.map(&:reservations).flatten.map(&:user_id).include? user.id
|
|
|
|
else
|
|
|
|
false
|
2017-02-28 16:51:56 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-03-23 18:39:41 +01:00
|
|
|
def is_reserved(start_at, reservations)
|
|
|
|
is_reserved = false
|
|
|
|
reservations.each do |r|
|
|
|
|
r.slots.each do |s|
|
|
|
|
is_reserved = true if s.start_at == start_at
|
|
|
|
end
|
|
|
|
end
|
|
|
|
is_reserved
|
|
|
|
end
|
|
|
|
|
2016-06-21 19:07:47 +02:00
|
|
|
def verify_machine_is_reserved(slot, reservations, user, user_role)
|
2016-03-23 18:39:41 +01:00
|
|
|
reservations.each do |r|
|
|
|
|
r.slots.each do |s|
|
2016-06-29 17:37:22 +02:00
|
|
|
if slot.machine.id == r.reservable_id
|
|
|
|
if s.start_at == slot.start_at and s.canceled_at == nil
|
|
|
|
slot.id = s.id
|
|
|
|
slot.is_reserved = true
|
|
|
|
slot.title = "#{slot.machine.name} - #{t('availabilities.not_available')}"
|
|
|
|
slot.can_modify = true if user_role === 'admin'
|
2017-02-27 13:48:35 +01:00
|
|
|
slot.reservations.push r
|
2016-06-29 17:37:22 +02:00
|
|
|
end
|
|
|
|
if s.start_at == slot.start_at and r.user == user and s.canceled_at == nil
|
|
|
|
slot.title = "#{slot.machine.name} - #{t('availabilities.i_ve_reserved')}"
|
|
|
|
slot.can_modify = true
|
|
|
|
slot.is_reserved_by_current_user = true
|
|
|
|
end
|
2016-03-23 18:39:41 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
slot
|
|
|
|
end
|
|
|
|
|
2017-02-23 17:45:55 +01:00
|
|
|
def verify_space_is_reserved(slot, reservations, user, user_role)
|
|
|
|
reservations.each do |r|
|
|
|
|
r.slots.each do |s|
|
2017-02-28 13:23:31 +01:00
|
|
|
if slot.space.id == r.reservable_id
|
2017-02-23 17:45:55 +01:00
|
|
|
if s.start_at == slot.start_at and s.canceled_at == nil
|
|
|
|
slot.can_modify = true if user_role === 'admin'
|
2017-02-27 13:48:35 +01:00
|
|
|
slot.reservations.push r
|
2017-02-23 17:45:55 +01:00
|
|
|
end
|
|
|
|
if s.start_at == slot.start_at and r.user == user and s.canceled_at == nil
|
2017-03-01 14:47:59 +01:00
|
|
|
slot.id = s.id
|
2017-02-23 17:45:55 +01:00
|
|
|
slot.title = t('availabilities.i_ve_reserved')
|
|
|
|
slot.can_modify = true
|
2017-02-27 16:15:27 +01:00
|
|
|
slot.is_reserved = true
|
2017-02-23 17:45:55 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
slot
|
|
|
|
end
|
|
|
|
|
2017-02-22 17:29:35 +01:00
|
|
|
def verify_training_event_is_reserved(availability, reservations, user)
|
2016-03-23 18:39:41 +01:00
|
|
|
reservations.each do |r|
|
|
|
|
r.slots.each do |s|
|
2016-06-29 17:37:22 +02:00
|
|
|
if ((availability.available_type == 'training' and availability.trainings.first.id == r.reservable_id) or (availability.available_type == 'event' and availability.event.id == r.reservable_id)) and s.start_at == availability.start_at and s.canceled_at == nil
|
2016-03-23 18:39:41 +01:00
|
|
|
availability.slot_id = s.id
|
2016-06-29 17:37:22 +02:00
|
|
|
if r.user == user
|
|
|
|
availability.is_reserved = true
|
|
|
|
availability.can_modify = true
|
|
|
|
end
|
2016-03-23 18:39:41 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
availability
|
|
|
|
end
|
|
|
|
|
|
|
|
def can_show_slot_plus_three_months(user)
|
|
|
|
# member must have validated at least 1 training and must have a valid yearly subscription.
|
|
|
|
user.trainings.size > 0 and is_subscription_year(user)
|
|
|
|
end
|
|
|
|
|
|
|
|
def is_subscription_year(user)
|
|
|
|
user.subscription and user.subscription.plan.interval == 'year' and user.subscription.expired_at >= Time.now
|
|
|
|
end
|
2016-06-28 18:58:44 +02:00
|
|
|
|
|
|
|
def in_same_day(start_date, end_date)
|
|
|
|
(end_date.to_date - start_date.to_date).to_i == 1
|
|
|
|
end
|
2016-07-14 18:36:52 +02:00
|
|
|
|
|
|
|
def filter_availabilites(availabilities)
|
|
|
|
availabilities_filtered = []
|
|
|
|
availabilities.to_ary.each do |a|
|
|
|
|
# machine slot
|
|
|
|
if !a.try(:available_type)
|
|
|
|
availabilities_filtered << a
|
|
|
|
else
|
|
|
|
# training
|
|
|
|
if params[:t] and a.available_type == 'training'
|
|
|
|
if params[:t].include?(a.trainings.first.id.to_s)
|
|
|
|
availabilities_filtered << a
|
|
|
|
end
|
|
|
|
end
|
2017-02-28 11:59:48 +01:00
|
|
|
# space
|
2017-02-28 17:17:43 +01:00
|
|
|
if params[:s] and a.available_type == 'space'
|
|
|
|
if params[:s].include?(a.spaces.first.id.to_s)
|
2017-02-28 11:59:48 +01:00
|
|
|
availabilities_filtered << a
|
|
|
|
end
|
|
|
|
end
|
2016-07-14 18:36:52 +02:00
|
|
|
# machines
|
|
|
|
if params[:m] and a.available_type == 'machines'
|
|
|
|
if (params[:m].map(&:to_i) & a.machine_ids).any?
|
|
|
|
availabilities_filtered << a
|
|
|
|
end
|
|
|
|
end
|
|
|
|
# event
|
|
|
|
if params[:evt] and params[:evt] == 'true' and a.available_type == 'event'
|
|
|
|
availabilities_filtered << a
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
availabilities_filtered.delete_if do |a|
|
|
|
|
if params[:dispo] == 'false'
|
|
|
|
a.is_reserved or (a.try(:is_completed) and a.is_completed)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-08-24 18:34:18 +02:00
|
|
|
|
|
|
|
def define_max_visibility
|
|
|
|
@visi_max_year = Setting.find_by(name: 'visibility_yearly').value.to_i.months.since
|
|
|
|
@visi_max_other = Setting.find_by(name: 'visibility_others').value.to_i.months.since
|
|
|
|
end
|
2016-03-23 18:39:41 +01:00
|
|
|
end
|