Commit f1b417493cad31487a7eab0f08d46cccb6f05ab5

Authored by filipecmedeiros
2 parents eedf7a4e 344859b6

Merged branch dev into dev

@@ -37,7 +37,7 @@ class RegisterUserForm(forms.ModelForm): @@ -37,7 +37,7 @@ class RegisterUserForm(forms.ModelForm):
37 def clean_cpf(self): 37 def clean_cpf(self):
38 cpf = self.cleaned_data['cpf'] 38 cpf = self.cleaned_data['cpf']
39 if User.objects.filter(cpf = cpf).exists(): 39 if User.objects.filter(cpf = cpf).exists():
40 - raise forms.ValidationError(_('There is already a registeres User with this CPF')) 40 + raise forms.ValidationError(_('There is already a registered User with this CPF'))
41 # if not self.validate_cpf(cpf): 41 # if not self.validate_cpf(cpf):
42 # raise forms.ValidationError(_('Please enter a valid CPF')) 42 # raise forms.ValidationError(_('Please enter a valid CPF'))
43 return cpf 43 return cpf
@@ -76,4 +76,4 @@ class RegisterUserForm(forms.ModelForm): @@ -76,4 +76,4 @@ class RegisterUserForm(forms.ModelForm):
76 model = User 76 model = User
77 # exclude = ['is_staff', 'is_active'] 77 # exclude = ['is_staff', 'is_active']
78 fields = ['username', 'name', 'email', 'city', 'state', 'gender', 'cpf', 'birth_date', 'phone', 'image', 'titration', 78 fields = ['username', 'name', 'email', 'city', 'state', 'gender', 'cpf', 'birth_date', 'phone', 'image', 'titration',
79 - 'year_titration', 'institution', 'curriculum',]  
80 \ No newline at end of file 79 \ No newline at end of file
  80 + 'year_titration', 'institution', 'curriculum',]
