consul/consul

View on GitHub
app/models/poll/officer_assignment.rb

Summary

Maintainability
A
0 mins
Test Coverage
class Poll
  class OfficerAssignment < ApplicationRecord
    belongs_to :officer
    belongs_to :booth_assignment
    has_many :ballot_sheets
    has_many :partial_results
    has_many :recounts
    has_many :voters

    validates :officer_id, presence: true
    validates :booth_assignment_id, presence: true
    validates :date, presence: true

    delegate :poll_id, :booth_id, to: :booth_assignment

    scope :voting_days, -> { where(final: false) }
    scope :final,       -> { where(final: true) }
    scope :by_officer_and_poll, ->(officer_id, poll_id) do
      where("officer_id = ? AND poll_booth_assignments.poll_id = ?", officer_id, poll_id)
    end
    scope :by_officer, ->(officer) { where(officer_id: officer.id) }
    scope :by_poll,  ->(poll) { joins(:booth_assignment).where("poll_booth_assignments.poll_id": poll.id) }
    scope :by_booth, ->(booth) { joins(:booth_assignment).where("poll_booth_assignments.booth_id": booth.id) }
    scope :by_date, ->(date) { where(date: date) }

    before_create :log_user_data

    def log_user_data
      self.user_data_log = "#{officer.user_id} - #{officer.user.name_and_email}"
    end

    def booth
      booth_assignment.booth
    end
  end
end