Commit 755aeab55b6a2a7c5c2ca4f008944f9e75e6bf78

Authored by Matheus Lins
2 parents df635407 f64fc7d5

Merge branch 'dev' of https://github.com/amadeusproject/amadeuslms into dev

forum/static/js/forum.js
  1 +/*
  2 +*
  3 +* Function to get a cookie stored on browser
  4 +*
  5 +*/
1 6 function getCookie(name) {
2 7 var cookieValue = null;
3 8 if (document.cookie && document.cookie !== '') {
... ... @@ -16,6 +21,31 @@ function getCookie(name) {
16 21  
17 22 /*
18 23 *
  24 +* Defining action of the form to make a post in forum
  25 +*
  26 +*/
  27 +$(document).ready(function (){
  28 + var frm = $('#form_post');
  29 + frm.submit(function () {
  30 + $.ajax({
  31 + type: frm.attr('method'),
  32 + url: frm.attr('action'),
  33 + data: frm.serialize(),
  34 + success: function (data) {
  35 + $("#posts_list").append(data);
  36 + frm[0].reset();
  37 + },
  38 + error: function(data) {
  39 + console.log(frm.serialize());
  40 + console.log('Error');
  41 + }
  42 + });
  43 + return false;
  44 + });
  45 +});
  46 +
  47 +/*
  48 +*
19 49 * Function to load create forum's form and set the submit function
20 50 *
21 51 */
... ... @@ -59,40 +89,10 @@ function createForum(url, topic) {
59 89  
60 90 /*
61 91 *
62   -* Function to load forum to modal
  92 +* Function to delete a forum
63 93 *
64 94 */
65   -function showForum(url, forum_id) {
66   - $.ajax({
67   - url: url,
68   - data: {'forum_id': forum_id},
69   - success: function(data) {
70   - $(".forum_topics").html(data);
71   -
72   - var frm = $('#form_post');
73   - frm.submit(function () {
74   - $.ajax({
75   - type: frm.attr('method'),
76   - url: frm.attr('action'),
77   - data: frm.serialize(),
78   - success: function (data) {
79   - $("#posts_list").append(data);
80   - frm[0].reset();
81   - },
82   - error: function(data) {
83   - console.log(frm.serialize());
84   - console.log('Error');
85   - }
86   - });
87   - return false;
88   - });
89   - }
90   - });
91   -
92   - $('#forumModal').modal();
93   -}
94   -
95   -function delete_forum(url, forum, message) {
  95 +function delete_forum(url, forum, message, return_url) {
96 96 alertify.confirm(message, function(){
97 97 var csrftoken = getCookie('csrftoken');
98 98  
... ... @@ -103,8 +103,9 @@ function delete_forum(url, forum, message) {
103 103 },
104 104 url: url,
105 105 success: function(data) {
106   - $("#forum_"+forum).remove();
107   - $('#forumModal').modal('hide');
  106 + alertify.alert('Amadeus', data, function(){
  107 + window.location.href = return_url;
  108 + });
108 109 }
109 110 });
110 111 });
... ...
forum/templates/forum/forum_view.html
... ... @@ -42,7 +42,7 @@
42 42 <div class="panel-body">
43 43 <ul class="nav nav-pills nav-stacked">
44 44 <li><a href="javascript:edit_forum('{% url 'course:forum:index' %}', '{{ forum.id }}')">{% trans 'Edit' %}</a></li>
45   - <li><a href="javascript:delete_forum('{% url 'course:forum:delete' forum.id %}', '{{ forum.id }}', '{% trans "Are you sure you want to delete this forum?" %}')">{% trans 'Delete' %}</a></li>
  45 + <li><a href="javascript:delete_forum('{% url 'course:forum:delete' forum.id %}', '{{ forum.id }}', '{% trans "Are you sure you want to delete this forum?" %}', '{% url 'course:view_subject' forum.topic.subject.slug %}')">{% trans 'Delete' %}</a></li>
46 46 </ul>
47 47 </div>
48 48 </div>
... ... @@ -59,7 +59,45 @@
59 59 <h4><b>{% trans 'Opened in' %}:</b> {{ forum.create_date }}</h4>
60 60 </div>
61 61 </div>
62   -
  62 + <div class="form_post_block">
  63 + <hr />
  64 + <form id="form_post" method="post" action="{% url 'course:forum:create_post' %}" enctype="multipart/form-data">
  65 + {% csrf_token %}
  66 + {% for field in form %}
  67 + {% if field.field.widget.input_type == 'hidden' %}
  68 + {% render_field field class='form-control' value=forum.id %}
  69 + {% else %}
  70 + <div class="form-group {% if form.has_error %} has-error {% endif %} is-fileinput">
  71 + <div class="input-group">
  72 + {% render_field field class='form-control' placeholder="Post a message" %}
  73 + <span class="help-block">{{ field.help_text }}</span>
  74 + {% if field.errors %}
  75 + <div class="row">
  76 + <br />
  77 + <div class="alert alert-danger alert-dismissible" role="alert">
  78 + <button type="button" class="close" data-dismiss="alert" aria-label="Close">
  79 + <span aria-hidden="true">&times;</span>
  80 + </button>
  81 + <ul>
  82 + {% for error in field.errors %}
  83 + <li>{{ error }}</li>
  84 + {% endfor %}
  85 + </ul>
  86 + </div>
  87 + </div>
  88 + {% endif %}
  89 + <span class="input-group-btn">
  90 + <button type="submit" class="btn btn-fab btn-fab-mini">
  91 + <i class="material-icons">send</i>
  92 + </button>
  93 + </span>
  94 + </div>
  95 + </div>
  96 + {% endif %}
  97 + {% endfor %}
  98 + </form>
  99 + <hr />
  100 + </div>
63 101 <div id="posts_list">
64 102 {% list_posts request forum %}
65 103 </div>
... ...
forum/urls.py
... ... @@ -5,7 +5,6 @@ from . import views
5 5  
6 6 urlpatterns = [
7 7 url(r'^$', views.ForumIndex.as_view(), name='index'),
8   - url(r'^(?P<slug>[\w_-]+)/$', views.ForumDetailView.as_view(), name='view'),
9 8 url(r'^create/$', views.CreateForumView.as_view(), name='create'),
10 9 url(r'^delete/(?P<pk>[\w_-]+)/$', views.ForumDeleteView.as_view(), name='delete'),
11 10 url(r'^render_forum/([\w_-]+)/$', views.render_forum, name='render_forum'),
... ... @@ -17,4 +16,5 @@ urlpatterns = [
17 16 url(r'^post_deleted/$', views.post_deleted, name='deleted_post'),
18 17 url(r'^post_answers/$', views.PostAnswerIndex.as_view(), name='post_answers'),
19 18 url(r'^reply_post/$', views.CreatePostAnswerView.as_view(), name='reply_post'),
  19 + url(r'^(?P<slug>[\w_-]+)/$', views.ForumDetailView.as_view(), name='view'),
20 20 ]
... ...
forum/views.py
... ... @@ -74,6 +74,7 @@ class ForumDetailView(LoginRequiredMixin, generic.DetailView):
74 74 context = super(ForumDetailView, self).get_context_data(**kwargs)
75 75 forum = get_object_or_404(Forum, slug = self.kwargs.get('slug'))
76 76  
  77 + context['form'] = PostForm()
77 78 context['forum'] = forum
78 79 context['title'] = forum.name
79 80  
... ... @@ -145,6 +146,8 @@ class PostAnswerIndex(LoginRequiredMixin, generic.ListView):
145 146 return context
146 147  
147 148 class CreatePostAnswerView(LoginRequiredMixin, generic.edit.CreateView):
  149 + login_url = reverse_lazy("core:home")
  150 + redirect_field_name = 'next'
148 151  
149 152 template_name = 'post_answers/post_answer_form.html'
150 153 form_class = PostAnswerForm
... ...
links/__init__.py 0 → 100644
links/admin.py 0 → 100644
... ... @@ -0,0 +1,3 @@
  1 +from django.contrib import admin
  2 +
  3 +# Register your models here.
... ...
links/apps.py 0 → 100644
... ... @@ -0,0 +1,5 @@
  1 +from django.apps import AppConfig
  2 +
  3 +
  4 +class LinksConfig(AppConfig):
  5 + name = 'links'
... ...
links/migrations/__init__.py 0 → 100644
links/models.py 0 → 100644
... ... @@ -0,0 +1,15 @@
  1 +from django.db import models
  2 +from courses.models import Material
  3 +# Create your models here.
  4 +class Link(Material,models.Model):
  5 + name = models.CharField(max_lenght = 100)
  6 + link = models.UrlField()
  7 + description = models.CharField(max_lenght = 200)
  8 + class Meta:
  9 + verbose_name = 'Link'
  10 + verbose_name_plural = "Links"
  11 + def __str__(self):
  12 + return str(self.name)
  13 +
  14 +
  15 +
... ...
links/tests.py 0 → 100644
... ... @@ -0,0 +1,3 @@
  1 +from django.test import TestCase
  2 +
  3 +# Create your tests here.
... ...
links/views.py 0 → 100644
... ... @@ -0,0 +1,3 @@
  1 +from django.shortcuts import render
  2 +
  3 +# Create your views here.
... ...