35 lines
1.9 KiB
Ruby
Executable File
35 lines
1.9 KiB
Ruby
Executable File
class InDuty < ApplicationRecord
|
|
belongs_to :dining_facility, foreign_key: 'dinning_id'
|
|
belongs_to :commissioner, foreign_key: 'commissioner_ids'
|
|
|
|
def self.get_induty_by_shift(shift_sale_range,shift,from,to,commissioner)
|
|
## => left join -> show all sales although no orders
|
|
if commissioner.blank?
|
|
commissioner = ''
|
|
else
|
|
if commissioner.present?
|
|
commissioner = " and CAST(in_duties.commissioner_ids AS SIGNED INTEGER) = #{commissioner}"
|
|
end
|
|
end
|
|
|
|
query = InDuty.select("in_duties.*,sales.receipt_no, commissioners.name,dining_facilities.name as dining_name")
|
|
.joins(" LEFT JOIN commissioners on commissioners.id = CAST(in_duties.commissioner_ids AS SIGNED INTEGER)")
|
|
.joins(" LEFT JOIN dining_facilities on dining_facilities.id = in_duties.dinning_id")
|
|
.joins(" JOIN sales on sales.sale_id = in_duties.sale_id")
|
|
if shift.present?
|
|
query = query.where("sales.shift_sale_id in (?) #{commissioner} and sales.sale_status= 'completed' and sale_payments.payment_amount != 0", shift.to_a)
|
|
.joins("join sale_payments on sale_payments.sale_id = sales.sale_id")
|
|
.group("sales.sale_id, in_duties.commissioner_ids")
|
|
elsif shift_sale_range.present?
|
|
query = query.where("sales.sale_status='completed' #{commissioner} and sale_payments.payment_amount != 0 and sales.shift_sale_id in (?)",shift_sale_range.to_a)
|
|
.joins("join sale_payments on sale_payments.sale_id = sales.sale_id")
|
|
.group("sales.sale_id, in_duties.commissioner_ids")
|
|
else
|
|
query = query.where("sales.sale_status='completed' and sales.receipt_date between ? and ? #{commissioner} and sale_payments.payment_amount != 0",from,to)
|
|
.joins("join sale_payments on sale_payments.sale_id = sales.sale_id")
|
|
.group("sales.sale_id, in_duties.commissioner_ids")
|
|
end
|
|
return query
|
|
end
|
|
end
|