clarion/app/models/conference.rb

47 lines
1.6 KiB
Ruby
Raw Normal View History

class Conference < ActiveRecord::Base
validates :title, presence: true, uniqueness: true
validates :email, presence: true, format: {with: /\A[^@]+@[^@]+\z/}
validates :description, presence: true
validates :start_date, presence: true
validates :end_date, presence: true
validate :start_date_is_before_end_date
2014-09-01 13:44:41 +03:00
translates :title, :description
has_many :tracks
has_many :halls
has_many :event_types
2015-08-14 23:58:19 +03:00
has_many :events
2015-09-01 11:09:26 +03:00
has_many :volunteer_teams
2015-04-20 18:55:06 +03:00
has_one :call_for_participation, dependent: :destroy
has_many :participants, class_name: 'User', through: :events
2015-10-17 19:34:17 +03:00
has_many :slots, through: :halls
2015-09-01 11:09:26 +03:00
accepts_nested_attributes_for :tracks, :halls, :event_types, :volunteer_teams,
reject_if: :all_blank, allow_destroy: true
2014-10-14 18:27:28 +03:00
after_create :create_call_for_participation
2015-07-30 21:19:03 +03:00
def participants
events.where(conference_id: id).map(&:user)
end
2015-04-20 19:11:39 +03:00
def submissions_grouped_by_day
submissions = events.group('date(events.created_at)').select('date(events.created_at) as created_at, count(events.id) as number')
2015-04-20 19:11:39 +03:00
submissions.group_by { |s| s.created_at.to_date }
end
def submissions_grouped_by_confirmation_day
submissions = events.approved.confirmed.group('date(propositions.confirmed_at)').select('date(propositions.confirmed_at) as confirmed_at, count(events.id) as number')
2015-04-20 19:11:39 +03:00
submissions.group_by { |s| s.confirmed_at.to_date }
end
private
def start_date_is_before_end_date
if start_date.present? and end_date.present? and start_date > end_date
errors.add(:end_date, :cannot_be_before_start_date)
end
end
end