Skip to content

Commit 85a8e21

Browse files
authored
Merge pull request liangliangyy#25 from liangliangyy/dev
评论添加markdown支持
2 parents 68097d7 + c9c89db commit 85a8e21

File tree

7 files changed

+90
-43
lines changed

7 files changed

+90
-43
lines changed

accounts/views.py

Lines changed: 14 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -58,23 +58,34 @@ def dispatch(self, request, *args, **kwargs):
5858

5959
return super(LoginView, self).dispatch(request, *args, **kwargs)
6060

61+
def get_context_data(self, **kwargs):
62+
redirect_to = self.request.GET.get(self.redirect_field_name)
63+
if redirect_to is None:
64+
redirect_to = '/'
65+
kwargs['redirect_to'] = redirect_to
66+
67+
return super(LoginView, self).get_context_data(**kwargs)
68+
6169
def form_valid(self, form):
6270
form = AuthenticationForm(data=self.request.POST, request=self.request)
6371

6472
if form.is_valid():
6573
from DjangoBlog.utils import cache
6674
if cache and cache is not None:
6775
cache.clear()
76+
print(self.redirect_field_name)
77+
redirect_to = self.request.GET.get(self.redirect_field_name)
6878
auth.login(self.request, form.get_user())
69-
70-
return HttpResponseRedirect('/')
79+
return super(LoginView, self).form_valid(form)
80+
# return HttpResponseRedirect('/')
7181
else:
7282
return self.render_to_response({
7383
'form': form
7484
})
7585

7686
def get_success_url(self):
77-
redirect_to = self.request.GET.get(self.redirectfieldname)
87+
print(self.redirect_field_name)
88+
redirect_to = self.request.POST.get(self.redirect_field_name)
7889
if not is_safe_url(url=redirect_to, host=self.request.get_host()):
7990
redirect_to = self.success_url
8091
return redirect_to

blog/static/blog/css/style.css

