Commit 8d127da80ee900234d29ca180a5b92ead5736dae
1 parent
9e08c780
Exists in
master
and in
3 other branches
Adding profile and fixing some html
Showing
10 changed files
with
237 additions
and
351 deletions
Show diff stats
amadeus/templates/base.html
| 1 | 1 | <!DOCTYPE html> |
| 2 | 2 | |
| 3 | 3 | {% load static i18n %} |
| 4 | -{% load static i18n permission_tags %} | |
| 4 | +{% load static i18n permission_tags django_bootstrap_breadcrumbs %} | |
| 5 | 5 | {% get_current_language as LANGUAGE_CODE %} |
| 6 | 6 | |
| 7 | 7 | <html> |
| 8 | 8 | <head> |
| 9 | 9 | <title>{{ title }} | Amadeus</title> |
| 10 | 10 | |
| 11 | - <!-- jQuery & jQuery UI --> | |
| 12 | - <script type="text/javascript" src="{% static 'js/jquery-3.1.0.min.js' %}"></script> | |
| 13 | - <script type="text/javascript" src="{% static 'js/jquery-ui.js' %}"></script> | |
| 11 | + <!-- jQuery & jQuery UI --> | |
| 12 | + <script type="text/javascript" src="{% static 'js/jquery-3.1.0.min.js' %}"></script> | |
| 13 | + <script type="text/javascript" src="{% static 'js/jquery-ui.js' %}"></script> | |
| 14 | 14 | |
| 15 | 15 | <meta http-equiv="Cache-Control" content="no-cache, no-store" /> |
| 16 | 16 | <link href="{% static 'img/topo-amadeus.png' %}" rel="shortcut icon" /> |
| ... | ... | @@ -35,7 +35,7 @@ |
| 35 | 35 | <script type="text/javascript" src="{% static 'material/js/material.min.js' %}"></script> |
| 36 | 36 | <script type="text/javascript" src="{% static 'material/js/ripples.min.js' %}"></script> |
| 37 | 37 | <script type="text/javascript" src="{% static 'js/bootstrap-datepicker.js' %}"></script> |
| 38 | - {% with "js/vendor/locales/bootstrap-datepicker."|add:LANGUAGE_CODE|add:".js" as locale_datepicker %} | |
| 38 | + {% with "js/locales/bootstrap-datepicker."|add:LANGUAGE_CODE|add:".js" as locale_datepicker %} | |
| 39 | 39 | <script type="text/javascript" src="{% static locale_datepicker %}"></script> |
| 40 | 40 | {% endwith %} |
| 41 | 41 | <script type="text/javascript" src="{% static 'js/alertify.min.js' %}"></script> |
| ... | ... | @@ -45,12 +45,13 @@ |
| 45 | 45 | <link rel="stylesheet" type="text/css" href="{% static 'font-awesome-4.6.3/css/font-awesome.min.css' %}"> |
| 46 | 46 | |
| 47 | 47 | <!-- Custom styles --> |
| 48 | - <link rel="stylesheet" type="text/css" href="{% static 'css/base/amadeus.css' %}"> | |
| 48 | + <link rel="stylesheet" type="text/css" href="{% static 'css/base/amadeus.css' %}"> | |
| 49 | 49 | |
| 50 | 50 | <!--Javascript block for specific-app ones --> |
| 51 | 51 | <script src="{% static 'js/base/amadeus.js' %}"></script> |
| 52 | - <script src="{% static 'js/main.js' %}"></script> | |
| 53 | - {% block style %} | |
| 52 | + <script src="{% static 'js/main.js' %}"></script> | |
| 53 | + | |
| 54 | + {% block style %} | |
| 54 | 55 | {% endblock %} |
| 55 | 56 | {% block javascript %} |
| 56 | 57 | {% endblock %} |
| ... | ... | @@ -61,91 +62,114 @@ |
| 61 | 62 | |
| 62 | 63 | </head> |
| 63 | 64 | <body> |
| 64 | - {% block nav %} | |
| 65 | - <div class="navbar navbar-default"> | |
| 66 | - <div class="navbar-header"> | |
| 67 | - <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-responsive-collapse"> | |
| 68 | - <span class="icon-bar"></span> | |
| 69 | - <span class="icon-bar"></span> | |
| 70 | - <span class="icon-bar"></span> | |
| 71 | - </button> | |
| 72 | - <a class="navbar-brand" href="#"><img class="logo" src="{% static 'img/topo-amadeus-white.png' %}" alt="Logo"/></a> | |
| 73 | - </div> | |
| 74 | - <div class="navbar-collapse collapse navbar-responsive-collapse"> | |
| 75 | - <div class="col-md-5 cards-content" id= 'NavBarSearch'> | |
| 76 | - <form id="SearchForm" action="#" method="get" accept-charset="utf-8"> | |
| 77 | - <div class="input-group"> | |
| 78 | - <div class="form-group is-empty" > | |
| 79 | - <input type="text" class="form-control" placeholder="{% trans 'Search Files (.pdf, others) and/or activities' %}" name="search"> | |
| 65 | + {% block nav %} | |
| 66 | + <div class="navbar navbar-default"> | |
| 67 | + <div class="navbar-header"> | |
| 68 | + <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-responsive-collapse"> | |
| 69 | + <span class="icon-bar"></span> | |
| 70 | + <span class="icon-bar"></span> | |
| 71 | + <span class="icon-bar"></span> | |
| 72 | + </button> | |
| 73 | + <a class="navbar-brand" href="#"><img class="logo" src="{% static 'img/topo-amadeus-white.png' %}" alt="Logo"/></a> | |
| 80 | 74 | </div> |
| 81 | - <span class="input-group-btn input-group-sm"> | |
| 82 | - <button type="submit" class="btn btn-primary" id="btn-search"> | |
| 83 | - <i class="fa fa-search fa-2x" aria-hidden="true" style="color:#93C741"></i> | |
| 84 | - </button> | |
| 85 | - </span> | |
| 86 | - </div> | |
| 87 | - </form> | |
| 88 | - </div> | |
| 89 | - <ul class="nav navbar-nav navbar-right notifications"> | |
| 90 | - <li class="" data-toggle="tooltip" data-placement="bottom" title data-original-title="notifications"> | |
| 91 | - <a class="dropdown-toggle" data-toggle="dropdown"> <span id="notification-count" class="badge notification-count">{{notifications.count}}</span><i class="fa fa-bell" aria-hidden="true"></i></a> | |
| 92 | - <!--<ul id="notification-dropdown" class="dropdown-menu"> | |
| 93 | - <li class="dropdown-header"> {% trans 'Notifications' %}</li> | |
| 94 | - | |
| 95 | - <li> | |
| 96 | - <a onclick="getNotifications(5)"> | |
| 97 | - <div id="notification-see-more" class="list-group-item"> | |
| 98 | - <div class="row-content"> | |
| 99 | - <p class="list-group-item-text">{% trans 'See More' %}</p> | |
| 100 | - </div> | |
| 75 | + <div class="navbar-collapse collapse navbar-responsive-collapse"> | |
| 76 | + <div class="col-md-5 cards-content" id= 'NavBarSearch'> | |
| 77 | + <form id="SearchForm" action="#" method="get" accept-charset="utf-8"> | |
| 78 | + <div class="input-group"> | |
| 79 | + <div class="form-group is-empty" > | |
| 80 | + <input type="text" class="form-control" placeholder="{% trans 'Search Files (.pdf, others) and/or activities' %}" name="search"> | |
| 81 | + </div> | |
| 82 | + <span class="input-group-btn input-group-sm"> | |
| 83 | + <button type="submit" class="btn btn-primary" id="btn-search"> | |
| 84 | + <i class="fa fa-search fa-2x" aria-hidden="true" style="color:white"></i> | |
| 85 | + </button> | |
| 86 | + </span> | |
| 87 | + </div> | |
| 88 | + </form> | |
| 101 | 89 | </div> |
| 102 | - </a> | |
| 103 | - </li> | |
| 104 | - </ul> --> | |
| 105 | - </li> | |
| 106 | - <li data-toggle="tooltip" data-placement="bottom" title data-original-title="{% trans 'messages' %}"> <a href="#"><i class="fa fa-comments" aria-hidden="true"></i></a> </li> | |
| 107 | - <li> | |
| 108 | - <a href="" data-toggle="dropdown">{{ user }}</a> | |
| 109 | - <ul class="dropdown-menu pull-right"> | |
| 110 | - <li><a href="#">{% trans 'Perfil' %}</a></li> | |
| 111 | - <li><a href="#">{% trans 'Edit Profile' %}</a></li> | |
| 112 | - <li><a href="#">{% trans 'Change password' %}</a></li> | |
| 113 | - <li><a href="#">{% trans 'Remove account' %}</a></li> | |
| 114 | - </ul> | |
| 115 | - </li> | |
| 116 | - <li data-toggle="tooltip" data-placement="bottom" title data-original-title="log out"> <a href="#"><i class="fa fa-sign-out" aria-hidden="true"></i></a></li> | |
| 117 | - </ul> | |
| 118 | - </div> | |
| 119 | - </div> | |
| 120 | - {% endblock %} | |
| 121 | - <div class="container-fluid"> | |
| 122 | - <div class="row"> | |
| 123 | - <div class="col-xs-2 col-sm-2 col-md-2 col-lg-2 col-xl-2"> | |
| 124 | - {% block test %} | |
| 125 | - {% endblock %} | |
| 126 | - {% block sidebar %} | |
| 127 | - {% endblock %} | |
| 128 | - </div> | |
| 129 | - <div class="col-xs-10 col-sm-10 col-md-10 col-lg-10 col-xl-10"> | |
| 130 | - {% block breadcrumbs %}{% endblock %} | |
| 131 | - {% block render_breadcrumbs %}{% endblock %} | |
| 132 | - </div> | |
| 133 | - <div class="col-xs-10 col-sm-10 col-md-10 col-lg-10 col-xl-10"> | |
| 134 | - {% block content %}{% endblock %} | |
| 135 | - </div> | |
| 90 | + <ul class="nav navbar-nav navbar-right notifications"> | |
| 91 | + <!--<li class="" data-toggle="tooltip" data-placement="bottom" title data-original-title="notifications"> | |
| 92 | + <a class="dropdown-toggle" data-toggle="dropdown"> <span id="notification-count" class="badge notification-count">{{notifications.count}}</span><i class="fa fa-bell" aria-hidden="true"></i></a>- | |
| 93 | + <ul id="notification-dropdown" class="dropdown-menu"> | |
| 94 | + <li class="dropdown-header"> {% trans 'Notifications' %}</li> | |
| 95 | + | |
| 96 | + <li> | |
| 97 | + <a onclick="getNotifications(5)"> | |
| 98 | + <div id="notification-see-more" class="list-group-item"> | |
| 99 | + <div class="row-content"> | |
| 100 | + <p class="list-group-item-text">{% trans 'See More' %}</p> | |
| 101 | + </div> | |
| 102 | + </div> | |
| 103 | + </a> | |
| 104 | + </li> | |
| 105 | + </ul> | |
| 106 | + </li> --> | |
| 107 | + <li title data-original-title="{% trans 'settings' %}"> | |
| 108 | + <a href="" data-toggle="dropdown"><i class="fa fa-cog" aria-hidden="true"></i></a> | |
| 109 | + <ul class="dropdown-menu pull-right"> | |
| 110 | + <li><a href="#">{% trans 'Perfil' %}</a></li> | |
| 111 | + <li><a href="#">{% trans 'Edit Profile' %}</a></li> | |
| 112 | + <li><a href="#">{% trans 'Change password' %}</a></li> | |
| 113 | + <li><a href="#">{% trans 'Remove account' %}</a></li> | |
| 114 | + </ul> | |
| 115 | + </li> | |
| 116 | + <li> | |
| 117 | + <a href="{% url 'users:profile' %}" style="padding-top: 15px;padding-bottom:15px;"> | |
| 118 | + <img src="{{ user.image_url }}" style="width:30px;height:30px" /> | |
| 119 | + </a> | |
| 120 | + </li> | |
| 121 | + <li data-toggle="tooltip" data-placement="bottom" title data-original-title="log out"> | |
| 122 | + <a href="{% url 'users:logout' %}"><i class="fa fa-sign-out" aria-hidden="true"></i></a> | |
| 123 | + </li> | |
| 124 | + </ul> | |
| 125 | + </div> | |
| 126 | + </div> | |
| 127 | + {% endblock %} | |
| 128 | + <div class="container-fluid"> | |
| 129 | + <div class="row"> | |
| 130 | + <div class="col-xs-2 col-sm-2 col-md-2 col-lg-2 col-xl-2"> | |
| 131 | + {% block sidebar %} | |
| 132 | + <div class="panel panel-primary"> | |
| 133 | + <div class="panel-heading"> | |
| 134 | + <h4>{% trans 'Menu' %}</h4> | |
| 135 | + </div> | |
| 136 | + <div class="panel-body menu-lateral"> | |
| 137 | + <ul class="nav nav-pills nav-stacked"> | |
| 138 | + <li> | |
| 139 | + <a href="#menu_courses" class="accordion" data-toggle="collapse">{% trans 'Courses' %}<span class="pull-right glyphicon glyphicon-chevron-down"></span></a> | |
| 140 | + <div id="menu_courses" class="collapse"> | |
| 141 | + <ul class="nav nav-pill nav-stacked accordion_list"> | |
| 142 | + <li><a href="#"><i class="fa fa-book" aria-hidden="true"></i> {% trans 'My Courses' %} </a></li> | |
| 143 | + <li><a href="#"><i class="fa fa-globe" aria-hidden="true"></i> {% trans 'All Courses' %} </a></li> | |
| 144 | + {% if user|has_role:'system_admin' or user|has_role:'professor'%} | |
| 145 | + <li><a href="#"><i class="fa fa-list" aria-hidden="true"></i> {% trans 'List Category' %}</a></li> | |
| 146 | + <li><a href="#">{% trans 'Create Course' %}</a></li> | |
| 147 | + {% endif %} | |
| 148 | + </ul> | |
| 149 | + </div> | |
| 150 | + </li> | |
| 151 | + </ul> | |
| 152 | + </div> | |
| 153 | + </div> | |
| 154 | + {% endblock %} | |
| 155 | + </div> | |
| 156 | + <div class="col-xs-10 col-sm-10 col-md-10 col-lg-10 col-xl-10"> | |
| 157 | + {% block breadcrumbs %} | |
| 158 | + {% breadcrumb 'Home' 'home' %} | |
| 159 | + {% endblock %} | |
| 160 | + {% block render_breadcrumbs %} | |
| 161 | + {% render_breadcrumbs %} | |
| 162 | + {% endblock %} | |
| 163 | + </div> | |
| 164 | + <div class="col-xs-10 col-sm-10 col-md-10 col-lg-10 col-xl-10"> | |
| 165 | + {% block content %} | |
| 166 | + {% endblock %} | |
| 167 | + </div> | |
| 168 | + </div> | |
| 136 | 169 | </div> |
| 137 | - </div> | |
| 138 | - | |
| 139 | - {% block script_file %} | |
| 140 | - | |
| 141 | - {% endblock script_file %} | |
| 142 | - | |
| 143 | - {% block script_link %} | |
| 144 | 170 | |
| 145 | - {% endblock script_link %} | |
| 146 | - <!-- Init material Bootstrap --> | |
| 147 | - <script type="text/javascript" src="{% static 'js/home.js' %}"></script> | |
| 148 | - <script type="text/javascript">$.material.init()</script> | |
| 171 | + <!-- Init material Bootstrap --> | |
| 172 | + <script type="text/javascript">$.material.init()</script> | |
| 149 | 173 | </body> |
| 150 | 174 | |
| 151 | 175 | </html> |
| 152 | 176 | \ No newline at end of file | ... | ... |
amadeus/urls.py
| ... | ... | @@ -24,7 +24,7 @@ from .views import index |
| 24 | 24 | urlpatterns = [ |
| 25 | 25 | url(r'^users/', include('users.urls', namespace = 'users')), |
| 26 | 26 | url(r'^admin/', admin.site.urls), |
| 27 | - url(r'^$', index), | |
| 27 | + url(r'^$', index, name = 'home'), | |
| 28 | 28 | url(r'^courses/', include('courses.urls', namespace = 'courses')), |
| 29 | 29 | #API |
| 30 | 30 | url(r'^o/', include('oauth2_provider.urls', namespace='oauth2_provider')), | ... | ... |
amadeus/views.py
courses/templates/courses/home.html
| ... | ... | @@ -14,59 +14,6 @@ |
| 14 | 14 | {% render_breadcrumbs %} |
| 15 | 15 | {% endblock %} |
| 16 | 16 | |
| 17 | -{% block sidebar %} | |
| 18 | - <div class="panel panel-primary"> | |
| 19 | - <div class="panel-heading"> | |
| 20 | - <h4>{% trans 'Menu' %}</h4> | |
| 21 | - </div> | |
| 22 | - <div class="panel-body menu-lateral"> | |
| 23 | - <ul class="nav nav-pills nav-stacked"> | |
| 24 | - <li> | |
| 25 | - <a href="#menu_courses" class="accordion" data-toggle="collapse">{% trans 'Courses' %}<span class="pull-right glyphicon glyphicon-chevron-down"></span></a> | |
| 26 | - <div id="menu_courses" class="collapse"> | |
| 27 | - <ul class="nav nav-pill nav-stacked accordion_list"> | |
| 28 | - <li><a href="#"><i class="fa fa-book" aria-hidden="true"></i> {% trans 'My Courses' %} </a></li> | |
| 29 | - <li><a href="#"><i class="fa fa-globe" aria-hidden="true"></i> {% trans 'All Courses' %} </a></li> | |
| 30 | - {% if user|has_role:'system_admin' or user|has_role:'professor'%} | |
| 31 | - <li><a href="#"><i class="fa fa-list" aria-hidden="true"></i> {% trans 'List Category' %}</a></li> | |
| 32 | - <li><a href="#">{% trans 'Create Course' %}</a></li> | |
| 33 | - <li><a href="#">{% trans 'Create Category' %}</a></li> | |
| 34 | - {% endif %} | |
| 35 | - </ul> | |
| 36 | - </div> | |
| 37 | - </li> | |
| 38 | - {% block menu %} | |
| 39 | - | |
| 40 | - {% endblock %} | |
| 41 | - {% if user|has_role:'system_admin' %} | |
| 42 | - | |
| 43 | - <li> | |
| 44 | - <a href="#menu_users" class="accordion" data-toggle="collapse">{% trans 'Users' %}<span class="pull-right glyphicon glyphicon-chevron-down"></span></a> | |
| 45 | - <div id="menu_users" class="collapse"> | |
| 46 | - <ul class="nav nav-pill nav-stacked accordion_list"> | |
| 47 | - <li> <a href="#"><i class="fa fa-users" aria-hidden="true"></i> {% trans 'Manage Users' %}</a></li> | |
| 48 | - <li> <a href="#"><i class="fa fa-user-plus" aria-hidden="true"></i> {% trans 'Create User' %}</a></li> | |
| 49 | - </ul> | |
| 50 | - </div> | |
| 51 | - </li> | |
| 52 | - <li> | |
| 53 | - <a href="#menu_settings" class="accordion" data-toggle="collapse">{% trans 'Settings' %}<span class="pull-right glyphicon glyphicon-chevron-down"></span></a> | |
| 54 | - <div id="menu_settings" class="collapse"> | |
| 55 | - <ul class="nav nav-pill nav-stacked accordion_list"> | |
| 56 | - | |
| 57 | - <li> <a href="#"><i class="fa fa-cog" aria-hidden="true"></i> {% trans "System" %}</a></li> | |
| 58 | - | |
| 59 | - <li> <a href="#"><i class="fa fa-envelope" aria-hidden="true"></i> {% trans "Mail Sender" %}</a></li> | |
| 60 | - <li> <a href="#"><i class="fa fa-shield" aria-hidden="true"></i> {% trans "Security" %}</a></li> | |
| 61 | - </ul> | |
| 62 | - </div> | |
| 63 | - </li> | |
| 64 | - {% endif %} | |
| 65 | - </ul> | |
| 66 | - </div> | |
| 67 | - </div> | |
| 68 | -{% endblock %} | |
| 69 | - | |
| 70 | 17 | {% block content %} |
| 71 | 18 | {% if user|has_role:'system_admin' %} |
| 72 | 19 | <h3>{% trans 'Courses' %}</h3> | ... | ... |
users/forms.py
| ... | ... | @@ -8,6 +8,9 @@ class Validation(forms.ModelForm): |
| 8 | 8 | def clean_password(self): |
| 9 | 9 | password = self.cleaned_data.get('password') |
| 10 | 10 | |
| 11 | + if self.is_edit and len(password) == 0: | |
| 12 | + return password | |
| 13 | + | |
| 11 | 14 | # At least MIN_LENGTH long |
| 12 | 15 | if len(password) < self.MIN_LENGTH: |
| 13 | 16 | raise forms.ValidationError(_("The password must contain at least % d characters." % self.MIN_LENGTH)) |
| ... | ... | @@ -23,16 +26,20 @@ class Validation(forms.ModelForm): |
| 23 | 26 | password = self.cleaned_data.get("password") |
| 24 | 27 | password2 = self.cleaned_data.get("password2") |
| 25 | 28 | |
| 29 | + if self.is_edit and len(password) == 0: | |
| 30 | + return password2 | |
| 31 | + | |
| 26 | 32 | if password and password2 and password != password2: |
| 27 | 33 | raise forms.ValidationError(_('The confirmation password is incorrect.')) |
| 28 | 34 | |
| 29 | 35 | return password2 |
| 30 | 36 | |
| 31 | 37 | class RegisterUserForm(Validation): |
| 32 | - password = forms.CharField(label=_('Password'), widget=forms.PasswordInput) | |
| 38 | + password = forms.CharField(label=_('Password'), widget = forms.PasswordInput) | |
| 33 | 39 | password2 = forms.CharField(label = _('Confirm Password'), widget = forms.PasswordInput) |
| 34 | 40 | |
| 35 | 41 | MIN_LENGTH = 8 |
| 42 | + is_edit = False | |
| 36 | 43 | |
| 37 | 44 | def save(self, commit=True): |
| 38 | 45 | super(RegisterUserForm, self).save(commit=False) |
| ... | ... | @@ -46,3 +53,27 @@ class RegisterUserForm(Validation): |
| 46 | 53 | class Meta: |
| 47 | 54 | model = User |
| 48 | 55 | fields = ['email', 'username', 'last_name', 'social_name',] |
| 56 | + | |
| 57 | +class ProfileForm(Validation): | |
| 58 | + password = forms.CharField(label=_('Password'), widget = forms.PasswordInput, required = False) | |
| 59 | + password2 = forms.CharField(label = _('Confirm Password'), widget = forms.PasswordInput, required = False) | |
| 60 | + | |
| 61 | + MIN_LENGTH = 8 | |
| 62 | + is_edit = True | |
| 63 | + | |
| 64 | + def save(self, commit=True): | |
| 65 | + super(ProfileForm, self).save(commit=False) | |
| 66 | + | |
| 67 | + if len(self.cleaned_data['password']) > 0: | |
| 68 | + self.instance.set_password(self.cleaned_data['password']) | |
| 69 | + | |
| 70 | + self.instance.save() | |
| 71 | + | |
| 72 | + return self.instance | |
| 73 | + | |
| 74 | + class Meta: | |
| 75 | + model = User | |
| 76 | + fields = ['social_name', 'description', 'show_email', 'image'] | |
| 77 | + widgets = { | |
| 78 | + 'description': forms.Textarea, | |
| 79 | + } | |
| 49 | 80 | \ No newline at end of file | ... | ... |
users/models.py
| ... | ... | @@ -22,7 +22,7 @@ class User(AbstractBaseUser, PermissionsMixin): |
| 22 | 22 | image = models.ImageField(verbose_name = _('Photo'), null=True, blank = True, upload_to = 'users/') |
| 23 | 23 | date_created = models.DateTimeField(_('Create Date'), auto_now_add = True) |
| 24 | 24 | last_update = models.DateTimeField(_('Last Update'), auto_now = True) |
| 25 | - show_email = models.IntegerField(_('Show email?'), null = True, choices = ((1, _('Allow everyone to see my address')), (2, _('Only classmates can see my address')), (3, _('Nobody can see my address')))) | |
| 25 | + show_email = models.IntegerField(_('Show email?'), null = True, blank = True, choices = ((1, _('Allow everyone to see my address')), (2, _('Only classmates can see my address')), (3, _('Nobody can see my address')))) | |
| 26 | 26 | is_staff = models.BooleanField(_('Administrator'), default = False) |
| 27 | 27 | is_active = models.BooleanField(_('Active'), default = True) |
| 28 | 28 | ... | ... |
users/templates/users/edit_profile.html
| ... | ... | @@ -6,14 +6,8 @@ |
| 6 | 6 | {% load django_bootstrap_breadcrumbs %} |
| 7 | 7 | |
| 8 | 8 | {% block breadcrumbs %} |
| 9 | - {% if user|has_role:'system_admin' %} | |
| 10 | - {{ block.super }} | |
| 11 | - {% breadcrumb 'Update User' 'users:update' %} | |
| 12 | - {% else %} | |
| 13 | - {{ block.super }} | |
| 14 | - {% breadcrumb 'Update Profile' 'users:update' %} | |
| 15 | - {% endif %} | |
| 16 | - | |
| 9 | + {{ block.super }} | |
| 10 | + {% breadcrumb 'Update Profile' 'users:edit_profile' %} | |
| 17 | 11 | {% endblock %} |
| 18 | 12 | |
| 19 | 13 | |
| ... | ... | @@ -35,13 +29,8 @@ |
| 35 | 29 | {% csrf_token %} |
| 36 | 30 | {% for field in form %} |
| 37 | 31 | <div class="form-group{% if form.has_error %} has-error {% endif %} is-fileinput"> |
| 38 | - {% if not field.auto_id == 'id_is_staff' and not field.auto_id == 'id_is_active' and not field.auto_id == 'id_type_profile' %} | |
| 39 | - <label for="{{ field.auto_id }}">{{ field.label }}</label> | |
| 40 | - {% endif %} | |
| 41 | - {% if field.auto_id == 'id_birth_date' %} | |
| 42 | - <input type="text" class="form-control date-picker"name="{{field.name}}" value="{{field.value|date:'SHORT_DATE_FORMAT'}}" min="{{now|date:'SHORT_DATE_FORMAT'}}" id="{{ field.auto_id }}"> | |
| 43 | - <span id="helpBlock" class="help-block">{{ field.help_text }}</span> | |
| 44 | - {% elif field.auto_id == 'id_image' or field.auto_id == 'id_curriculum'%} | |
| 32 | + <label for="{{ field.auto_id }}">{{ field.label }}</label> | |
| 33 | + {% if field.auto_id == 'id_image' %} | |
| 45 | 34 | {% render_field field class='form-control input-sm' %} |
| 46 | 35 | <div class="input-group"> |
| 47 | 36 | <input type="text" readonly="" class="form-control" placeholder="{% trans 'Choose your file...' %}"> |
| ... | ... | @@ -51,35 +40,11 @@ |
| 51 | 40 | </button> |
| 52 | 41 | </span> |
| 53 | 42 | </div> |
| 54 | - {% elif field.auto_id == 'id_cpf' %} | |
| 55 | - {% render_field field class='form-control' onkeypress='campoNumerico(this,event); formatarCpf(this,event);' %} | |
| 56 | - | |
| 57 | - {% elif field.auto_id == 'id_phone' %} | |
| 58 | - {% render_field field class='form-control' onkeypress='campoNumerico(this,event); formatarTelefone(this,event);' %} | |
| 59 | - | |
| 60 | - {% elif field.auto_id == 'id_year_titration' %} | |
| 61 | - {% render_field field class='form-control' onkeypress='campoNumerico(this,event);' %} | |
| 62 | - | |
| 63 | - {% elif field.auto_id == 'id_is_staff' or field.auto_id == 'id_is_active' %} | |
| 64 | - {% if user|has_role:'system_admin' %} | |
| 65 | - <label for="{{ field.auto_id }}">{{ field.label }}</label> | |
| 66 | - <div class="checkbox"> | |
| 67 | - <label for="{{ field.auto_id }}"> | |
| 68 | - {% render_field field %} {{field.label}} | |
| 69 | - </label> | |
| 70 | - </div> | |
| 71 | - {% endif %} | |
| 72 | - {% elif field.auto_id == 'id_type_profile' %} | |
| 73 | - {% if user|has_role:'system_admin' %} | |
| 74 | - <label for="{{ field.auto_id }}">{{ field.label }}</label> | |
| 75 | - {% render_field field class='form-control' %} | |
| 76 | - <span id="helpBlock" class="help-block">{{ field.help_text }}</span> | |
| 77 | - {% endif %} | |
| 43 | + {% elif field.auto_id == 'id_description' %} | |
| 44 | + {% render_field field class='form-control text_wysiwyg' %} | |
| 78 | 45 | {% else %} |
| 79 | - {% if not field.auto_id == 'id_is_staff' and not field.auto_id == 'id_is_active' and not field.auto_id == 'id_type_profile' %} | |
| 80 | - {% render_field field class='form-control' %} | |
| 81 | - <span id="helpBlock" class="help-block">{{ field.help_text }}</span> | |
| 82 | - {% endif %} | |
| 46 | + {% render_field field class='form-control' %} | |
| 47 | + <span id="helpBlock" class="help-block">{{ field.help_text }}</span> | |
| 83 | 48 | {% endif %} |
| 84 | 49 | {% if field.errors %} |
| 85 | 50 | <div class="alert alert-danger alert-dismissible" role="alert"> |
| ... | ... | @@ -107,10 +72,8 @@ |
| 107 | 72 | </div> |
| 108 | 73 | <br clear="all" /> |
| 109 | 74 | <script type="text/javascript"> |
| 110 | - var locale = navigator.language || navigator.userLanguage; | |
| 111 | - | |
| 112 | - $('.date-picker').datepicker({ | |
| 113 | - language: locale, | |
| 114 | - }); | |
| 75 | + $('.text_wysiwyg').summernote({ | |
| 76 | + height: 200 | |
| 77 | + }); | |
| 115 | 78 | </script> |
| 116 | 79 | {% endblock %} | ... | ... |
users/templates/users/profile.html
| 1 | -{% extends 'home.html' %} | |
| 1 | +{% extends 'base.html' %} | |
| 2 | 2 | |
| 3 | 3 | {% load static i18n %} |
| 4 | 4 | {% load widget_tweaks %} |
| 5 | 5 | {% load django_bootstrap_breadcrumbs permission_tags%} |
| 6 | 6 | |
| 7 | 7 | {% block breadcrumbs %} |
| 8 | + {{ block.super }} | |
| 9 | + {% breadcrumb 'Profile' 'users:profile' %} | |
| 10 | +{% endblock %} | |
| 8 | 11 | |
| 9 | - {{ block.super }} | |
| 10 | - {% breadcrumb 'Profile' 'users:profile' %} | |
| 11 | - | |
| 12 | +{% block render_breadcrumbs %} | |
| 13 | + {% render_breadcrumbs %} | |
| 12 | 14 | {% endblock %} |
| 13 | 15 | |
| 14 | 16 | {% block content %} |
| ... | ... | @@ -24,120 +26,33 @@ |
| 24 | 26 | {% endif %} |
| 25 | 27 | <div class="row"> |
| 26 | 28 | <div class="col-lg-12"> |
| 27 | - <div class="well well-lg"> | |
| 28 | - <div class="row"> | |
| 29 | - | |
| 30 | - {% if user.image %} | |
| 31 | - <div class="col-md-4" style="width: 200px;overflow:hidden;margin-left: 8em;height: 150px;background-image: url('{{user.image.url}}');background-position: center;background-size: cover;"> | |
| 32 | - {% else %} | |
| 33 | - <div class="col-md-4"> | |
| 34 | - {% if user.gender == 'M' %} | |
| 35 | - <img src="{% static 'img/male_avatar.png' %}" alt="Avatar" class="img-circle img-responsive img-list-user" style="margin-left: 8em;"> | |
| 36 | - {% else %} | |
| 37 | - <img src="{% static 'img/female_avatar.png' %}" alt="Avatar" class="img-circle img-responsive img-list-user" style="margin-left: 8em;"> | |
| 38 | - {% endif %} | |
| 39 | - {% endif %} | |
| 29 | + <div class="well well-lg container-fluid"> | |
| 30 | + <div class="row-fluid"> | |
| 31 | + <div class="col-md-3"> | |
| 32 | + <span class="thumbnail"> | |
| 33 | + <img src="{{ user.image_url }}" /> | |
| 34 | + </span> | |
| 40 | 35 | </div> |
| 41 | - <div class="col-md-8"> | |
| 42 | - <table class="table table-hover table-edited"> | |
| 43 | - <tbody> | |
| 44 | - <tr> | |
| 45 | - <td>{% trans "Status" %}:</td> | |
| 46 | - {% if user %} | |
| 47 | - <td> {% trans "Online" %}</td> | |
| 48 | - {% else %} | |
| 49 | - <td> {% trans "OffLine" %}</td> | |
| 50 | - {% endif %} | |
| 51 | - | |
| 52 | - </tr> | |
| 53 | - <tr> | |
| 54 | - <td>{% trans "Name" %}:</td> | |
| 55 | - <td>{{user}}</td> | |
| 56 | - </tr> | |
| 57 | - <tr> | |
| 58 | - <td>{% trans "Login" %}</td> | |
| 59 | - <td>{{user.username}}</td> | |
| 60 | - </tr> | |
| 61 | - <tr> | |
| 62 | - <td>{% trans "Email" %}:</td> | |
| 63 | - <td>{{user.email}}</td> | |
| 64 | - </tr> | |
| 65 | - </tbody> | |
| 66 | - </table> | |
| 36 | + <div class="col-md-9"> | |
| 37 | + <span><b>{% trans 'Name' %}: </b> {{ user.username }}</span><br /> | |
| 38 | + <span><b>{% trans 'Last Name' %}: </b> {{ user.last_name }}</span><br /> | |
| 39 | + <span><b>{% trans 'Social Name' %}: </b> {% if user.social_name is None %}{% trans 'Not informed' %}{% else %}{{ user.social_name }}{% endif %}</span><br /> | |
| 40 | + <span><b>{% trans 'User since' %}: </b> {{ user.date_created|date }}</span><br /> | |
| 67 | 41 | </div> |
| 68 | 42 | </div> |
| 69 | - <div class="row"> | |
| 70 | - <div class="col-md-10 col-md-offset-1"> | |
| 71 | - <table class="table table-hover table-edited"> | |
| 72 | - <tbody> | |
| 73 | - <tr> | |
| 74 | - <td>{% trans "User role" %}:</td> | |
| 75 | - {% if user.type_profile == 1 %} | |
| 76 | - <td>{% trans "Teacher" %}</td> | |
| 77 | - {% else %} | |
| 78 | - <td>{% trans "Student" %}</td> | |
| 79 | - {% endif %} | |
| 80 | - | |
| 81 | - </tr> | |
| 82 | - <tr> | |
| 83 | - <td>{% trans "CPF" %}:</td> | |
| 84 | - {% if user.cpf %} | |
| 85 | - <td>{{user.cpf}}</td> | |
| 86 | - | |
| 87 | - {% else %} | |
| 88 | - <td>{% trans "doesn't possess CPF" %}</td> | |
| 89 | - {% endif %} | |
| 90 | - | |
| 91 | - </tr> | |
| 92 | - <tr> | |
| 93 | - <td>{% trans "Phone Number" %}:</td> | |
| 94 | - {% if user.phone %} | |
| 95 | - <td>{{user.phone}}</td> | |
| 96 | - {% else %} | |
| 97 | - <td>{% trans "doesn't possess Phone" %}</td> | |
| 98 | - {% endif %} | |
| 99 | - | |
| 100 | - </tr> | |
| 101 | - <tr> | |
| 102 | - <td>{% trans "Gender" %}:</td> | |
| 103 | - <td>{{user.gender}}</td> | |
| 104 | - </tr> | |
| 105 | - <tr> | |
| 106 | - <td>{% trans "Birth Date" %}:</td> | |
| 107 | - <td>{{user.birth_date}}</td> | |
| 108 | - </tr> | |
| 109 | - <tr> | |
| 110 | - <td>{% trans "State and City" %}:</td> | |
| 111 | - <td>{{user.state}} - {{user.city}}</td> | |
| 112 | - </tr> | |
| 113 | - <tr> | |
| 114 | - <td>{% trans "Title" %}:</td> | |
| 115 | - <td>{{user.titration}}</td> | |
| 116 | - </tr> | |
| 117 | - <tr> | |
| 118 | - <td>{% trans "Year" %}:</td> | |
| 119 | - <td>{{user.year_titration}}</td> | |
| 120 | - </tr> | |
| 121 | - <tr> | |
| 122 | - <td>{% trans "Institution" %}:</td> | |
| 123 | - {% if user.institution %} | |
| 124 | - <td>{{user.institution}}</td> | |
| 125 | - {% else %} | |
| 126 | - <td>{% trans "Didn't inform institution" %}</td> | |
| 127 | - {% endif %} | |
| 128 | - </tr> | |
| 129 | - <tr> | |
| 130 | - <td>{% trans "Curriculum" %}:</td> | |
| 131 | - {% if user.curriculum %} | |
| 132 | - <td> | |
| 133 | - <a href="{{user.curriculum.url }}" target="_blank">link</a> | |
| 134 | - </td> | |
| 135 | - {% else %} | |
| 136 | - <td>{% trans "Didn't upload any curriculum" %}</td> | |
| 137 | - {% endif %} | |
| 138 | - </tr> | |
| 139 | - </tbody> | |
| 140 | - </table> | |
| 43 | + <div class="row-fluid"> | |
| 44 | + <div class="col-md-12"> | |
| 45 | + {{ user.description|linebreaks }} | |
| 46 | + </div> | |
| 47 | + </div> | |
| 48 | + <div class="row-fluid"> | |
| 49 | + <div class="col-md-12"> | |
| 50 | + <a href="{% url 'users:edit_profile' %}" class="pull-left btn btn-raised btn-primary btn-sm"> | |
| 51 | + <i class="fa fa-edit"></i> {% trans 'Edit Profile' %} | |
| 52 | + </a> | |
| 53 | + <a class="pull-right btn btn-raised btn-danger btn-sm"> | |
| 54 | + <i class="fa fa-trash"></i> {% trans 'Delete Account' %} | |
| 55 | + </a> | |
| 141 | 56 | </div> |
| 142 | 57 | </div> |
| 143 | 58 | </div> | ... | ... |
users/urls.py
| ... | ... | @@ -7,4 +7,6 @@ urlpatterns = [ |
| 7 | 7 | url(r'^login/$', views.login, name='login'), |
| 8 | 8 | url(r'^logout/$', auth_views.logout, {'next_page': 'users:login'}, name='logout'), |
| 9 | 9 | url(r'^signup/$', views.RegisterUser.as_view(), name = 'signup'), |
| 10 | + url(r'^profile/$', views.Profile.as_view(), name = 'profile'), | |
| 11 | + url(r'^edit_profile/$', views.UpdateProfile.as_view(), name = 'edit_profile'), | |
| 10 | 12 | ] | ... | ... |
users/views.py
| ... | ... | @@ -14,7 +14,7 @@ from itertools import chain |
| 14 | 14 | from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger |
| 15 | 15 | |
| 16 | 16 | from .models import User |
| 17 | -from .forms import RegisterUserForm | |
| 17 | +from .forms import RegisterUserForm, ProfileForm | |
| 18 | 18 | |
| 19 | 19 | #API IMPORTS |
| 20 | 20 | from rest_framework import viewsets |
| ... | ... | @@ -153,29 +153,7 @@ from rest_framework.permissions import IsAuthenticated, IsAuthenticatedOrReadOnl |
| 153 | 153 | # context['title'] = "Remove Account" |
| 154 | 154 | # return context |
| 155 | 155 | |
| 156 | -# class UpdateProfile(LoginRequiredMixin, generic.edit.UpdateView): | |
| 157 | -# #login_url = reverse_lazy("core:home") | |
| 158 | -# template_name = 'users/edit_profile.html' | |
| 159 | -# form_class = UpdateProfileForm | |
| 160 | -# success_url = reverse_lazy('users:profile') | |
| 161 | - | |
| 162 | -# def get_object(self): | |
| 163 | -# user = get_object_or_404(User, username = self.request.user.username) | |
| 164 | -# return user | |
| 165 | - | |
| 166 | -# def get_context_data(self, **kwargs): | |
| 167 | -# context = super(UpdateProfile, self).get_context_data(**kwargs) | |
| 168 | -# context['title'] = 'Update Profile' | |
| 169 | - | |
| 170 | -# context['form'] = UpdateProfileForm(instance = self.object) | |
| 171 | - | |
| 172 | -# return context | |
| 173 | - | |
| 174 | -# def form_valid(self, form): | |
| 175 | -# form.save() | |
| 176 | -# messages.success(self.request, _('Profile edited successfully!')) | |
| 177 | 156 | |
| 178 | -# return super(UpdateProfile, self).form_valid(form) | |
| 179 | 157 | |
| 180 | 158 | # class DeleteUser(LoginRequiredMixin, generic.edit.DeleteView): |
| 181 | 159 | # allowed_roles = ['student'] |
| ... | ... | @@ -189,23 +167,6 @@ from rest_framework.permissions import IsAuthenticated, IsAuthenticatedOrReadOnl |
| 189 | 167 | # user = get_object_or_404(User, username = self.request.user.username) |
| 190 | 168 | # return user |
| 191 | 169 | |
| 192 | - | |
| 193 | -# class Profile(LoginRequiredMixin, generic.DetailView): | |
| 194 | - | |
| 195 | -# #login_url = reverse_lazy("core:home") | |
| 196 | -# redirect_field_name = 'next' | |
| 197 | -# context_object_name = 'user' | |
| 198 | -# template_name = 'users/profile.html' | |
| 199 | - | |
| 200 | -# def get_object(self): | |
| 201 | -# user = get_object_or_404(User, username = self.request.user.username) | |
| 202 | -# return user | |
| 203 | - | |
| 204 | -# def get_context_data (self, **kwargs): | |
| 205 | -# context = super(Profile, self).get_context_data(**kwargs) | |
| 206 | -# context['title'] = "Profile" | |
| 207 | -# return context | |
| 208 | - | |
| 209 | 170 | # class SearchView(LoginRequiredMixin, generic.ListView): |
| 210 | 171 | |
| 211 | 172 | # #login_url = reverse_lazy("core:home") |
| ... | ... | @@ -221,6 +182,49 @@ from rest_framework.permissions import IsAuthenticated, IsAuthenticatedOrReadOnl |
| 221 | 182 | |
| 222 | 183 | # return context |
| 223 | 184 | |
| 185 | +class Profile(LoginRequiredMixin, generic.DetailView): | |
| 186 | + login_url = reverse_lazy("users:login") | |
| 187 | + redirect_field_name = 'next' | |
| 188 | + | |
| 189 | + context_object_name = 'acc' | |
| 190 | + template_name = 'users/profile.html' | |
| 191 | + | |
| 192 | + def get_object(self): | |
| 193 | + user = get_object_or_404(User, username = self.request.user.username) | |
| 194 | + | |
| 195 | + return user | |
| 196 | + | |
| 197 | + def get_context_data (self, **kwargs): | |
| 198 | + context = super(Profile, self).get_context_data(**kwargs) | |
| 199 | + context['title'] = _("Profile") | |
| 200 | + | |
| 201 | + return context | |
| 202 | + | |
| 203 | +class UpdateProfile(LoginRequiredMixin, generic.edit.UpdateView): | |
| 204 | + login_url = reverse_lazy("users:login") | |
| 205 | + redirect_field_name = 'next' | |
| 206 | + | |
| 207 | + template_name = 'users/edit_profile.html' | |
| 208 | + form_class = ProfileForm | |
| 209 | + success_url = reverse_lazy('users:profile') | |
| 210 | + | |
| 211 | + def get_object(self): | |
| 212 | + user = get_object_or_404(User, email = self.request.user.email) | |
| 213 | + | |
| 214 | + return user | |
| 215 | + | |
| 216 | + def get_context_data(self, **kwargs): | |
| 217 | + context = super(UpdateProfile, self).get_context_data(**kwargs) | |
| 218 | + context['title'] = _('Update Profile') | |
| 219 | + | |
| 220 | + return context | |
| 221 | + | |
| 222 | + def form_valid(self, form): | |
| 223 | + form.save() | |
| 224 | + messages.success(self.request, _('Profile edited successfully!')) | |
| 225 | + | |
| 226 | + return super(UpdateProfile, self).form_valid(form) | |
| 227 | + | |
| 224 | 228 | class RegisterUser(generic.edit.CreateView): |
| 225 | 229 | model = User |
| 226 | 230 | form_class = RegisterUserForm |
| ... | ... | @@ -258,12 +262,12 @@ def login(request): |
| 258 | 262 | messages.add_message(request, messages.ERROR, _('E-mail or password are incorrect.')) |
| 259 | 263 | context["username"] = username |
| 260 | 264 | elif request.user.is_authenticated: |
| 261 | - return redirect('courses:index') | |
| 265 | + return redirect('home') | |
| 262 | 266 | |
| 263 | 267 | return render(request,"users/login.html",context) |
| 264 | 268 | |
| 265 | -# API VIEWS | |
| 266 | 269 | |
| 270 | +# API VIEWS | |
| 267 | 271 | class UserViewSet(viewsets.ModelViewSet): |
| 268 | 272 | queryset = User.objects.all() |
| 269 | 273 | serializer_class = UserSerializer | ... | ... |