views.py 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. from app import constants, db
  2. from app.models import News, Comment, CommentLike
  3. from app.utils.common import user_login_data
  4. from app.utils.response_code import RET
  5. from . import news_bp
  6. from flask import render_template, current_app, abort, g, request, jsonify
  7. @news_bp.route("/<int:news_id>")
  8. @user_login_data
  9. def news_detail(news_id):
  10. try:
  11. cur_news = News.query.get(news_id)
  12. except Exception as e:
  13. current_app.logger.error(e)
  14. abort(404)
  15. if not cur_news:
  16. # 返回数据未找到的页面
  17. abort(404)
  18. cur_news.clicks += 1
  19. # 获取点击排行数据
  20. new_list = None
  21. try:
  22. news_list = News.query.order_by(News.clicks.desc()).limit(constants.CLICK_RANK_MAX_NEWS)
  23. except Exception as e:
  24. current_app.logger.error(e)
  25. click_news_list = []
  26. for news in news_list if news_list else []:
  27. click_news_list.append(news.to_dict())
  28. # 判断是否收藏该新闻,默认值为false
  29. is_collected = False
  30. # 判断用户是否收藏过该新闻
  31. if g.user:
  32. if cur_news in g.user.collection_news:
  33. is_collected = True
  34. # 获取当前新闻评论
  35. comments = []
  36. try:
  37. comments = (Comment.query.filter(Comment.news_id == news_id)) \
  38. .order_by(Comment.create_time.desc()).all()
  39. except Exception as e:
  40. current_app.logger.error(e)
  41. return jsonify(errno=RET.DBERR, errmsg="评论查询失败")
  42. # 获取评论点赞
  43. comment_like_ids = []
  44. if g.user:
  45. # 如果当前用户已登录
  46. try:
  47. comment_ids = [comment.id for comment in comments]
  48. if len(comment_ids) > 0:
  49. # 取到当前用户在当前新闻的所有评论点赞的记录
  50. comment_likes = CommentLike.query.filter(CommentLike.comment_id.in_(comment_ids),
  51. CommentLike.user_id == g.user.id).all()
  52. # 取出记录中所有的评论id
  53. comment_like_ids = [comment_like.comment_id for comment_like in comment_likes]
  54. except Exception as e:
  55. current_app.logger.error(e)
  56. comment_list = []
  57. for item in comments if comments else []:
  58. comment_dict = item.to_dict()
  59. comment_dict["is_like"] = False
  60. # 判断用户是否点赞该评论
  61. if g.user and item.id in comment_like_ids:
  62. comment_dict["is_like"] = True
  63. comment_list.append(comment_dict)
  64. data = {
  65. "news": cur_news.to_dict(),
  66. "user_info": g.user.to_dict() if g.user else None,
  67. "click_news_list": click_news_list,
  68. "is_collected": is_collected,
  69. "comments": comment_list
  70. }
  71. return render_template('news/detail.html', data=data)
  72. @news_bp.route("/news_collect", methods=['POST'])
  73. @user_login_data
  74. def news_collect():
  75. """新闻收藏"""
  76. user = g.user
  77. json_data = request.json
  78. print(type(json_data))
  79. news_id = json_data.get("news_id")
  80. action = json_data.get("action")
  81. if not user:
  82. return jsonify(errno=RET.SESSIONERR, errmsg="用户未登录")
  83. if not news_id:
  84. return jsonify(errno=RET.PARAMERR, errmsg="参数错误")
  85. if action not in ("collect", "cancel_collect"):
  86. return jsonify(errno=RET.PARAMERR, errmsg="参数错误")
  87. try:
  88. news = News.query.get(news_id)
  89. except Exception as e:
  90. current_app.logger.error(e)
  91. return jsonify(error=RET.DBERR, errmsg="查询数据失败")
  92. if not news:
  93. return jsonify(errno=RET.NODATA, errmsg="新闻数据不存在")
  94. if action == "collect":
  95. user.collection_news.append(news)
  96. else:
  97. user.collection_news.remove(news)
  98. try:
  99. db.session.commit()
  100. except Exception as e:
  101. current_app.logger.error(e)
  102. db.session.rollback()
  103. return jsonify(errno=RET.DBERR, errmsg="数据保存失败")
  104. return jsonify(errno=RET.OK, errmsg="操作成功")
  105. @news_bp.route("/news_comment", methods=['POST'])
  106. @user_login_data
  107. def add_news_comment():
  108. """添加评论"""
  109. user = g.user
  110. if not user:
  111. return jsonify(errno=RET.SESSIONERR, errmsg="用户未登陆")
  112. # 获取参数
  113. data_dict = request.json
  114. news_id = data_dict.get("news_id")
  115. comment_str = data_dict.get("comment")
  116. parent_id = data_dict.get("parent_id")
  117. if not all([news_id, comment_str]):
  118. jsonify(errno=RET.PARAMERR, errmsg="参数错误")
  119. try:
  120. news = News.query.get(news_id)
  121. except Exception as e:
  122. current_app.logger.error(e)
  123. return jsonify(errno=RET.DBERR, errmsg="数据查询失败")
  124. if not news:
  125. return jsonify(errno=RET.NODATA, errmsg="该新闻不存在")
  126. # 初始化模型,保存数据
  127. comment = Comment()
  128. comment.user_id = user.id
  129. comment.news_id = news_id
  130. comment.content = comment_str
  131. if parent_id:
  132. comment.parent_id = parent_id
  133. try:
  134. db.session.add(comment)
  135. db.session.commit()
  136. except Exception as e:
  137. current_app.logger.error(e)
  138. return jsonify(errno=RET.DBERR, errmsg="保存评论数据失败")
  139. # 返回响应
  140. return jsonify(errno=RET.OK, errmsg="评论成功", data=comment.to_dict())
  141. @news_bp.route("/comment_like", methods=['POST'])
  142. @user_login_data
  143. def set_comment_like():
  144. """评论点赞"""
  145. if not g.user:
  146. return jsonify(errno=RET.SESSIONERR, errmsg="用户未登陆")
  147. # 获取参数
  148. comment_id = request.json.get("comment_id")
  149. news_id = request.json.get("news_id")
  150. action = request.json.get("action")
  151. # 判断参数
  152. if not all([comment_id, news_id, action]):
  153. return jsonify(errno=RET.PARAMERR, errmsg="参数有误")
  154. # 查询评论数据
  155. try:
  156. comment = Comment.query.get(comment_id)
  157. except Exception as e:
  158. current_app.logger.error(e)
  159. return jsonify(errno=RET.DBERR, errmsg="数据查询失败")
  160. if not comment:
  161. return jsonify(errno=RET.NODATA, errmsg="评论数据不存在")
  162. if action == "add":
  163. comment_like = CommentLike.query.filter(CommentLike.comment_id == comment_id,
  164. CommentLike.user_id == g.user.id).first()
  165. if not comment_like:
  166. comment_like = CommentLike()
  167. comment_like.comment_id = comment_id
  168. comment_like.user_id = g.user.id
  169. db.session.add(comment_like)
  170. # 增加点赞条数
  171. comment.like_count += 1
  172. else:
  173. # 删除点赞数据
  174. comment_like = CommentLike.query.filter(CommentLike.comment_id == comment_id,
  175. CommentLike.user_id == g.user.id).first()
  176. if comment_like:
  177. db.session.delete(comment_like)
  178. # 减少点赞条数
  179. comment.like_count -= 1
  180. try:
  181. db.session.commit()
  182. except Exception as e:
  183. current_app.logger.error(e)
  184. db.session.rollback()
  185. return jsonify(errno=RET.DBERR, errmsg="数据更新失败")
  186. return jsonify(errno=RET.OK, errmsg="操作成功")