openaustralia/publicwhip

View on GitHub
app/controllers/feeds_controller.rb

Summary

Maintainability
A
0 mins
Test Coverage
A
100%
# frozen_string_literal: true

class FeedsController < ApplicationController
  def mp_info
    @members = Member.in_house(params[:house] || "representatives").joins(:member_info).order(:entered_house, :last_name, :first_name, :constituency)
    @most_recent_division = Division.most_recent_date

    @current_members_by_attendance = Ranker.rank(@members.current, by: ->(m) { m.person.attendance_fraction || 0 })
    @current_members_count = @members.current.count

    members_with_rebellions = @members.current.to_a.delete_if { |m| !m.person.rebellions_fraction }
    @current_members_by_rebellions = Ranker.rank(members_with_rebellions, by: ->(m) { m.person.rebellions_fraction })
    @members_with_rebellions_and_party_whip_count = members_with_rebellions.select(&:subject_to_whip?).count
  end

  def mpdream_info
    @policy = Policy.find(params[:id])

    # FIXME: Using SQL to match PHP, see #211 for detailed description
    sql = "select policy_person_distances.person_id, distance_a, members.id as member_id,
           (nvotessame + nvotessamestrong + nvotesdiffer + nvotesdifferstrong) as both_voted,
           (nvotesabsent + nvotesabsentstrong) as absent
           from policy_person_distances, members
           where policy_id = '#{@policy.id}' and
           members.person_id = policy_person_distances.person_id order by member_id"
    @policy_person_distances = PolicyPersonDistance.connection.select_all(sql)
  end
end