courses/forms.py
@@ -42,16 +42,11 @@ class CourseForm(forms.ModelForm): @@ -42,16 +42,11 @@ class CourseForm(forms.ModelForm):
42 raise forms.ValidationError(_('The end date may not be before the start date.')) 42 raise forms.ValidationError(_('The end date may not be before the start date.'))
43 return end_date 43 return end_date
44 44
45 - # init_register_date = forms.DateField(widget=forms.DateField)  
46 - # end_register_date = forms.DateField(widget=forms.DateField)  
47 - # init_date = forms.DateField(widget=forms.DateField)  
48 - # end_date = forms.DateField(widget=forms.DateField)  
49 -  
50 45
51 class Meta: 46 class Meta:
52 model = Course 47 model = Course
53 fields = ('name', 'objectivies', 'content', 'max_students', 'init_register_date', 'end_register_date', 48 fields = ('name', 'objectivies', 'content', 'max_students', 'init_register_date', 'end_register_date',
54 - 'init_date', 'end_date', 'category', 'coordenator') 49 + 'init_date', 'end_date', 'category', 'coordenator','public')
55 labels = { 50 labels = {
56 'name': _('Name'), 51 'name': _('Name'),
57 'objectivies': _('Objectives'), 52 'objectivies': _('Objectives'),
@@ -61,8 +56,9 @@ class CourseForm(forms.ModelForm): @@ -61,8 +56,9 @@ class CourseForm(forms.ModelForm):
61 'end_register_date': _('Course registration end date'), 56 'end_register_date': _('Course registration end date'),
62 'init_date': _('Course start date'), 57 'init_date': _('Course start date'),
63 'end_date': _('Course end date'), 58 'end_date': _('Course end date'),
64 - 'category': _('CourseCategory'), 59 + 'category': _('Category'),
65 'coordenator': _('Coordenator'), 60 'coordenator': _('Coordenator'),
  61 + 'public':_('Public'),
66 } 62 }
67 help_texts = { 63 help_texts = {
68 'name': _('Course name'), 64 'name': _('Course name'),
@@ -75,16 +71,42 @@ class CourseForm(forms.ModelForm): @@ -75,16 +71,42 @@ class CourseForm(forms.ModelForm):
75 'end_date': _('Date that the course ends (dd/mm/yyyy)'), 71 'end_date': _('Date that the course ends (dd/mm/yyyy)'),
76 'category': _('CourseCategory which the course belongs'), 72 'category': _('CourseCategory which the course belongs'),
77 'coordenator': _('Course Coordenator'), 73 'coordenator': _('Course Coordenator'),
  74 + 'public':_('To define if the course can be accessed by people not registered'),
78 } 75 }
79 76
80 widgets = { 77 widgets = {
81 - 'categoy': forms.Select(), 78 + 'ategoy': forms.Select(),
82 'coordenator': forms.Select(), 79 'coordenator': forms.Select(),
83 - 'objectivies': SummernoteWidget(attrs={'cols': 80, 'rows': 5}),  
84 - 'content': SummernoteWidget(attrs={'cols': 80, 'rows': 5}), 80 + 'content': SummernoteWidget(),
  81 + 'objectivies': SummernoteWidget(),
85 } 82 }
86 83
87 class UpdateCourseForm(CourseForm): 84 class UpdateCourseForm(CourseForm):
  85 +
  86 + def clean_end_register_date(self):
  87 + init_register_date = self.cleaned_data['init_register_date']
  88 + end_register_date = self.cleaned_data['end_register_date']
  89 +
  90 + if init_register_date and end_register_date and end_register_date < init_register_date:
  91 + raise forms.ValidationError(_('The end date may not be before the start date.'))
  92 + return end_register_date
  93 +
  94 + def clean_init_date(self):
  95 + end_register_date = self.cleaned_data['end_register_date']
  96 + init_date = self.cleaned_data['init_date']
  97 +
  98 + if end_register_date and init_date and init_date <= end_register_date:
  99 + raise forms.ValidationError(_('The course start date must be after the end of registration.'))
  100 + return init_date
  101 +
  102 + def clean_end_date(self):
  103 + init_date = self.cleaned_data['init_date']
  104 + end_date = self.cleaned_data['end_date']
  105 +
  106 + if init_date and end_date and end_date < init_date:
  107 + raise forms.ValidationError(_('The end date may not be before the start date.'))
  108 + return end_date
  109 +
