views.py 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. #!/usr/bin/env python
  2. # -*- coding=UTF-8 -*-
  3. # **************************************************************************
  4. # Copyright © 2016 jianglin
  5. # File Name: views.py
  6. # Author: jianglin
  7. # Email: xiyang0807@gmail.com
  8. # Created: 2016-05-20 13:47:04 (CST)
  9. # Last Update:星期六 2016-6-25 17:55:55 (CST)
  10. # By:
  11. # Description:
  12. # **************************************************************************
  13. from flask import (Blueprint, render_template, redirect, url_for, request, g,
  14. jsonify, session, Markup, abort)
  15. from flask.views import MethodView
  16. from flask_login import login_required
  17. from flask_maple.forms import flash_errors
  18. from maple import app, db
  19. from maple.main.models import RedisData
  20. from maple.main.permission import topic_permission, reply_permission
  21. from maple.helpers import is_num
  22. from maple.forums.models import Board
  23. from maple.topic.models import Topic
  24. from maple.topic.forms import TopicForm, ReplyForm
  25. from maple.filters import safe_clean, Filters
  26. from .controls import TopicModel, ReplyModel
  27. site = Blueprint('topic', __name__)
  28. @site.route('/ask')
  29. @login_required
  30. def ask():
  31. form = session.get('topicform', None)
  32. if form is None:
  33. form = TopicForm()
  34. boardId = request.args.get('boardId')
  35. if boardId is not None:
  36. board = Board.query.filter_by(id=boardId).first()
  37. form.category.data = board.id
  38. return render_template('topic/ask.html', form=form)
  39. @site.route('/good')
  40. def good():
  41. page = is_num(request.args.get('page'))
  42. topics = Topic.query.filter_by(is_good=True).paginate(
  43. page, app.config['PER_PAGE'],
  44. error_out=True)
  45. return render_template('topic/topic_good.html', topics=topics)
  46. @site.route('/preview', methods=['GET', 'POST'])
  47. @login_required
  48. def preview():
  49. if request.method == "POST":
  50. choice = request.values.get('choice')
  51. content = request.values.get('content')
  52. print(choice)
  53. if choice == '2':
  54. return safe_clean(content)
  55. else:
  56. return Filters.safe_markdown(content)
  57. else:
  58. abort(404)
  59. @site.route('/up/<topicId>', methods=['POST'])
  60. def vote_up(topicId):
  61. if not g.user.is_authenticated:
  62. return jsonify(judge=False, url=url_for('auth.login'))
  63. topic = Topic.query.filter_by(uid=topicId).first_or_404()
  64. if not topic.vote:
  65. topic.vote = 1
  66. else:
  67. topic.vote += 1
  68. db.session.commit()
  69. html = TopicModel.vote(topicId, topic.vote)
  70. return jsonify(judge=True, html=html)
  71. @site.route('/down/<topicId>', methods=['POST'])
  72. def vote_down(topicId):
  73. if not g.user.is_authenticated:
  74. return jsonify(judge=False, url=url_for('auth.login'))
  75. topic = Topic.query.filter_by(uid=topicId).first_or_404()
  76. if not topic.vote:
  77. topic.vote = -1
  78. else:
  79. topic.vote -= 1
  80. db.session.commit()
  81. html = TopicModel.vote(topicId, topic.vote)
  82. return jsonify(judge=True, html=html)
  83. class TopicAPI(MethodView):
  84. decorators = [topic_permission]
  85. def template_with_uid(self, form, topic, replies):
  86. data = {'topic': topic, 'replies': replies, 'form': form}
  87. return render_template('topic/content.html', **data)
  88. def template_without_uid(self, topics, top_topics):
  89. data = {'topics': topics, 'top_topics': top_topics}
  90. return render_template('topic/topic.html', **data)
  91. def get(self, uid):
  92. page = is_num(request.args.get('page'))
  93. if uid is None:
  94. topics = Topic.query.filter_by(is_top=False).paginate(
  95. page, app.config['PER_PAGE'],
  96. error_out=True)
  97. top_topics = Topic.query.filter_by(is_top=True).limit(5).all()
  98. return self.template_without_uid(topics, top_topics)
  99. else:
  100. form = ReplyForm()
  101. topic = Topic.query.filter_by(uid=str(uid)).first_or_404()
  102. replies = topic.replies.paginate(page, app.config['PER_PAGE'],
  103. True)
  104. RedisData.set_read_count(topic.id)
  105. return self.template_with_uid(form, topic, replies)
  106. def post(self):
  107. form = TopicForm()
  108. if form.validate_on_submit():
  109. topic = TopicModel.post_data(form)
  110. return redirect(url_for('topic.topic', uid=topic.uid))
  111. else:
  112. if form.errors:
  113. flash_errors(form)
  114. session['topicform'] = form
  115. return redirect(url_for('topic.ask'))
  116. # def put(self, uid):
  117. # form = TopicForm()
  118. # if form.validate_on_submit():
  119. # pass
  120. # def delete(self, uid):
  121. # return 'delete'
  122. class ReplyAPI(MethodView):
  123. decorators = [reply_permission]
  124. def post(self, uid):
  125. form = ReplyForm()
  126. topic = Topic.query.filter_by(id=uid).first()
  127. if form.validate_on_submit():
  128. ReplyModel.post_data(form, uid)
  129. return redirect(url_for('topic.topic',
  130. uid=topic.uid,
  131. _anchor='replies-content'))
  132. else:
  133. if form.errors:
  134. flash_errors(form)
  135. else:
  136. pass
  137. return redirect(url_for('topic.topic',
  138. uid=str(topic.uid),
  139. _anchor='replies-content'))
  140. # def put(self, uid):
  141. # return 'put'
  142. # def delete(self, uid):
  143. # return 'delete'
  144. topic_view = TopicAPI.as_view('topic')
  145. site.add_url_rule('',
  146. defaults={'uid': None},
  147. view_func=topic_view,
  148. methods=['GET'])
  149. site.add_url_rule('', view_func=TopicAPI.as_view('post'), methods=['POST'])
  150. site.add_url_rule('/<uid>', view_func=topic_view, methods=['GET'])
  151. site.add_url_rule('/reply/<uid>',
  152. view_func=ReplyAPI.as_view('reply'),
  153. methods=['POST'])