2019-05-02 18:17:27 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-11-19 08:50:00 -05:00
|
|
|
class Poll < ActiveRecord::Base
|
|
|
|
# because we want to use the 'type' column and don't want to use STI
|
|
|
|
self.inheritance_column = nil
|
|
|
|
|
|
|
|
belongs_to :post
|
|
|
|
|
2019-01-30 11:45:50 -05:00
|
|
|
has_many :poll_options, -> { order(:id) }, dependent: :destroy
|
2018-11-19 08:50:00 -05:00
|
|
|
has_many :poll_votes
|
|
|
|
|
|
|
|
enum type: {
|
|
|
|
regular: 0,
|
|
|
|
multiple: 1,
|
|
|
|
number: 2,
|
|
|
|
}
|
|
|
|
|
|
|
|
enum status: {
|
|
|
|
open: 0,
|
|
|
|
closed: 1,
|
|
|
|
}
|
|
|
|
|
|
|
|
enum results: {
|
|
|
|
always: 0,
|
|
|
|
on_vote: 1,
|
|
|
|
on_close: 2,
|
2019-08-15 14:27:18 -04:00
|
|
|
staff_only: 3,
|
2018-11-19 08:50:00 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
enum visibility: {
|
|
|
|
secret: 0,
|
|
|
|
everyone: 1,
|
|
|
|
}
|
|
|
|
|
2019-11-25 12:51:01 -05:00
|
|
|
enum chart_type: {
|
|
|
|
bar: 0,
|
|
|
|
pie: 1
|
|
|
|
}
|
|
|
|
|
2018-12-31 04:48:30 -05:00
|
|
|
validates :min, numericality: { allow_nil: true, only_integer: true, greater_than_or_equal_to: 0 }
|
2018-11-19 08:50:00 -05:00
|
|
|
validates :max, numericality: { allow_nil: true, only_integer: true, greater_than: 0 }
|
|
|
|
validates :step, numericality: { allow_nil: true, only_integer: true, greater_than: 0 }
|
|
|
|
|
|
|
|
def is_closed?
|
|
|
|
closed? || (close_at && close_at <= Time.zone.now)
|
|
|
|
end
|
|
|
|
|
|
|
|
def can_see_results?(user)
|
2019-08-15 14:27:18 -04:00
|
|
|
return true if always?
|
|
|
|
return !!user&.staff? if staff_only?
|
|
|
|
return has_voted?(user) if on_vote?
|
|
|
|
is_closed?
|
2018-11-19 08:50:00 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
def has_voted?(user)
|
|
|
|
user&.id && poll_votes.any? { |v| v.user_id == user.id }
|
|
|
|
end
|
|
|
|
|
|
|
|
def can_see_voters?(user)
|
|
|
|
everyone? && can_see_results?(user)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: polls
|
|
|
|
#
|
2019-05-13 11:37:21 -04:00
|
|
|
# id :bigint not null, primary key
|
|
|
|
# post_id :bigint
|
2018-11-19 08:50:00 -05:00
|
|
|
# name :string default("poll"), not null
|
|
|
|
# close_at :datetime
|
|
|
|
# type :integer default("regular"), not null
|
|
|
|
# status :integer default("open"), not null
|
|
|
|
# results :integer default("always"), not null
|
|
|
|
# visibility :integer default("secret"), not null
|
|
|
|
# min :integer
|
|
|
|
# max :integer
|
|
|
|
# step :integer
|
|
|
|
# anonymous_voters :integer
|
|
|
|
# created_at :datetime not null
|
|
|
|
# updated_at :datetime not null
|
2019-11-29 10:49:08 -05:00
|
|
|
# chart_type :integer default("bar"), not null
|
2018-11-19 08:50:00 -05:00
|
|
|
#
|
|
|
|
# Indexes
|
|
|
|
#
|
|
|
|
# index_polls_on_post_id (post_id)
|
|
|
|
# index_polls_on_post_id_and_name (post_id,name) UNIQUE
|
|
|
|
#
|
2019-05-13 11:37:21 -04:00
|
|
|
# Foreign Keys
|
|
|
|
#
|
|
|
|
# fk_rails_... (post_id => posts.id)
|
|
|
|
#
|