88 def __init__(self, *args, **kwargs): 110 def __init__(self, *args, **kwargs):
89 super(UpdateCourseForm, self).__init__(*args, **kwargs) 111 super(UpdateCourseForm, self).__init__(*args, **kwargs)
90 self.fields["students"].required = False 112 self.fields["students"].required = False
@@ -92,7 +114,7 @@ class UpdateCourseForm(CourseForm): @@ -92,7 +114,7 @@ class UpdateCourseForm(CourseForm):
92 class Meta: 114 class Meta:
93 model = Course 115 model = Course
94 fields = ('name', 'objectivies', 'content', 'max_students', 'init_register_date', 'end_register_date', 116 fields = ('name', 'objectivies', 'content', 'max_students', 'init_register_date', 'end_register_date',
95 - 'init_date', 'end_date', 'category','students', 'coordenator') 117 + 'init_date', 'end_date', 'category','students', 'coordenator','public')
96 labels = { 118 labels = {
97 'name': _('Name'), 119 'name': _('Name'),
98 'objectivies': _('Objectives'), 120 'objectivies': _('Objectives'),
@@ -102,9 +124,10 @@ class UpdateCourseForm(CourseForm): @@ -102,9 +124,10 @@ class UpdateCourseForm(CourseForm):
102 'end_register_date': _('Course registration end date'), 124 'end_register_date': _('Course registration end date'),
103 'init_date': _('Course start date'), 125 'init_date': _('Course start date'),
104 'end_date': _('Course end date'), 126 'end_date': _('Course end date'),
105 - 'category': _('CourseCategory'), 127 + 'category': _('Category'),
106 'coordenator': _('Coordenator'), 128 'coordenator': _('Coordenator'),
107 'students': _('Student'), 129 'students': _('Student'),
  130 + 'public':_('Public'),
108 } 131 }
109 help_texts = { 132 help_texts = {
110 'name': _('Course name'), 133 'name': _('Course name'),
@@ -118,12 +141,13 @@ class UpdateCourseForm(CourseForm): @@ -118,12 +141,13 @@ class UpdateCourseForm(CourseForm):
118 'category': _('CourseCategory which the course belongs'), 141 'category': _('CourseCategory which the course belongs'),
119 'coordenator': _('Course Coordenator'), 142 'coordenator': _('Course Coordenator'),
120 'students': _("Course's Students"), 143 'students': _("Course's Students"),
  144 + 'public':_('To define if the course can be accessed by people not registered'),
121 } 145 }
122 widgets = { 146 widgets = {
123 'categoy': forms.Select(), 147 'categoy': forms.Select(),
124 'coordenator': forms.Select(), 148 'coordenator': forms.Select(),
125 - 'objectivies': SummernoteWidget(attrs={'cols': 80, 'rows': 5}),  
126 - 'content': SummernoteWidget(attrs={'cols': 80, 'rows': 5}), 149 + 'content': SummernoteWidget(),
  150 + 'objectivies': SummernoteWidget(),
127 } 151 }
128 152
129 class SubjectForm(forms.ModelForm): 153 class SubjectForm(forms.ModelForm):
courses/templates/course/create.html
@@ -17,10 +17,17 @@ @@ -17,10 +17,17 @@
17 {% csrf_token %} 17 {% csrf_token %}
18 {% for field in form %} 18 {% for field in form %}
19 <div class="form-group {% if form.has_error %} has-error {% endif %} is-fileinput"> 19 <div class="form-group {% if form.has_error %} has-error {% endif %} is-fileinput">
20 - <label for="{{ field.auto_id }}">{{ field.label }}</label> 20 + {% if field.auto_id != 'id_public' %}
  21 + <label for="{{ field.auto_id }}">{{ field.label }}</label>
  22 + {% endif %}
21 {% if field.auto_id == 'id_init_register_date' or field.auto_id == 'id_end_register_date' or field.auto_id == 'id_init_date' or field.auto_id == 'id_end_date'%} 23 {% if field.auto_id == 'id_init_register_date' or field.auto_id == 'id_end_register_date' or field.auto_id == 'id_init_date' or field.auto_id == 'id_end_date'%}
22 <input type="text" class="form-control date-picker" name="{{field.name}}" value="{{field.value|date:'SHORT_DATE_FORMAT'}}" min="{{now|date:'SHORT_DATE_FORMAT'}}"> 24 <input type="text" class="form-control date-picker" name="{{field.name}}" value="{{field.value|date:'SHORT_DATE_FORMAT'}}" min="{{now|date:'SHORT_DATE_FORMAT'}}">
23 - 25 + {% elif field.auto_id == 'id_public' %}
  26 + <div class="checkbox">
  27 + <label>
  28 + <input type="checkbox" name="{{field.name}}" {% if field.value %}checked="checked"{% endif %}><span class="checkbox-material"></span> {{field.name}}
  29 + </label>
  30 + </div>
24 {% else %} 31 {% else %}
25 {% render_field field class='form-control' %} 32 {% render_field field class='form-control' %}
26 {% endif %} 33 {% endif %}
@@ -49,6 +56,8 @@ @@ -49,6 +56,8 @@
49 </div> 56 </div>
50 </div> 57 </div>
51 </br> 58 </br>
  59 +</br>
  60 +</br>
