2024-12-28 18:28:28 +01:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2024-10-27 21:42:45 +00:00
|
|
|
# Copyright (C) 2024 Manuel Bustillo
|
|
|
|
|
2024-08-01 18:27:41 +00:00
|
|
|
class TablesArrangementsController < ApplicationController
|
|
|
|
def index
|
2024-12-28 18:28:28 +01:00
|
|
|
render json: TablesArrangement.order(discomfort: :asc).limit(3).as_json(only: %i[id name discomfort])
|
2024-08-01 18:27:41 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def show
|
2024-12-16 18:52:34 +01:00
|
|
|
Guest.joins(:seats, :group)
|
|
|
|
.where(seats: { tables_arrangement_id: params[:id] })
|
|
|
|
.select('guests.*', 'groups.color', 'seats.table_number')
|
|
|
|
.group_by(&:table_number)
|
|
|
|
.map { |number, guests| format(number:, guests:) }
|
|
|
|
.then { |result| render json: { id: params[:id], tables: result } }
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def format(number:, guests:)
|
|
|
|
{
|
|
|
|
number: number,
|
|
|
|
discomfort: discomfort(guests: guests),
|
|
|
|
guests: guests.as_json(only: %i[id name color])
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
def discomfort(guests:)
|
|
|
|
table = Tables::Table.new(guests)
|
|
|
|
|
|
|
|
table.min_per_table = TableSimulatorJob::MIN_PER_TABLE
|
|
|
|
table.max_per_table = TableSimulatorJob::MAX_PER_TABLE
|
|
|
|
calculator = Tables::DiscomfortCalculator.new(table:)
|
|
|
|
{
|
|
|
|
discomfort: calculator.calculate,
|
|
|
|
breakdown: calculator.breakdown
|
|
|
|
}
|
2024-08-01 18:27:41 +00:00
|
|
|
end
|
|
|
|
end
|