forked from Gitlink/forgeplus
110 lines
5.1 KiB
Ruby
110 lines
5.1 KiB
Ruby
# == Schema Information
|
||
#
|
||
# Table name: journals_for_messages
|
||
#
|
||
# id :integer not null, primary key
|
||
# jour_id :integer
|
||
# jour_type :string(255)
|
||
# user_id :integer
|
||
# notes :text(65535)
|
||
# status :integer
|
||
# reply_id :integer
|
||
# created_on :datetime not null
|
||
# updated_on :datetime not null
|
||
# m_parent_id :string(255)
|
||
# is_readed :boolean
|
||
# m_reply_count :integer
|
||
# m_reply_id :integer
|
||
# is_comprehensive_evaluation :integer
|
||
# private :integer default("0")
|
||
# root_id :integer
|
||
# hidden :boolean default("0")
|
||
# praises_count :integer default("0")
|
||
#
|
||
# Indexes
|
||
#
|
||
# index_journals_for_messages_on_jour_id (jour_id)
|
||
# index_journals_for_messages_on_root_id (root_id)
|
||
#
|
||
|
||
class JournalsForMessage < ApplicationRecord
|
||
belongs_to :jour, :polymorphic => true
|
||
belongs_to :user
|
||
belongs_to :parent, class_name: "JournalsForMessage", foreign_key: "m_parent_id",
|
||
counter_cache: :m_reply_count, optional: true
|
||
|
||
has_many :praise_treads, as: :praise_tread_object, dependent: :destroy
|
||
|
||
#scope :children, -> {where(m_parent_id: self.id).includes(:user).reorder("created_on asc")}
|
||
#scope :children, -> (discuss_id){ where(parent_id: discuss_id).includes(:user).reorder("created_at asc") }
|
||
|
||
scope :parent_comment, -> { where(m_parent_id: nil)}
|
||
scope :search_by_jour_type, lambda{|type,ids| where(jour_type:type,jour_id: ids)}
|
||
has_many :tidings, as: :container, dependent: :destroy
|
||
|
||
# "jour_type", # 留言所属类型
|
||
# "jour_id", # 留言所属类型的id
|
||
# "notes", # 留言内容
|
||
# "reply_id", # 留言被回复留言者的用户id(用户a回复了用户b,这是b的id,用以查询谁给b留言了)
|
||
# "status", # 留言是否被查看(弃用)
|
||
# "user_id", # 留言者的id
|
||
# "m_parent_id", # 留言信息的父留言id
|
||
# "is_readed", # 留言是否已读
|
||
# "m_reply_count", # 留言的回复数量
|
||
# "m_reply_id" , # 回复某留言的留言id(a留言回复了b留言,这是b留言的id)
|
||
# "is_comprehensive_evaluation", # 1 教师评论、2 匿评、3 留言
|
||
# "hidden", 隐藏、
|
||
|
||
validates :notes, length: { maximum: 2000, too_long: "不能超过2000个字符" }
|
||
|
||
after_create :send_tiding
|
||
|
||
|
||
# course_identity 课堂用户身份
|
||
def contents_show course_identity
|
||
if self.hidden && course_identity >= Course::STUDENT
|
||
nil
|
||
else
|
||
self.notes
|
||
end
|
||
end
|
||
|
||
def can_delete course_identity
|
||
course_identity < Course::STUDENT
|
||
end
|
||
|
||
def created_at
|
||
self.created_on
|
||
end
|
||
|
||
def children page, limit
|
||
JournalsForMessage.includes(:user).where(m_parent_id: self.id).page(page).per(limit).reorder("created_on asc")
|
||
end
|
||
|
||
|
||
def send_tiding
|
||
# 回复和@同一个人时:只发@的消息(因@的消息先创建)
|
||
case self.jour_type
|
||
# 用户留言当做私信处理 不发消息
|
||
when "Principal"
|
||
=begin
|
||
user_id = self.m_parent_id.present? ? JournalsForMessage.find(self.m_parent_id).user_id : self.jour_id
|
||
if user_id != self.user_id && !self.tidings.where(:user_id => user_id, :trigger_user_id => self.user_id, :tiding_type => "Mentioned").first.present?
|
||
self.tidings << Tiding.new(:trigger_user_id => self.user_id, :user_id => user_id, :parent_container_id => self.jour_id, :parent_container_type => self.jour_type, :belong_container_id => self.jour_id, :belong_container_type => "User", :viewed => 0, :tiding_type => self.m_parent_id.present? ? "Comment" : "Journal")
|
||
end
|
||
=end
|
||
when "HomeworkCommon", "GraduationTopic"
|
||
user_id = self.m_parent_id.present? ? JournalsForMessage.find(self.m_parent_id).user_id : (self.jour_type == "HomeworkCommon" ? self.jour.user_id : self.jour.tea_id)
|
||
if user_id != self.user_id && !self.tidings.where(:user_id => user_id, :trigger_user_id => self.user_id, :tiding_type => "Mentioned").first.present?
|
||
self.tidings << Tiding.new(:trigger_user_id => self.user_id, :user_id => user_id, :parent_container_id => self.jour_id, :parent_container_type => self.jour_type, :belong_container_id => self.jour.course_id, :belong_container_type => "Course", :viewed => 0, :tiding_type => "Comment")
|
||
end
|
||
when "StudentWorksScore"
|
||
course_id = self.jour.try(:student_work).try(:homework_common).try(:course_id)
|
||
user_id = self.m_parent_id.present? ? JournalsForMessage.find(self.m_parent_id).user_id : self.jour.user_id
|
||
if user_id != self.user_id && !self.tidings.where(:user_id => user_id, :trigger_user_id => self.user_id, :tiding_type => "Mentioned").first.present?
|
||
self.tidings << Tiding.new(:trigger_user_id => self.user_id, :user_id => user_id, :parent_container_id => self.jour_id, :parent_container_type => self.jour_type, :belong_container_id => course_id, :belong_container_type => "Course", :viewed => 0, :tiding_type => "Comment")
|
||
end
|
||
end
|
||
end
|
||
end
|