52 <script type="text/javascript"> 61 <script type="text/javascript">
53 var locale = navigator.language || navigator.userLanguage; 62 var locale = navigator.language || navigator.userLanguage;
54 63
courses/templates/course/replicate.html
1 {% extends 'course/view.html' %} 1 {% extends 'course/view.html' %}
2 2
3 {% load static i18n %} 3 {% load static i18n %}
4 -{% load widget_tweaks %} 4 +{% load widget_tweaks course_value_field %}
5 5
6 {% block breadcrumbs %} 6 {% block breadcrumbs %}
7 <ol class="breadcrumb"> 7 <ol class="breadcrumb">
@@ -12,131 +12,79 @@ @@ -12,131 +12,79 @@
12 12
13 {% block content %} 13 {% block content %}
14 <div class="card card-content"> 14 <div class="card card-content">
15 - <div class="card-body"> 15 + <div class="card-body">
16 <form method="post" action="" enctype="multipart/form-data"> 16 <form method="post" action="" enctype="multipart/form-data">
17 {% csrf_token %} 17 {% csrf_token %}
18 - <div class="form-group is-fileinput">  
19 - <label for="id_name">{% trans 'Name' %}</label>  
20 -  
21 -  
22 - <input class="form-control" id="id_name" maxlength="100" name="name" type="text" required="" value="{{course.name}}">  
23 -  
24 - <span class="help-block">{% trans 'Course name' %}</span>  
25 -  
26 - </div>  
27 -  
28 - <div class="form-group is-fileinput">  
29 - <label for="id_objectivies">{% trans 'Objectives' %}</label>  
30 -  
31 - <textarea class="form-control" cols="80" id="id_objectivies" name="objectivies" rows="5">{{ course.objectivies }}</textarea>  
32 -  
33 - <span class="help-block">{% trans 'Course objective' %}</span>  
34 -  
35 - </div>  
36 -  
37 - <div class="form-group is-fileinput">  
38 - <label for="id_content">{% trans 'Content' %}</label>  
39 -  
40 -  
41 - <textarea class="form-control" cols="80" id="id_content" name="content" rows="5">{{course.content}}</textarea>  
42 -  
43 - <span class="help-block">{% trans 'Course modules' %}</span>  
44 -  
45 - </div>  
46 -  
47 - <div class="form-group is-fileinput">  
48 - <label for="id_max_students">{% trans 'Number of studets maximum' %}</label>  
49 -  
50 -  
51 - <input class="form-control" id="id_max_students" min="0" name="max_students" type="number" value="{{course.max_students}}">  
52 -  
53 - <span class="help-block">{% trans 'Max number of students that a class can have' %}</span>  
54 -  
55 - </div>  
56 -  
57 - <div class="form-group is-fileinput">  
58 - <label for="id_init_register_date">{% trans 'Course registration start date' %}</label>  
59 -  
60 -  
61 - <input type="text" class="form-control date-picker" name="init_register_date" value="{{field.value|date:'SHORT_DATE_FORMAT'}}" min="{{now|date:'SHORT_DATE_FORMAT'}}">  
62 -  
63 - <span class="help-block">{% trans 'Date that starts the registration period of the course (dd/mm/yyyy)' %}</span>  
64 -  
65 - </div>  
66 -  
67 - <div class="form-group is-fileinput">  
68 - <label for="id_end_register_date">{% trans 'Course registration end date' %}</label>  
69 -  
70 -  
71 - <input type="text" class="form-control date-picker" name="end_register_date" value="{{field.value|date:'SHORT_DATE_FORMAT'}}" min="{{now|date:'SHORT_DATE_FORMAT'}}">  
72 -  
73 - <span class="help-block">{% trans 'Date that ends the registration period of the course (dd/mm/yyyy)' %}</span>  
74 -  
75 - </div>  
76 -  
77 - <div class="form-group is-fileinput">  
78 - <label for="id_init_date">{% trans 'Course start date' %}</label>  
79 -  
80 -  
81 - <input type="text" class="form-control date-picker" name="init_date" value="{{field.value|date:'SHORT_DATE_FORMAT'}}" min="{{now|date:'SHORT_DATE_FORMAT'}}">  
82 -  
83 - <span class="help-block">{% trans 'Date that the course starts (dd/mm/yyyy)' %}</span>  
84 -  
85 - </div>  
86 -  
87 - <div class="form-group is-fileinput">  
88 - <label for="id_end_date">{% trans 'Course end date' %}</label>  
89 -  
90 -  
91 - <input type="text" class="form-control date-picker" name="end_date" value="{{field.value|date:'SHORT_DATE_FORMAT'}}" min="{{now|date:'SHORT_DATE_FORMAT'}}">  
92 -  
93 - <span class="help-block">{% trans 'Date that the course ends (dd/mm/yyyy)' %}</span>  
94 -  
95 - </div>  
96 -  
97 - <div class="form-group is-fileinput">  
98 - <label for="id_image">{% trans 'Imagem' %}</label>  
99 -  
100 -  
101 - <input class="form-control" id="id_image" name="image" type="file">  
102 - <div class="input-group">  
103 - <input type="text" readonly="" class="form-control" placeholder="Choose your photo...">  
104 - <span class="input-group-btn input-group-sm">  
105 - <button type="button" class="btn btn-fab btn-fab-mini">  
106 - <i class="material-icons">{% trans 'attach_file' %}</i>  
107 - </button>  
108 - </span> 18 + {% for field in form %}
  19 + <div class="form-group {% if form.has_error %} has-error {% endif %} is-fileinput">
  20 + {% if field.auto_id != 'id_public' %}
  21 + <label for="{{ field.auto_id }}">{{ field.label }}</label>
  22 + {% endif %}
  23 + {% if field.auto_id == 'id_init_register_date' or field.auto_id == 'id_end_register_date' or field.auto_id == 'id_init_date' or field.auto_id == 'id_end_date'%}
  24 + <input type="text" class="form-control date-picker" name="{{field.name}}" value="{{field.value|date:'SHORT_DATE_FORMAT'}}" min="{{now|date:'SHORT_DATE_FORMAT'}}">
  25 + {% elif field.auto_id == 'id_public' %}
  26 + {% value_field course field.name as value_field %}
  27 + <div class="checkbox">
  28 + <label>
  29 + <input type="checkbox" name="{{field.name}}" {% if value_field %}checked="checked"{% endif %}><span class="checkbox-material"></span> {{field.name}}
  30 + </label>
  31 + </div>
  32 + {% else %}
  33 + {% if field.errors %}
  34 + {% render_field field class='form-control' %}
  35 + {% else %}
  36 + {% value_field course field.name as value_field %}
  37 + {% if field.auto_id == 'id_category' or field.auto_id == 'id_coordenator' %}
  38 + {% get_value_choice value_field field.field.choices as field_choice%}
  39 + <select class="form-control" id="{{field.auto_id}}" name="{{field.name}}" required="">
  40 + {% for v, name in field.field.choices%}
  41 + <option value="{{v}}" {% if field_choice == v %}selected{% endif %}>{{name}}</option>
  42 + {% endfor %}
  43 + </select>
  44 + {% elif field.auto_id == 'id_objectivies' or field.auto_id == 'id_content'%}
  45 + <textarea class="form-control" cols="80" id="{{field.auto_id}}" name="{{field.name}}" rows="5">{{value_field}}</textarea>
  46 + {% else %}
  47 + {% render_field field class='form-control' value=value_field%}
  48 + {% endif %}
  49 + {% endif %}
  50 + {% endif %}
  51 + <span class="help-block">{{ field.help_text }}</span>
  52 + {% if field.errors %}
  53 + <div class="row">
  54 + </br>
  55 + <div class="alert alert-danger alert-dismissible" role="alert">
  56 + <button type="button" class="close" data-dismiss="alert" aria-label="Close">
  57 + <span aria-hidden="true">&times;</span>
  58 + </button>
  59 + <ul>
  60 + {% for error in field.errors %}
  61 + <li>{{ error }}</li>
  62 + {% endfor %}
  63 + </ul>
  64 + </div>
  65 + </div>
  66 + {% endif %}
