微信增加回复的回复后台代码

This commit is contained in:
yuanke 2016-09-05 14:49:22 +08:00
parent 10017d2c69
commit 6f7b40b5ad
1 changed files with 125 additions and 68 deletions

View File

@ -78,22 +78,25 @@ module Mobile
subscribe = 0 #默认未关注 subscribe = 0 #默认未关注
#-------------------获取用户是否关注此公众号----------------------------- #-------------------获取用户是否关注此公众号-----------------------------
openid = session[:wechat_openid] # openid = session[:wechat_openid]
raise "无法获取到openid,请在微信中打开本页面" unless openid # raise "无法获取到openid,请在微信中打开本页面" unless openid
user_info = Wechat.api.user(openid) # user_info = Wechat.api.user(openid)
Rails.logger.info "user_info!!!!!!!!!" # Rails.logger.info "user_info!!!!!!!!!"
Rails.logger.info user_info # Rails.logger.info user_info
subscribe = user_info["subscribe"] # subscribe = user_info["subscribe"]
subscribe = "123"
status = 0 status = 0
tip = 0 #0班级1项目 tip = 0 #0班级1项目
type = params[:type] type = params[:type]
result = 1 result = 1
#0回复 1回复的回复
reply_type = params[:reply_type]
if params[:content]!="" && current_user if params[:content]!="" && current_user
case type case type
when "HomeworkCommon" when "HomeworkCommon"
homework_common = HomeworkCommon.find(params[:id])
#如果是私有的 并且不是成员则不能回复 #如果是私有的 并且不是成员则不能回复
# is_public = homework_common.course.is_public # is_public = homework_common.course.is_public
# if is_public == 0 && !current_user.member_of_course?(homework_common.course) # if is_public == 0 && !current_user.member_of_course?(homework_common.course)
@ -106,15 +109,27 @@ module Mobile
# result = 2 # result = 2
# end # end
# end # end
if reply_type == nil || reply_type == 0
homework_common = HomeworkCommon.find(params[:id])
feedback = HomeworkCommon.add_homework_jour(current_user, params[:content], params[:id]) feedback = HomeworkCommon.add_homework_jour(current_user, params[:content], params[:id])
if (feedback.errors.empty?) if (feedback.errors.empty?)
homework_common.update_column(:updated_at, Time.now) homework_common.update_column(:updated_at, Time.now)
result = 2 result = 2
end end
else
#二级回复
reply = JournalsForMessage.find params[:id].to_i
homework_common = HomeworkCommon.find reply.jour_id
options = {:notes => params[:content], :reply_id => reply.user_id,:user_id => current_user.id,:m_parent_id => params[:id].to_i,:m_reply_id => params[:id].to_i}
feedback = HomeworkCommon.add_homework_jour(current_user, params[:content], reply.jour_id, options)
if (feedback.errors.empty?)
homework_common.update_column(:updated_at, Time.now)
result = 2
end
end
when "News" when "News"
news = News.find(params[:id])
# if news.project # if news.project
# if news.project.is_public == false && !current_user.member_of?(news.project) # if news.project.is_public == false && !current_user.member_of?(news.project)
# status = -1 # status = -1
@ -126,19 +141,26 @@ module Mobile
# tip = 0 # tip = 0
# end # end
# end # end
if status == 0 if status == 0
if reply_type == nil || reply_type == 0
news = News.find(params[:id])
comment = Comment.new comment = Comment.new
comment.comments = params[:content] comment.comments = params[:content]
comment.author = current_user comment.author = current_user
if news.comments << comment if news.comments << comment
result = 2 result = 2
end end
else
#二级回复
comment = Comment.find(params[:id])
news = News.find comment.commented_id
new_comment = news.comments.build(:author_id => current_user.id, :reply_id => params[:id], :comments => params[:content], :parent_id => comment.id)
if new_comment.save
result = 2
end
end
end end
when "Message" when "Message"
message = Message.find(params[:id])
board = Board.find(message.board_id)
# if message.project # if message.project
# if message.project.is_public == false && !current_user.member_of?(message.project) # if message.project.is_public == false && !current_user.member_of?(message.project)
# status = -1 # status = -1
@ -152,6 +174,9 @@ module Mobile
# end # end
if status == 0 if status == 0
# if reply_type == nil || reply_type == 0
message = Message.find(params[:id])
board = Board.find(message.board_id)
topic = message.root topic = message.root
reply = Message.new reply = Message.new
reply.author = current_user reply.author = current_user
@ -162,10 +187,12 @@ module Mobile
if topic.children << reply if topic.children << reply
result = 2 result = 2
end end
# else
#二级回复
# end
end end
when "JournalsForMessage" when "JournalsForMessage"
jour = JournalsForMessage.find params[:id]
# if jour.jour_type == "Project" # if jour.jour_type == "Project"
# if jour.project.is_public == false && !current_user.member_of?(jour.project) # if jour.project.is_public == false && !current_user.member_of?(jour.project)
# status = -1 # status = -1
@ -179,6 +206,8 @@ module Mobile
# end # end
if status == 0 if status == 0
# if reply_type == nil || reply_type == 0
jour = JournalsForMessage.find params[:id]
parent_id = params[:id] parent_id = params[:id]
author_id = current_user.id author_id = current_user.id
reply_user_id = jour.user_id reply_user_id = jour.user_id
@ -196,25 +225,36 @@ module Mobile
(JournalsForMessage.find parent_id).update_attribute(:updated_on,Time.now) (JournalsForMessage.find parent_id).update_attribute(:updated_on,Time.now)
result = 2 result = 2
end end
# else
#二级回复
# end
end end
when 'Issue' when 'Issue'
issue = Issue.find params[:id]
# if issue.project.is_public == false && !current_user.member_of?(issue.project) # if issue.project.is_public == false && !current_user.member_of?(issue.project)
# status = -1 # status = -1
# tip = 1 # tip = 1
# end # end
if status == 0 if status == 0
if reply_type == nil || reply_type == 0
issue = Issue.find params[:id]
is_jour = Journal.new is_jour = Journal.new
is_jour.user_id = current_user.id is_jour.user_id = current_user.id
is_jour.notes = params[:content] is_jour.notes = params[:content]
is_jour.journalized = issue is_jour.journalized = issue
if is_jour.save if is_jour.save
result = 2 result = 2
end
else
#二级回复
end end
end end
when 'BlogComment' when 'BlogComment'
if reply_type == nil || reply_type == 0
blog = BlogComment.find(params[:id]).root blog = BlogComment.find(params[:id]).root
blogComment = BlogComment.new blogComment = BlogComment.new
blogComment.author = current_user blogComment.author = current_user
@ -224,6 +264,23 @@ module Mobile
if blog.children << blogComment if blog.children << blogComment
result = 2 result = 2
end end
else
#二级回复
blog = BlogComment.find(params[:id]).root
blogComment = BlogComment.new
blogComment.author = current_user
blogComment.blog = blog.blog
blogComment.content = params[:content]
blogComment.title = "RE: #{blog.title}"
parent = BlogComment.find params[:id]
blogComment.parent_id = params[:id] #被回复的回复
blogComment.reply_id = parent.author.id #被回复者id
if parent.children << blogComment
result = 2
end
end
end end
if result == 2 if result == 2
update_course_activity_api(type,params[:id]) update_course_activity_api(type,params[:id])