class Api::V1::UsersCollection < Api::V1::Collection
  def self.as_json
    self.new.data.to_json
  end

  def data
    { users: map_query }
  end

  private

  def users_table
    User.arel_table
  end

  def teams_table
    Team.arel_table
  end

  def joins
    [
      users_table[:team_id].eq(teams_table[:id])
    ]
  end

  def columns
    [
      users_table[:username],
      users_table[:steamid],
      teams_table[:name],
      teams_table[:tag],
      teams_table[:logo],
      users_table[:id]
    ]
  end

  def arel_query
    users_table
    .project(columns)
    .join(teams_table, Arel::Nodes::OuterJoin)
    .on(joins)
    .where(users_table[:team_id].not_eq(nil))
    .order(users_table[:id])
  end

  def map_query
    execute_query.map do |row|
      {
        id: row[5],
        username: row[0],
        steamid: row[1],
        team: {
          name: row[2],
          tag: row[3],
          logo: row[4]
        }
      }
    end
  end
end