109 </div> 67 </div>
110 -  
111 - <span class="help-block">{% trans 'Representative image of the course' %}</span>  
112 -  
113 - </div>  
114 -  
115 - <div class="form-group is-fileinput">  
116 - <label for="id_category">{% trans 'CourseCategory' %}</label>  
117 -  
118 -  
119 - <select class="form-control" id="id_category" name="category" required="">  
120 - {% for category in categorys_courses %}  
121 - <option value="{{category.id}}">{{category}}</option>  
122 - {% endfor %}  
123 - </select>  
124 -  
125 - <span class="help-block">{% trans 'CourseCategory which the course belongs' %}</span>  
126 -  
127 - </div>  
128 - 68 + {% endfor %}
129 <div class="row text-center"> 69 <div class="row text-center">
130 - <input type="submit" value="Create" class="btn btn-primary btn-raised"> 70 + <input type="submit" value="{% trans 'Create' %}" class="btn btn-primary btn-raised" />
131 </div> 71 </div>
132 - </form> 72 + </form>
133 </div> 73 </div>
134 </div> 74 </div>
135 - <script>  
136 - $(document).ready(function() {  
137 - $('#id_objectivies').summernote();  
138 - $('#id_content').summernote(); 75 +</br>
  76 +</br>
  77 +</br>
  78 +<script type="text/javascript">
  79 + var locale = navigator.language || navigator.userLanguage;
  80 +
  81 + $('.date-picker').datepicker({
  82 + language: locale,
  83 + });
  84 +
  85 + $(document).ready(function() {
  86 + $('#id_objectivies').summernote({'height':300});
  87 + $('#id_content').summernote({'height':300});
139 }); 88 });
140 - </script>  
141 -</br></br></br> 89 +</script>
142 {% endblock %} 90 {% endblock %}
courses/templates/course/update.html
@@ -16,9 +16,17 @@ @@ -16,9 +16,17 @@
16 {% csrf_token %} 16 {% csrf_token %}
17 {% for field in form %} 17 {% for field in form %}
18 <div class="form-group {% if form.has_error %} has-error {% endif %} is-fileinput"> 18 <div class="form-group {% if form.has_error %} has-error {% endif %} is-fileinput">
19 - <label for="{{ field.auto_id }}">{{ field.label }}</label> 19 + {% if field.auto_id != 'id_public' %}
  20 + <label for="{{ field.auto_id }}">{{ field.label }}</label>
  21 + {% endif %}
