Show More
1 | NO CONTENT: modified file, binary diff hidden |
|
NO CONTENT: modified file, binary diff hidden |
1 | NO CONTENT: modified file, binary diff hidden |
|
NO CONTENT: modified file, binary diff hidden |
@@ -1,8 +1,8 b'' | |||||
1 | from django import forms |
|
1 | from django import forms | |
2 |
|
2 | |||
3 |
|
3 | |||
4 | class NewThreadForm(forms.Form): |
|
4 | class NewThreadForm(forms.Form): | |
5 | title = forms.CharField(max_length = 100) |
|
5 | title = forms.CharField(max_length = 100) | |
6 | text = forms.CharField(widget = forms.Textarea) |
|
6 | text = forms.CharField(widget = forms.Textarea) | |
7 | image = forms.ImageField() |
|
7 | image = forms.ImageField(required=False) | |
8 | tags = forms.CharField(max_length=100) |
|
8 | tags = forms.CharField(max_length=100) |
1 | NO CONTENT: modified file, binary diff hidden |
|
NO CONTENT: modified file, binary diff hidden |
@@ -1,30 +1,43 b'' | |||||
1 | html { |
|
1 | html { | |
2 | background: #555555; |
|
2 | background: #555555; | |
3 | } |
|
3 | } | |
4 |
|
4 | |||
5 |
|
|
5 | .admin_panel { | |
6 | background: #FF0000; |
|
6 | background: #FF0000; | |
7 | color: #00FF00 |
|
7 | color: #00FF00 | |
8 | } |
|
8 | } | |
9 |
|
9 | |||
|
10 | .input_field { | |||
|
11 | ||||
|
12 | } | |||
|
13 | ||||
|
14 | .input_field_name { | |||
|
15 | ||||
|
16 | } | |||
|
17 | ||||
|
18 | .input_field_error { | |||
|
19 | color: #FF0000; | |||
|
20 | } | |||
|
21 | ||||
|
22 | ||||
10 | .title { |
|
23 | .title { | |
11 | font-weight: bold; |
|
24 | font-weight: bold; | |
12 | color: #ffcc00; |
|
25 | color: #ffcc00; | |
13 | } |
|
26 | } | |
14 |
|
27 | |||
15 | .text { |
|
28 | .text { | |
16 | color: #ffffff; |
|
29 | color: #ffffff; | |
17 | } |
|
30 | } | |
18 |
|
31 | |||
19 | .post-form { |
|
32 | .post-form { | |
20 | text-align: left; |
|
33 | text-align: left; | |
21 | color: #ffffff; |
|
34 | color: #ffffff; | |
22 | } |
|
35 | } | |
23 |
|
36 | |||
24 | .link { |
|
37 | .link { | |
25 | color: #33bb33 |
|
38 | color: #33bb33 | |
26 | } |
|
39 | } | |
27 |
|
40 | |||
28 | .link:hover { |
|
41 | .link:hover { | |
29 | color: #00ff00; |
|
42 | color: #00ff00; | |
30 | } No newline at end of file |
|
43 | } |
1 | NO CONTENT: modified file, binary diff hidden |
|
NO CONTENT: modified file, binary diff hidden |
@@ -1,85 +1,95 b'' | |||||
1 | from django.template import RequestContext |
|
1 | from django.template import RequestContext | |
2 | from boards import forms |
|
2 | from boards import forms | |
|
3 | from boards.forms import NewThreadForm | |||
3 | from boards.models import Post, Admin |
|
4 | from boards.models import Post, Admin | |
4 | from django.shortcuts import render, get_list_or_404 |
|
5 | from django.shortcuts import render, get_list_or_404 | |
5 |
from django.http import HttpResponseRedirect |
|
6 | from django.http import HttpResponseRedirect | |
6 |
|
7 | |||
7 | def index(request): |
|
8 | def index(request): | |
8 | context = RequestContext(request) |
|
9 | context = RequestContext(request) | |
9 |
|
10 | |||
10 | if request.method == 'POST': |
|
11 | if request.method == 'POST': | |
11 | Post.objects.create_post(request.POST['title'], |
|
12 | ||
12 | request.POST['text'], ip = request.META['REMOTE_ADDR']) |
|
13 | form = NewThreadForm(request.POST) | |
|
14 | if form.is_valid(): | |||
|
15 | ||||
|
16 | Post.objects.create_post(form.cleaned_data['title'], | |||
|
17 | form.cleaned_data['text'], ip = request.META['REMOTE_ADDR']) | |||
|
18 | else: | |||
|
19 | context['form'] = form | |||
|
20 | ||||
13 |
|
21 | |||
14 | threads = Post.objects.get_threads() |
|
22 | threads = Post.objects.get_threads() | |
15 |
|
23 | |||
16 | context['threads'] = None if len(threads) == 0 else threads |
|
24 | context['threads'] = None if len(threads) == 0 else threads | |
|
25 | ||||
|
26 | if 'form' not in context: | |||
17 | context['form'] = forms.NewThreadForm() |
|
27 | context['form'] = forms.NewThreadForm() | |
18 |
|
28 | |||
19 | return render(request, 'posting_general.html', |
|
29 | return render(request, 'posting_general.html', | |
20 | context) |
|
30 | context) | |
21 |
|
31 | |||
22 | def new_post(request): |
|
32 | def new_post(request): | |
23 | """Add a new post (in thread or as a reply).""" |
|
33 | """Add a new post (in thread or as a reply).""" | |
24 |
|
34 | |||
25 | title = request.POST['title'] |
|
35 | title = request.POST['title'] | |
26 | text = request.POST['text'] |
|
36 | text = request.POST['text'] | |
27 |
|
37 | |||
28 | image = request.POST['image'] |
|
38 | image = request.POST['image'] | |
29 |
|
39 | |||
30 | # TODO Get tags list, download image (if link is given) |
|
40 | # TODO Get tags list, download image (if link is given) | |
31 |
|
41 | |||
32 | post = Post.objects.create_post(title = title, text = text, image = image) |
|
42 | post = Post.objects.create_post(title = title, text = text, image = image) | |
33 |
|
43 | |||
34 | # TODO Show the thread with a newly created post |
|
44 | # TODO Show the thread with a newly created post | |
35 |
|
45 | |||
36 | def tag(request): |
|
46 | def tag(request): | |
37 | """Get all tag threads (posts without a parent).""" |
|
47 | """Get all tag threads (posts without a parent).""" | |
38 |
|
48 | |||
39 | tag_name = request.GET['tag'] |
|
49 | tag_name = request.GET['tag'] | |
40 |
|
50 | |||
41 | threads = get_list_or_404(Post, tag = tag_name) |
|
51 | threads = get_list_or_404(Post, tag = tag_name) | |
42 |
|
52 | |||
43 | context = RequestContext(request) |
|
53 | context = RequestContext(request) | |
44 | context['threads'] = None if len(threads) == 0 else threads |
|
54 | context['threads'] = None if len(threads) == 0 else threads | |
45 | context['tag'] = tag_name |
|
55 | context['tag'] = tag_name | |
46 |
|
56 | |||
47 | return render(request, 'posting_general.html', |
|
57 | return render(request, 'posting_general.html', | |
48 | context) |
|
58 | context) | |
49 |
|
59 | |||
50 | def thread(request, id): |
|
60 | def thread(request, id): | |
51 | """Get all thread posts""" |
|
61 | """Get all thread posts""" | |
52 |
|
62 | |||
53 | # TODO Show 404 if there is no such thread |
|
63 | # TODO Show 404 if there is no such thread | |
54 |
|
64 | |||
55 | posts = Post.objects.get_thread(id) |
|
65 | posts = Post.objects.get_thread(id) | |
56 |
|
66 | |||
57 | context = RequestContext(request) |
|
67 | context = RequestContext(request) | |
58 | context['posts'] = posts |
|
68 | context['posts'] = posts | |
59 |
|
69 | |||
60 | return render(request, 'thread.html', context) |
|
70 | return render(request, 'thread.html', context) | |
61 |
|
71 | |||
62 | def login(request): |
|
72 | def login(request): | |
63 | """Log in as admin""" |
|
73 | """Log in as admin""" | |
64 |
|
74 | |||
65 | if 'name' in request.POST and 'password' in request.POST: |
|
75 | if 'name' in request.POST and 'password' in request.POST: | |
66 | request.session['admin'] = False |
|
76 | request.session['admin'] = False | |
67 |
|
77 | |||
68 | isAdmin = len(Admin.objects.filter(name = request.POST['name'], |
|
78 | isAdmin = len(Admin.objects.filter(name = request.POST['name'], | |
69 | password = request.POST['password'])) > 0 |
|
79 | password = request.POST['password'])) > 0 | |
70 |
|
80 | |||
71 | if isAdmin : |
|
81 | if isAdmin : | |
72 | request.session['admin'] = True |
|
82 | request.session['admin'] = True | |
73 |
|
83 | |||
74 | response = HttpResponseRedirect('/boards') |
|
84 | response = HttpResponseRedirect('/boards') | |
75 |
|
85 | |||
76 | else: |
|
86 | else: | |
77 | response = render(request, 'login.html', {'error' : 'Login error'}) |
|
87 | response = render(request, 'login.html', {'error' : 'Login error'}) | |
78 | else: |
|
88 | else: | |
79 | response = render(request, 'login.html', {}) |
|
89 | response = render(request, 'login.html', {}) | |
80 |
|
90 | |||
81 | return response |
|
91 | return response | |
82 |
|
92 | |||
83 | def logout(request): |
|
93 | def logout(request): | |
84 | request.session['admin'] = False |
|
94 | request.session['admin'] = False | |
85 | return HttpResponseRedirect('/boards') |
|
95 | return HttpResponseRedirect('/boards') |
1 | NO CONTENT: modified file, binary diff hidden |
|
NO CONTENT: modified file, binary diff hidden |
@@ -1,20 +1,20 b'' | |||||
1 | <!DOCTYPE html> |
|
1 | <!DOCTYPE html> | |
2 | <html> |
|
2 | <html> | |
3 | <head> |
|
3 | <head> | |
4 | <link rel="stylesheet" type="text/css" href="{{ STATIC_URL }}css/base_page.css" media="all"/> |
|
4 | <link rel="stylesheet" type="text/css" href="{{ STATIC_URL }}css/base_page.css" media="all"/> | |
5 | {% block head %}{% endblock %} |
|
5 | {% block head %}{% endblock %} | |
6 | </head> |
|
6 | </head> | |
7 | <body> |
|
7 | <body> | |
8 |
<div |
|
8 | <div class="admin_panel"> | |
9 |
|
9 | |||
10 | {% if request.session.admin == True %} |
|
10 | {% if request.session.admin == True %} | |
11 | Admin panel TODO: Need to implement <BR /> |
|
11 | Admin panel TODO: Need to implement <BR /> | |
12 | {% endif %} |
|
12 | {% endif %} | |
13 |
|
13 | |||
14 |
|
14 | |||
15 | </div> |
|
15 | </div> | |
16 |
|
16 | |||
17 | {% block content %}{% endblock %} |
|
17 | {% block content %}{% endblock %} | |
18 |
|
18 | |||
19 | </body> |
|
19 | </body> | |
20 | </html> No newline at end of file |
|
20 | </html> |
@@ -1,28 +1,52 b'' | |||||
1 | {% extends "base.html" %} |
|
1 | {% extends "base.html" %} | |
2 |
|
2 | |||
3 | {% block content %} |
|
3 | {% block content %} | |
4 |
|
4 | |||
5 | {% if threads %} |
|
5 | {% if threads %} | |
6 | {% for thread in threads %} |
|
6 | {% for thread in threads %} | |
7 | <span class="title">{{ thread.title }}</span><br /> |
|
7 | <span class="title">{{ thread.title }}</span><br /> | |
8 | <span class="text">{{ thread.text }}</span><br /> |
|
8 | <span class="text">{{ thread.text }}</span><br /> | |
9 | <a class="link" href="/boards/post/{{ thread.id }}/">View |
|
9 | <a class="link" href="/boards/post/{{ thread.id }}/">View | |
10 | thread</a> |
|
10 | thread</a> | |
11 | <hr /> |
|
11 | <hr /> | |
12 | {% endfor %} |
|
12 | {% endfor %} | |
13 | {% else %} |
|
13 | {% else %} | |
14 | No threads found. |
|
14 | No threads found. | |
15 | <hr /> |
|
15 | <hr /> | |
16 | {% endif %} |
|
16 | {% endif %} | |
17 |
|
17 | |||
18 | <div class="post-form"> |
|
18 | <div class="post-form"> | |
19 | <form action="/boards/" method="post">{% csrf_token %} |
|
19 | <form action="/boards/" method="post">{% csrf_token %} | |
20 | {{ form.as_p }} |
|
20 | <div class="input_field_name"> | |
21 | <input type="submit" value="Post!" /> |
|
21 | <span class=input_field_error>{{ form.title.errors }}</span> | |
|
22 | ||||
|
23 | <label class=input_field_name for="title">Title</label> | |||
|
24 | {{ form.title }} | |||
|
25 | </div> | |||
|
26 | ||||
|
27 | <div class="input_field_name"> | |||
|
28 | <span class=input_field_error>{{ form.text.errors }}</span> | |||
|
29 | ||||
|
30 | <label class=input_field_name for="text">Text</label> | |||
|
31 | {{ form.text }} | |||
|
32 | </div> | |||
|
33 | ||||
|
34 | <div class="input_field_name"> | |||
|
35 | <label class=input_field_name for="image">Avatar</label> | |||
|
36 | {{ form.image }} | |||
|
37 | </div> | |||
|
38 | ||||
|
39 | <div class="input_field_name"> | |||
|
40 | <span class=input_field_error>{{ form.tags.errors}}</span> | |||
|
41 | <label class=input_field_name for="tags">Name</label> | |||
|
42 | {{ form.tags }} | |||
|
43 | </div> | |||
|
44 | ||||
|
45 | <input type="submit" value="Create" /> | |||
22 | </form> |
|
46 | </form> | |
23 | </div> |
|
47 | </div> | |
24 |
|
48 | |||
25 | <HR /> |
|
49 | <HR /> | |
26 |
|
50 | |||
27 | {% endblock %} |
|
51 | {% endblock %} | |
28 |
|
52 |
General Comments 0
You need to be logged in to leave comments.
Login now