Lines changed: 40 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -1998,8 +1998,9 @@ div {
19981998
#wp-auto-top-bottom:hover {
19991999
background-position: right -68px;
20002000
}
2001-
.widget-login{
2002-
margin-top: 15px!important;
2001+
2002+
.widget-login {
2003+
margin-top: 15px !important;
20032004
}
20042005

20052006
/* ------------------------------------------------------------------------- *
@@ -2361,7 +2362,40 @@ li #reply-title {
23612362
font: inherit;
23622363
vertical-align: baseline;
23632364
}
2364-
#rocket{position:fixed;right:50px;bottom:50px;display:block;visibility:hidden;width:26px;height:48px;background:url("") no-repeat 50% 0;cursor:pointer;-webkit-transition:all 0s;transition:all 0s;}
2365-
#rocket:hover{background-position:50% -62px;}
2366-
#rocket.show{visibility:visible;opacity:1;}
2367-
#rocket.move{background-position:50% -62px;-webkit-animation:toTop .8s ease-in;animation:toTop .8s ease-in;animation-fill-mode:forwards;-webkit-animation-fill-mode:forwards;}
2365+
2366+
#rocket {
2367+
position: fixed;
2368+
right: 50px;
2369+
bottom: 50px;
2370+
display: block;
2371+
visibility: hidden;
2372+
width: 26px;
2373+
height: 48px;
2374+
background: url("") no-repeat 50% 0;
2375+
cursor: pointer;
2376+
-webkit-transition: all 0s;
2377+
transition: all 0s;
2378+
}
2379+
2380+
#rocket:hover {
2381+
background-position: 50% -62px;
2382+
}
2383+
2384+
#rocket.show {
2385+
visibility: visible;
2386+
opacity: 1;
2387+
}
2388+
2389+
#rocket.move {
2390+
background-position: 50% -62px;
2391+
-webkit-animation: toTop .8s ease-in;
2392+
animation: toTop .8s ease-in;
2393+
animation-fill-mode: forwards;
2394+
-webkit-animation-fill-mode: forwards;
2395+
}
2396+
2397+
.comment-markdown {
2398+
float: right;
2399+
font-size: small;
2400+
}
2401+

comments/models.py

Lines changed: 26 additions & 25 deletions
Original file line numberDiff line numberDiff line change
@@ -35,38 +35,39 @@ def __str__(self):
3535

3636
def save(self, *args, **kwargs):
3737
super().save(*args, **kwargs)
38-
subject = '感谢您发表的评论'
39-
site = Site.objects.get_current().domain
40-
article_url = "https://{site}{path}".format(site=site, path=self.article.get_absolute_url())
41-
html_content = """
42-
<p>非常感谢您在本站发表评论</p>
43-
您可以访问
44-
<a href="%s" rel="bookmark">%s</a>
45-
来查看您的评论,
46-
再次感谢您!
47-
<br />
48-
如果上面链接无法打开,请将此链接复制至浏览器。
49-
%s
50-
""" % (article_url, self.article.title, article_url)
51-
tomail = self.author.email
52-
msg = EmailMultiAlternatives(subject, html_content, from_email='no-reply@lylinux.net', to=[tomail])
53-
54-
msg.content_subtype = "html"
55-
56-
_thread.start_new_thread(self.send_comment_email, (msg,))
57-
58-
if self.parent_comment:
38+
if not settings.DEBUG:
39+
subject = '感谢您发表的评论'
40+
site = Site.objects.get_current().domain
41+
article_url = "https://{site}{path}".format(site=site, path=self.article.get_absolute_url())
5942
html_content = """
60-
您在 <a href="%s" rel="bookmark">%s</a> 的评论 <br/> %s <br/> 收到回复啦.快去看看吧
61-
<br/>
43+
<p>非常感谢您在本站发表评论</p>
44+
您可以访问
45+
<a href="%s" rel="bookmark">%s</a>
46+
来查看您的评论,
47+
再次感谢您!
48+
<br />
6249
如果上面链接无法打开,请将此链接复制至浏览器。
6350
%s
64-
""" % (article_url, self.article.title, self.parent_comment.body, article_url)
65-
tomail = self.parent_comment.author.email
51+
""" % (article_url, self.article.title, article_url)
52+
tomail = self.author.email
6653
msg = EmailMultiAlternatives(subject, html_content, from_email='no-reply@lylinux.net', to=[tomail])
54+
6755
msg.content_subtype = "html"
6856

6957
_thread.start_new_thread(self.send_comment_email, (msg,))
7058

59+
if self.parent_comment:
60+
html_content = """
61+
您在 <a href="%s" rel="bookmark">%s</a> 的评论 <br/> %s <br/> 收到回复啦.快去看看吧
62+
<br/>
63+
如果上面链接无法打开,请将此链接复制至浏览器。
64+
%s
65+
""" % (article_url, self.article.title, self.parent_comment.body, article_url)
66+
tomail = self.parent_comment.author.email
67+
msg = EmailMultiAlternatives(subject, html_content, from_email='no-reply@lylinux.net', to=[tomail])
68+
msg.content_subtype = "html"
69+
70+
_thread.start_new_thread(self.send_comment_email, (msg,))
71+
7172
def __str__(self):
7273
return self.body

templates/account/login.html

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -19,7 +19,7 @@ <h2 class="form-signin-heading text-center">Sign in with your Account</h2>
1919
{{ field.errors }}
2020
{% endfor %}
2121

22-
22+
<input type="hidden" name="next" value="{{ redirect_to }}">
2323
<button class="btn btn-lg btn-primary btn-block" type="submit">Sign in</button>
2424

2525
<div class="checkbox">

templates/blog/article_detail.html

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -49,7 +49,8 @@ <h3 class="assistive-text">文章导航</h3>
4949
{% include 'comments/tags/post_comment.html' %}
5050
{% else %}
5151
<div class="comments-area">
52-
<h3 class="comment-meta">您还没有登录,请您<a href="{% url "account:login" %}">登录</a>后发表评论。</h3>
52+
<h3 class="comment-meta">您还没有登录,请您<a
53+
href="{% url "account:login" %}?next={{ request.get_full_path }}">登录</a>后发表评论。</h3>
5354

5455
{% load oauth_tags %}
5556
{% load_oauth_applications %}

templates/comments/tags/comment_item.html

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -8,11 +8,11 @@
88
class="avatar avatar-96 photo" height="96" width="96">
99
<cite class="fn">
1010
<a rel="nofollow"
11-
{% if comment_item.author.is_superuser %}
11+
{% if comment_item.author.is_superuser %}
1212
href="{{ comment_item.author.get_absolute_url }}"
13-
{% else %}
13+
{% else %}
1414
href="#"
15-
{% endif %}
15+
{% endif %}
1616
rel="external nofollow"
1717
class="url">{{ comment_item.author.username }}
1818
</a>
@@ -24,7 +24,7 @@
2424
{{ comment_item.created_time }}
2525
</div>
2626

27-
<p>{{ comment_item.body }}</p>
27+
<p>{{ comment_item.body |custom_markdown }}</p>
2828

2929
<div class="reply"><a rel="nofollow" class="comment-reply-link"
3030
href="javascript:void(0)"

0 commit comments

Comments
 (0)