20 {% if field.auto_id == 'id_init_register_date' or field.auto_id == 'id_end_register_date' or field.auto_id == 'id_init_date' or field.auto_id == 'id_end_date'%} 22 {% if field.auto_id == 'id_init_register_date' or field.auto_id == 'id_end_register_date' or field.auto_id == 'id_init_date' or field.auto_id == 'id_end_date'%}
21 <input type="text" class="form-control date-picker" name="{{field.name}}" value="{{field.value|date:'SHORT_DATE_FORMAT'}}" min="{{now|date:'SHORT_DATE_FORMAT'}}"> 23 <input type="text" class="form-control date-picker" name="{{field.name}}" value="{{field.value|date:'SHORT_DATE_FORMAT'}}" min="{{now|date:'SHORT_DATE_FORMAT'}}">
  24 + {% elif field.auto_id == 'id_public' %}
  25 + <div class="checkbox">
  26 + <label>
  27 + <input type="checkbox" name="{{field.name}}" {% if field.value %}checked="checked"{% endif %}><span class="checkbox-material"></span> {{field.name}}
  28 + </label>
  29 + </div>
22 {% else %} 30 {% else %}
23 {% render_field field class='form-control' %} 31 {% render_field field class='form-control' %}
24 {% endif %} 32 {% endif %}
courses/templatetags/course_value_field.py 0 → 100644
@@ -0,0 +1,53 @@ @@ -0,0 +1,53 @@
  1 +from django import template
  2 +
  3 +register = template.Library()
  4 +
  5 +"""
  6 + Template tag to load all the foruns of a post
  7 +"""
  8 +
  9 +@register.simple_tag
  10 +def value_field(course, field):
  11 + value = ""
  12 + if field == 'name':
  13 + value = course.name
  14 + elif field == 'objectivies':
  15 + value = course.objectivies
  16 + elif field == 'content':
  17 + value = course.content
  18 + elif field == 'max_students':
  19 + value = course.max_students
  20 + elif field == 'init_register_date':
  21 + value = course.init_register_date
  22 + elif field == 'end_register_date':
  23 + value = course.end_register_date
  24 + elif field == 'init_date':
  25 + value = course.init_date
  26 + elif field == 'end_date':
  27 + value = course.end_date
  28 + elif field == 'coordenator':
  29 + value = course.coordenator
  30 + elif field == 'category':
  31 + value = course.category
  32 + elif field == 'professors':
  33 + value = course.professors.all()
  34 + elif field == 'students':
  35 + value = course.students.all()
  36 + elif field == 'public':
  37 + value = course.public
  38 +
  39 + return value
  40 +
  41 +
  42 +@register.simple_tag
  43 +def get_value_choice(value, choices):
  44 + for v, name in choices:
  45 + if (str(name) == str(value)): return v
  46 +
  47 + return ""
  48 +
  49 +@register.simple_tag
  50 +def get_tag(field):
  51 + field.value = "cacsdv"
  52 + print (dir(field.field))
  53 + print (dir(field.field.widget),field.name,"\n\n\n")
