class ItemBankQuery < ApplicationQuery
  include CustomSortable
  attr_reader :params

  sort_columns :updated_at, default_by: :updated_at, default_direction: :desc, default_table: 'item_banks'

  def initialize(params)
    @params = params
  end

  def call
    if params[:public].to_i == 1
      items = ItemBank.where(public: 1)
    elsif params[:public].to_i == 0
      items = ItemBank.where(user_id: User.current.id)
    end

    if params[:tag_discipline_id].present?
      items = items.joins(:tag_discipline_containers).where(tag_discipline_containers: {tag_discipline_id: params[:tag_discipline_id]})
    elsif params[:sub_discipline_id].present?
      items = items.where(sub_discipline_id: params[:sub_discipline_id])
    elsif params[:discipline_id].present?
      items = items.joins(:sub_discipline).where(sub_disciplines: {discipline_id: params[:discipline_id]})
    end

    if params[:oj_status].present? && params[:item_type] == "PROGRAM"
      items = items.joins("join hacks on hacks.id=item_banks.container_id and item_banks.container_type='Hack'").where(hacks: {status: params[:oj_status]})
    end

    items = items.where(item_type: params[:item_type]) if params[:item_type].present?
    items = items.where(difficulty: params[:difficulty].to_i) if params[:difficulty].present?

    items = items.where("name like ?", "%#{params[:keyword].strip}%") if params[:keyword].present?

    custom_sort(items, params[:sort_by], params[:sort_direction])
  end
end