In Ruby, the Kernel class defined the `open` method, which is available for (almost) every object. So creating a scope with the name `open` generates a warning indicating we are overwriting the existing `open` method. While this warning is pretty much harmless and we could ignore it, it generates a lot of noise in the logs. So I'm "undefining" the method before generating the scope, so we don't get the warning all the time.
165 lines
6.1 KiB
Ruby
165 lines
6.1 KiB
Ruby
require "csv"
|
|
|
|
class Legislation::Process < ApplicationRecord
|
|
include ActsAsParanoidAliases
|
|
include Taggable
|
|
include Milestoneable
|
|
include Imageable
|
|
include Documentable
|
|
|
|
acts_as_paranoid column: :hidden_at
|
|
acts_as_taggable_on :customs
|
|
|
|
translates :title, touch: true
|
|
translates :summary, touch: true
|
|
translates :description, touch: true
|
|
translates :additional_info, touch: true
|
|
translates :milestones_summary, touch: true
|
|
translates :homepage, touch: true
|
|
include Globalizable
|
|
extend DownloadSettings::LegislationProcessCsv
|
|
|
|
PHASES_AND_PUBLICATIONS = %i[homepage_phase draft_phase debate_phase allegations_phase
|
|
proposals_phase people_proposals_phase draft_publication
|
|
result_publication].freeze
|
|
|
|
CSS_HEX_COLOR = /\A#?(?:[A-F0-9]{3}){1,2}\z/i
|
|
|
|
has_many :draft_versions, -> { order(:id) }, class_name: "Legislation::DraftVersion",
|
|
foreign_key: "legislation_process_id",
|
|
dependent: :destroy
|
|
has_one :final_draft_version, -> { where final_version: true, status: "published" },
|
|
class_name: "Legislation::DraftVersion",
|
|
foreign_key: "legislation_process_id"
|
|
has_many :questions, -> { order(:id) }, class_name: "Legislation::Question",
|
|
foreign_key: "legislation_process_id", dependent: :destroy
|
|
has_many :proposals, -> { order(:id) }, class_name: "Legislation::Proposal",
|
|
foreign_key: "legislation_process_id", dependent: :destroy
|
|
has_many :people_proposals, -> { order(:id) }, class_name: "Legislation::PeopleProposal",
|
|
foreign_key: "legislation_process_id", dependent: :destroy
|
|
|
|
validates_translation :title, presence: true
|
|
validates :start_date, presence: true
|
|
validates :end_date, presence: true
|
|
validates :debate_start_date, presence: true, if: :debate_end_date?
|
|
validates :debate_end_date, presence: true, if: :debate_start_date?
|
|
validates :draft_start_date, presence: true, if: :draft_end_date?
|
|
validates :draft_end_date, presence: true, if: :draft_start_date?
|
|
validates :allegations_start_date, presence: true, if: :allegations_end_date?
|
|
validates :allegations_end_date, presence: true, if: :allegations_start_date?
|
|
validates :proposals_phase_end_date, presence: true, if: :proposals_phase_start_date?
|
|
validates :people_proposals_phase_end_date, presence: true,
|
|
if: :people_proposals_phase_start_date?
|
|
validate :valid_date_ranges
|
|
validates :background_color, format: { allow_blank: true, with: CSS_HEX_COLOR }
|
|
validates :font_color, format: { allow_blank: true, with: CSS_HEX_COLOR }
|
|
|
|
class << self; undef :open; end
|
|
scope :open, -> { where("start_date <= ? and end_date >= ?", Date.current, Date.current) }
|
|
scope :active, -> { where("end_date >= ?", Date.current) }
|
|
scope :past, -> { where("end_date < ?", Date.current) }
|
|
|
|
scope :published, -> { where(published: true) }
|
|
|
|
def self.not_in_draft
|
|
where("draft_phase_enabled = false or (draft_start_date IS NOT NULL and
|
|
draft_end_date IS NOT NULL and (draft_start_date > ? or
|
|
draft_end_date < ?))", Date.current, Date.current)
|
|
end
|
|
|
|
def past?
|
|
end_date < Date.current
|
|
end
|
|
|
|
def homepage_phase
|
|
Legislation::Process::Phase.new(start_date, end_date, homepage_enabled)
|
|
end
|
|
|
|
def draft_phase
|
|
Legislation::Process::Phase.new(draft_start_date, draft_end_date, draft_phase_enabled)
|
|
end
|
|
|
|
def debate_phase
|
|
Legislation::Process::Phase.new(debate_start_date, debate_end_date, debate_phase_enabled)
|
|
end
|
|
|
|
def allegations_phase
|
|
Legislation::Process::Phase.new(allegations_start_date,
|
|
allegations_end_date, allegations_phase_enabled)
|
|
end
|
|
|
|
def proposals_phase
|
|
Legislation::Process::Phase.new(proposals_phase_start_date,
|
|
proposals_phase_end_date, proposals_phase_enabled)
|
|
end
|
|
|
|
def people_proposals_phase
|
|
Legislation::Process::Phase.new(people_proposals_phase_start_date,
|
|
people_proposals_phase_end_date, people_proposals_phase_enabled)
|
|
end
|
|
|
|
def draft_publication
|
|
Legislation::Process::Publication.new(draft_publication_date, draft_publication_enabled)
|
|
end
|
|
|
|
def result_publication
|
|
Legislation::Process::Publication.new(result_publication_date, result_publication_enabled)
|
|
end
|
|
|
|
def enabled_phases?
|
|
PHASES_AND_PUBLICATIONS.any? { |process| send(process).enabled? }
|
|
end
|
|
|
|
def enabled_phases_and_publications_count
|
|
PHASES_AND_PUBLICATIONS.count { |process| send(process).enabled? }
|
|
end
|
|
|
|
def total_comments
|
|
questions.sum(:comments_count) + draft_versions.map(&:total_comments).sum
|
|
end
|
|
|
|
def status
|
|
today = Date.current
|
|
|
|
if today < start_date
|
|
:planned
|
|
elsif end_date < today
|
|
:closed
|
|
else
|
|
:open
|
|
end
|
|
end
|
|
|
|
def get_last_draft_version
|
|
Legislation::DraftVersion.where(process: self, status: "published").last
|
|
end
|
|
|
|
def get_annotations_from_draft
|
|
Legislation::Annotation.where(legislation_draft_version_id: get_last_draft_version)
|
|
end
|
|
|
|
def get_best_annotation_comments
|
|
Comment.where(commentable_id: get_annotations_from_draft,
|
|
commentable_type: "Legislation::Annotation", ancestry: nil)
|
|
.order("cached_votes_up - cached_votes_down DESC")
|
|
end
|
|
|
|
private
|
|
|
|
def valid_date_ranges
|
|
if end_date && start_date && end_date < start_date
|
|
errors.add(:end_date, :invalid_date_range)
|
|
end
|
|
if debate_end_date && debate_start_date && debate_end_date < debate_start_date
|
|
errors.add(:debate_end_date, :invalid_date_range)
|
|
end
|
|
if draft_end_date && draft_start_date && draft_end_date < draft_start_date
|
|
errors.add(:draft_end_date, :invalid_date_range)
|
|
end
|
|
if allegations_end_date && allegations_start_date &&
|
|
allegations_end_date < allegations_start_date
|
|
errors.add(:allegations_end_date, :invalid_date_range)
|
|
end
|
|
end
|
|
end
|