courses/views.py
@@ -216,6 +216,7 @@ class ReplicateCourseView(LoginRequiredMixin, HasRoleMixin, LogMixin, Notificati @@ -216,6 +216,7 @@ class ReplicateCourseView(LoginRequiredMixin, HasRoleMixin, LogMixin, Notificati
216 context['categorys_courses'] = categorys_courses 216 context['categorys_courses'] = categorys_courses
217 context['title'] = _("Replicate Course") 217 context['title'] = _("Replicate Course")
218 context['now'] = date.today() 218 context['now'] = date.today()
  219 + print (course.public)
219 return context 220 return context
220 221
221 def get_success_url(self): 222 def get_success_url(self):
@@ -243,6 +244,7 @@ class UpdateCourseView(LoginRequiredMixin, HasRoleMixin, LogMixin, generic.Updat @@ -243,6 +244,7 @@ class UpdateCourseView(LoginRequiredMixin, HasRoleMixin, LogMixin, generic.Updat
243 def form_valid(self, form): 244 def form_valid(self, form):
244 self.object = form.save() 245 self.object = form.save()
245 246
  247 + print (form)
246 self.log_context['course_id'] = self.object.id 248 self.log_context['course_id'] = self.object.id
247 self.log_context['course_name'] = self.object.name 249 self.log_context['course_name'] = self.object.name
248 self.log_context['course_slug'] = self.object.slug 250 self.log_context['course_slug'] = self.object.slug
@@ -256,7 +258,7 @@ class UpdateCourseView(LoginRequiredMixin, HasRoleMixin, LogMixin, generic.Updat @@ -256,7 +258,7 @@ class UpdateCourseView(LoginRequiredMixin, HasRoleMixin, LogMixin, generic.Updat
256 def get_context_data(self, **kwargs): 258 def get_context_data(self, **kwargs):
257 context = super(UpdateCourseView, self).get_context_data(**kwargs) 259 context = super(UpdateCourseView, self).get_context_data(**kwargs)
258 course = get_object_or_404(Course, slug = self.kwargs.get('slug')) 260 course = get_object_or_404(Course, slug = self.kwargs.get('slug'))
259 - 261 + print (course.public)
260 if has_role(self.request.user,'system_admin'): 262 if has_role(self.request.user,'system_admin'):
261 courses = Course.objects.all() 263 courses = Course.objects.all()
262 elif has_role(self.request.user,'professor'): 264 elif has_role(self.request.user,'professor'):
@@ -445,28 +447,11 @@ class IndexCatView(LoginRequiredMixin, generic.ListView): @@ -445,28 +447,11 @@ class IndexCatView(LoginRequiredMixin, generic.ListView):
445 447
446 login_url = reverse_lazy("core:home") 448 login_url = reverse_lazy("core:home")
447 redirect_field_name = 'next' 449 redirect_field_name = 'next'
448 - queryset = CourseCategory.objects.all() 450 + queryset = sorted(CourseCategory.objects.all(),key = lambda x:x.name)
449 template_name = 'category/index.html' 451 template_name = 'category/index.html'
450 context_object_name = 'categories' 452 context_object_name = 'categories'
451 paginate_by = 5 453 paginate_by = 5
452 -  
453 - def get_context_data(self, **kwargs):  
454 - context = super(IndexCatView, self).get_context_data(**kwargs)  
455 - list_cat = CourseCategory.objects.filter(course_category = True).order_by('name')  
456 - paginator = Paginator(list_cat, self.paginate_by)  
457 - page = self.request.GET.get('page')  
458 -  
459 - try:  
460 - list_cat = paginator.page(page)  
461 - except PageNotAnInteger:  
462 - list_cat = paginator.page(1)  
463 - except EmptyPage:  
464 - list_cat = paginator.page(paginator.num_pages)  
465 -  
466 - context['list_cat'] = list_cat  
467 -  
468 - return context  
469 - 454 +
470 class CreateCatView(LoginRequiredMixin, HasRoleMixin, generic.edit.CreateView): 455 class CreateCatView(LoginRequiredMixin, HasRoleMixin, generic.edit.CreateView):
471 456
472 allowed_roles = ['professor', 'system_admin'] 457 allowed_roles = ['professor', 'system_admin']
@@ -477,7 +462,8 @@ class CreateCatView(LoginRequiredMixin, HasRoleMixin, generic.edit.CreateView): @@ -477,7 +462,8 @@ class CreateCatView(LoginRequiredMixin, HasRoleMixin, generic.edit.CreateView):
477 success_url = reverse_lazy('course:manage_cat') 462 success_url = reverse_lazy('course:manage_cat')
478 463
479 def get_success_url(self): 464 def get_success_url(self):
480 - messages.success(self.request, _('Category created successfully!')) 465 + objeto = self.object.name
  466 + messages.success(self.request, _('Category "%s" created successfully!')%(objeto))
481 return reverse_lazy('course:manage_cat') 467 return reverse_lazy('course:manage_cat')
482 468
483 class UpdateCatView(LoginRequiredMixin, HasRoleMixin, generic.UpdateView): 469 class UpdateCatView(LoginRequiredMixin, HasRoleMixin, generic.UpdateView):
@@ -488,11 +474,13 @@ class UpdateCatView(LoginRequiredMixin, HasRoleMixin, generic.UpdateView): @@ -488,11 +474,13 @@ class UpdateCatView(LoginRequiredMixin, HasRoleMixin, generic.UpdateView):
488 template_name = 'category/update.html' 474 template_name = 'category/update.html'
489 model = CourseCategory 475 model = CourseCategory
490 form_class = CategoryCourseForm 476 form_class = CategoryCourseForm
  477 + success_url = reverse_lazy('course:manage_cat')
491 478
492 def get_success_url(self): 479 def get_success_url(self):
493 - messages.success(self.request, _('Category updated successfully!'))  
494 - return reverse_lazy('course:update_cat', kwargs={'slug' : self.object.slug})  
495 - 480 + objeto = self.object.name
  481 + messages.success(self.request, _('Category "%s" updated successfully!')%(objeto))
  482 + #return reverse_lazy('course:update_cat', kwargs={'slug' : self.object.slug})
  483 + return reverse_lazy('course:manage_cat')
496 class DeleteCatView(LoginRequiredMixin, HasRoleMixin, generic.DeleteView): 484 class DeleteCatView(LoginRequiredMixin, HasRoleMixin, generic.DeleteView):
497 485
498 allowed_roles = ['professor', 'system_admin'] 486 allowed_roles = ['professor', 'system_admin']