diff options
-rw-r--r-- | workshop_app/templates/workshop_app/my_workshops.html | 780 | ||||
-rw-r--r-- | workshop_app/templates/workshop_app/workshop_type_details.html (renamed from workshop_app/templates/workshop_app/view_workshoptype_details.html) | 2 | ||||
-rw-r--r-- | workshop_app/templates/workshop_app/workshop_type_list.html (renamed from workshop_app/templates/workshop_app/view_workshoptype_list.html) | 16 | ||||
-rw-r--r-- | workshop_app/urls.py | 18 | ||||
-rw-r--r-- | workshop_app/views.py | 1062 |
5 files changed, 569 insertions, 1309 deletions
diff --git a/workshop_app/templates/workshop_app/my_workshops.html b/workshop_app/templates/workshop_app/my_workshops.html index ed79934..9d81c84 100644 --- a/workshop_app/templates/workshop_app/my_workshops.html +++ b/workshop_app/templates/workshop_app/my_workshops.html @@ -1,403 +1,419 @@ {% extends "workshop_app/base.html" %} {% block title %} - Workshop Status + Workshop Status {% endblock %} {% block extra %} - <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script> - <link rel="stylesheet" href="https://ajax.googleapis.com/ajax/libs/jqueryui/1.12.1/themes/smoothness/jquery-ui.css"> - <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script> - <script src="{{URL_ROOT}}/static/workshop_app/js/bootstrap-3.3.7.min.js"></script> - <script src="{{URL_ROOT}}/static/workshop_app/js/jquery-1.12.1-ui.min.js"></script> - - <script> - //ToolTip popup function onhover - $(document).ready(function(){ - $('[data-toggle="popover"]').popover({ - placement : 'top', - trigger : 'hover' - }); - }); - - function sendData(d){ - var URL = "{{ URL_ROOT }}/my_workshops/" - $.ajax({ - url: URL, - type: "POST", - dataType: 'json', - data: { - d, - csrfmiddlewaretoken: $("input[name=csrfmiddlewaretoken]").val() - }, - }); - - window.location.reload(); - alert("Refreshing Page please wait, if you don't see your changes, please refresh this page again."); - } - </script> - - <!-- Change Workshop Date --> - <script type="text/javascript"> - //ToolTip popup function onhover - $(document).ready(function(){ - $('[data-toggle="popinfo"]').popover({ - placement : 'top', - trigger : 'hover' - }); - }); - - function changeDate(date){ - var previous_date = new Date(date); - var dateToday = new Date(); - var upto = new Date(); - - previous_date.setDate(previous_date.getDate() + 1); - upto.setFullYear(dateToday.getFullYear() + 1); - - if(date[0]=='P'){ - var counter = date.split(" "); - var id = counter.slice(-1).pop(); - counter = '.pDate'+id - $(counter).datepicker({ - changeMonth: true, - changeYear: true, - minDate: dateToday, - maxDate: upto, - dateFormat:"yy-mm-dd", - }); - $(".ui-dialog-content").dialog("close"); - $('.myDialogP'+id).dialog(); - - } else { - var counter = date.split(" "); - var id = counter.slice(-1).pop(); - counter = '.rDate'+id; - $(counter).datepicker({ - changeMonth: true, - changeYear: true, - minDate: dateToday, - maxDate: upto, - dateFormat:"yy-mm-dd", - }); - $(".ui-dialog-content").dialog("close"); - $('.myDialogR'+id).dialog(); - - } - }; - - function submitNewDate(info){ - var data = info.split(","); - if(data[1] == 'R'){ - var date = document.getElementsByClassName('rDate'+data[0]); - info = data.slice(2); - } - else{ - var date = document.getElementsByClassName('pDate'+data[0]); - info = data.slice(2); - } - var data_c = info + ',new_date=' + date[0].value +',CHANGE_DATE'; - var URL = "{{ URL_ROOT }}/my_workshops/"; - $.ajax({ - url: URL, - async: false, - type: "POST", - data: { - data_c, - csrfmiddlewaretoken: $("input[name=csrfmiddlewaretoken]").val() - }, - success:function(response){ - window.location.reload(); - alert(response); - } - }); - - }; + <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script> + <link rel="stylesheet" href="https://ajax.googleapis.com/ajax/libs/jqueryui/1.12.1/themes/smoothness/jquery-ui.css"> + <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script> + <script src="{{ URL_ROOT }}/static/workshop_app/js/bootstrap-3.3.7.min.js"></script> + <script src="{{ URL_ROOT }}/static/workshop_app/js/jquery-1.12.1-ui.min.js"></script> + + <script> + //ToolTip popup function onhover + $(document).ready(function () { + $('[data-toggle="popover"]').popover({ + placement: 'top', + trigger: 'hover' + }); + }); + + function sendData(d) { + var URL = "{{ URL_ROOT }}/my_workshops/" + $.ajax({ + url: URL, + type: "POST", + dataType: 'json', + data: { + d, + csrfmiddlewaretoken: $("input[name=csrfmiddlewaretoken]").val() + }, + }); + + window.location.reload(); + alert("Refreshing Page please wait, if you don't see your changes, please refresh this page again."); + } + </script> + + <!-- Change Workshop Date --> + <script type="text/javascript"> + //ToolTip popup function onhover + $(document).ready(function () { + $('[data-toggle="popinfo"]').popover({ + placement: 'top', + trigger: 'hover' + }); + }); + + function changeDate(date) { + var previous_date = new Date(date); + var dateToday = new Date(); + var upto = new Date(); + + previous_date.setDate(previous_date.getDate() + 1); + upto.setFullYear(dateToday.getFullYear() + 1); + + if (date[0] == 'P') { + var counter = date.split(" "); + var id = counter.slice(-1).pop(); + counter = '.pDate' + id + $(counter).datepicker({ + changeMonth: true, + changeYear: true, + minDate: dateToday, + maxDate: upto, + dateFormat: "yy-mm-dd", + }); + $(".ui-dialog-content").dialog("close"); + $('.myDialogP' + id).dialog(); + + } else { + var counter = date.split(" "); + var id = counter.slice(-1).pop(); + counter = '.rDate' + id; + $(counter).datepicker({ + changeMonth: true, + changeYear: true, + minDate: dateToday, + maxDate: upto, + dateFormat: "yy-mm-dd", + }); + $(".ui-dialog-content").dialog("close"); + $('.myDialogR' + id).dialog(); + + } + }; + + function submitNewDate(info) { + var data = info.split(","); + if (data[1] == 'R') { + var date = document.getElementsByClassName('rDate' + data[0]); + info = data.slice(2); + } else { + var date = document.getElementsByClassName('pDate' + data[0]); + info = data.slice(2); + } + var data_c = info + ',new_date=' + date[0].value + ',CHANGE_DATE'; + var URL = "{{ URL_ROOT }}/my_workshops/"; + $.ajax({ + url: URL, + async: false, + type: "POST", + data: { + data_c, + csrfmiddlewaretoken: $("input[name=csrfmiddlewaretoken]").val() + }, + success: function (response) { + window.location.reload(); + alert(response); + } + }); + + }; </script> {% endblock %} {% block content %} -{% if workshops %} - <h3 align="center" style="color:#2952a2;">The status of your workshops </h3> - <br> - - <!-- Pending View --> - <div class="container"> - {% if request.user.profile.position == 'instructor'%} - <h3 align="center" style="color: #04a9cf;"><strong><u>Team Member Requests</u></strong></h3> - - <table class="table"> - <thead> - <tr> - <th>Coordinator Name</th> - <th>Team Member</th> - <th>Workshop Name</th> - <th>Workshop Day</th> - </tr> - </thead> - <tbody> - {% for workshop in team_workshops %} - <tr> - <td><a href="{{ URL_ROOT }}/view_comment_profile/{{ workshop.coordinator.id }}"> - {{ workshop.coordinator.get_full_name }}</a> - </td> - <td> - {{ workshop.instructor.get_full_name }} - </td> - <td> - {{ workshop.title }} - </td> - <td> - {{ workshop.date | date }} - </td> - </tr> - {% endfor %} - </tbody> - </table> - {% endif %} - {% if request.user.profile.position == 'instructor' %} - <h3 align="center" style="color: #04a9cf;"><strong><u>Requests for Me</u></strong></h3> - {% else %} - <h3 align="center" style="color: #04a9cf;"><strong><u>My Requests</u></strong></h3> - {% endif %} - <table class="table table-striped"> - <thead> - <tr> - {% if request.user.profile.position == 'instructor' %} - <th>Coordinator Name</th> - {% else %} - <th>Instructor Name</th> - {% endif %} - <th>Workshop Name</th> - <th>Workshop Day</th> - <th>Status</th> - </tr> - </thead> - {% csrf_token %} - {% for workshop in workshops %} - <tbody> - <tr> - {% if workshop.status == 0 and workshop.instructor %} - {% if request.user.profile.position == 'instructor' %} - <td><a href="{{ URL_ROOT }}/view_comment_profile/{{ workshop.coordinator.profile.user.id }}"> - {{ workshop.coordinator.get_full_name }}</a></td> - {% else %} - <td>{{ workshop.instructor.get_full_name }}</td> - {% endif %} - <td>{{ workshop.title }}</td> - <td>{{ workshop.date | date }}</td> - <td><span class = "label label-warning">{{ workshop.status }}</span></td> - {% endif %} - {% if request.user.profile.position == 'instructor' and workshop.status == 0 and workshop.instructor %} - <td><button class="btn btn-primary btn-sm" id="book-btn" onClick="sendData('{{workshop.coordinator}},{{workshop.date| safe}},{{ workshop.title_id }},ACCEPTED')" data-toggle="popover" title="Please Note" data-content="Once Accepted you can't Reject, you have to personally contact the Coordinator if the workshop is to be cancelled"> Accept</button></td> - <td><button class="btn btn-danger btn-sm" id="book-btn" onClick="sendData('{{workshop.coordinator}},{{workshop.date| safe}},{{ workshop.title_id }},REJECTED')" data-toggle="popover" title="Please Note" data-content="Once Rejected you cannot revoke this action."> Reject </button></td> - {% endif %} - </tr> - </tbody> - {% endfor %} - </table> - </div> - - <!-- Accepted View --> - <div class="container"> - <h3 align="center" style="color: #04a9cf;"><strong><u>Workshops Accepted</u></strong></h3> - <table class="table table-striped"> - <thead> - <tr> - {% if request.user.profile.position == 'instructor' %} - <th>Coordinator Name</th> - <th>Institute</th> - {% else %} - <th>Instructor Name</th> - {% endif %} - <th>Workshop Name</th> - <th>Workshop Day</th> - <th>Status</th> - </tr> - </thead> - {% csrf_token %} - {% for workshop in workshops %} - <tbody> - <tr> - {% if workshop.status == 1 and workshop.workshop_type %} - {% if request.user.profile.position == 'instructor' %} - <td><a href="{{ URL_ROOT }}/view_comment_profile/{{ workshop.coordinator.profile.user.id }}"> - {{ workshop.coordinator.get_full_name }}</a></td> - <td>{{ workshop.coordinator.profile.institute }}</td> - {% else %} - <td>{{ workshop.instructor.get_full_name }}</td> - {% endif %} - <td>{{ workshop.title |capfirst }}</td> - {% if workshop.date > today %} - <td>{{ workshop.date | date }} - <span class="glyphicon glyphicon-calendar" data-toggle="popinfo" title="Note" data-content="Click here to change date" - class="datepicker" onclick="changeDate('R,{{ workshop.date| safe}}, {{forloop.counter}}')"> + {% if workshops %} + <h3 align="center" style="color:#2952a2;">The status of your workshops </h3> + <br> + + <!-- Pending View --> + <div class="container"> + {% if request.user.profile.position == 'instructor' %} + <h3 align="center" style="color: #04a9cf;"><strong><u>Team Member Requests</u></strong></h3> + + <table class="table"> + <thead> + <tr> + <th>Coordinator Name</th> + <th>Team Member</th> + <th>Workshop Name</th> + <th>Workshop Day</th> + </tr> + </thead> + <tbody> + </tbody> + </table> + {% endif %} + {% if request.user.profile.position == 'instructor' %} + <h3 align="center" style="color: #04a9cf;"><strong><u>Requests for Me</u></strong></h3> + {% else %} + <h3 align="center" style="color: #04a9cf;"><strong><u>My Requests</u></strong></h3> + {% endif %} + <table class="table table-striped"> + <thead> + <tr> + {% if request.user.profile.position == 'instructor' %} + <th>Coordinator Name</th> + {% else %} + <th>Instructor Name</th> + {% endif %} + <th>Workshop Name</th> + <th>Workshop Day</th> + <th>Status</th> + </tr> + </thead> + {% csrf_token %} + {% for workshop in workshops %} + <tbody> + <tr> + {% if workshop.status == 0 and workshop.instructor %} + {% if request.user.profile.position == 'instructor' %} + <td> + <a href="{{ URL_ROOT }}/view_comment_profile/{{ workshop.coordinator.profile.user.id }}"> + {{ workshop.coordinator.get_full_name }}</a></td> + {% else %} + <td>{{ workshop.instructor.get_full_name }}</td> + {% endif %} + <td>{{ workshop.title }}</td> + <td>{{ workshop.date | date }}</td> + <td><span class="label label-warning">{{ workshop.status }}</span></td> + {% endif %} + {% if request.user.profile.position == 'instructor' and workshop.status == 0 and workshop.instructor %} + <td> + <button class="btn btn-primary btn-sm" id="book-btn" + onClick="sendData('{{ workshop.coordinator }},{{ workshop.date| safe }},{{ workshop.title_id }},ACCEPTED')" + data-toggle="popover" title="Please Note" + data-content="Once Accepted you can't Reject, you have to personally contact the Coordinator if the workshop is to be cancelled"> + Accept + </button> + </td> + <td> + <button class="btn btn-danger btn-sm" id="book-btn" + onClick="sendData('{{ workshop.coordinator }},{{ workshop.date| safe }},{{ workshop.title_id }},REJECTED')" + data-toggle="popover" title="Please Note" + data-content="Once Rejected you cannot revoke this action."> Reject + </button> + </td> + {% endif %} + </tr> + </tbody> + {% endfor %} + </table> + </div> + + <!-- Accepted View --> + <div class="container"> + <h3 align="center" style="color: #04a9cf;"><strong><u>Workshops Accepted</u></strong></h3> + <table class="table table-striped"> + <thead> + <tr> + {% if request.user.profile.position == 'instructor' %} + <th>Coordinator Name</th> + <th>Institute</th> + {% else %} + <th>Instructor Name</th> + {% endif %} + <th>Workshop Name</th> + <th>Workshop Day</th> + <th>Status</th> + </tr> + </thead> + {% csrf_token %} + {% for workshop in workshops %} + <tbody> + <tr> + {% if workshop.status == 1 and workshop.workshop_type %} + {% if request.user.profile.position == 'instructor' %} + <td> + <a href="{{ URL_ROOT }}/view_comment_profile/{{ workshop.coordinator.profile.user.id }}"> + {{ workshop.coordinator.get_full_name }}</a></td> + <td>{{ workshop.coordinator.profile.institute }}</td> + {% else %} + <td>{{ workshop.instructor.get_full_name }}</td> + {% endif %} + <td>{{ workshop.title |capfirst }}</td> + {% if workshop.date > today %} + <td>{{ workshop.date | date }} + <span class="glyphicon glyphicon-calendar" data-toggle="popinfo" title="Note" + data-content="Click here to change date" + class="datepicker" + onclick="changeDate('R,{{ workshop.date| safe }}, {{ forloop.counter }}')"> </span> - <div class="myDialogR{{forloop.counter}}" style="display: none;" title="Select New Date"> + <div class="myDialogR{{ forloop.counter }}" style="display: none;" + title="Select New Date"> <form method="post"> - <input type="text" name="new_date" class="rDate{{forloop.counter}}" /><br> - <input type="hidden" name="action" value="change_date"> + <input type="text" name="new_date" class="rDate{{ forloop.counter }}"/><br> + <input type="hidden" name="action" value="change_date"> <input type="hidden" name="workshop_id" value="{{ workshop.id }}"> <input type="hidden" name="cid" value="{{ workshop.coordinator.id }}"> {% csrf_token %} - <button class="btn btn-primary btn-xs" type="submit" >Save</button> + <button class="btn btn-primary btn-xs" type="submit">Save</button> </form> - </div> - </td> - {% else %} - <td>{{ workshop.date | date }}</td> - {% endif %} - <td><span class = "label label-success">{{ workshop.get_status }}</span></td> - {% endif %} - {% if workshop.status == 1 and workshop.condition_one %} - {% if request.user.profile.position == 'instructor' %} - <td><a href="{{ URL_ROOT }}/view_comment_profile/{{ workshop.coordinator.profile.user.id }}"> - {{ workshop.coordinator.get_full_name }}</a></td> - <td>{{ workshop.coordinator.profile.institute }}</td> - {% else %} - <td>{{ workshop.instructor.get_full_name }}</td> - {% endif %} - <td>{{ workshop.title }}</td> - {% if workshop.date > today %} - <td>{{ workshop.date | date }} - <span class="glyphicon glyphicon-calendar" - class="datepicker" data-toggle="popinfo" title="Note" data-content="Click here to change date" - onclick="changeDate('P,{{ workshop.date | safe}}, {{forloop.counter}}')"> + </div> + </td> + {% else %} + <td>{{ workshop.date | date }}</td> + {% endif %} + <td><span class="label label-success">{{ workshop.get_status }}</span></td> + {% endif %} + {% if workshop.status == 1 and workshop.condition_one %} + {% if request.user.profile.position == 'instructor' %} + <td> + <a href="{{ URL_ROOT }}/view_comment_profile/{{ workshop.coordinator.profile.user.id }}"> + {{ workshop.coordinator.get_full_name }}</a></td> + <td>{{ workshop.coordinator.profile.institute }}</td> + {% else %} + <td>{{ workshop.instructor.get_full_name }}</td> + {% endif %} + <td>{{ workshop.title }}</td> + {% if workshop.date > today %} + <td>{{ workshop.date | date }} + <span class="glyphicon glyphicon-calendar" + class="datepicker" data-toggle="popinfo" title="Note" + data-content="Click here to change date" + onclick="changeDate('P,{{ workshop.date | safe }}, {{ forloop.counter }}')"> </span> - <div class="myDialogP{{forloop.counter}}" style="display: none;" title="Select New Date"> - - <input type="text" class="pDate{{forloop.counter}}" /><br> - <button class="btn btn-primary btn-xs" type="submit" onclick="submitNewDate('{{forloop.counter}},P,{{workshop.instructor_id}},{{workshop.coordinator_id}},{{ workshop.title_id }},{{ workshop.date | safe}}')">Update</button> - </div> - </td> - {% else %} - <td>{{ workshop.date | date }}</td> - {% endif %} - <td><span class = "label label-success">{{ workshop.status }}</span></td> - {% endif %} - </tr> - </tbody> - - {% endfor %} - - </table> - </div> - - -<!-- Proposed View --> -<div class="container"> - {% if request.user.profile.position == 'instructor' %} - <h3 align="center" style="color: #04a9cf;"><strong><u>Workshops Proposed By Coordinators</u></strong></h3> - {% else %} - <h3 align="center" style="color: #04a9cf;"><strong><u>Workshops Proposed By Me</u></strong></h3> - {% endif %} - <table class="table table-striped"> - <thead> - <tr> - {% if request.user.profile.position == 'instructor' %} - <th>Coordinator Name</th> - <th>Institute</th> - {% else %} - - {% endif %} - <th>Workshop Name</th> - <th>Workshop Day</th> - <th>Status</th> - </tr> - </thead> - {% csrf_token %} - {% for workshop in workshops %} - <tbody> - <tr> - {% if workshop.status == 0 and workshop.tnc_accepted %} - {% if request.user.profile.position == 'instructor' %} - - <td><a href="{{ URL_ROOT }}/view_comment_profile/{{ workshop.coordinator.profile.user.id }}"> - {{ workshop.coordinator.get_full_name }}</a></td> - <td>{{ workshop.coordinator.profile.institute }}</td> - {% endif %} - <td>{{ workshop.workshop_type }}</td> - <td>{{ workshop.date | date }}</td> - - <td><span class = "label label-warning">{{ workshop.get_status }}</span></td> - {% if request.user.profile.position == 'instructor' and workshop.status == 0 %} - <td><form method="post"> - <input type="hidden" name="action" value="approve"> - <input type="hidden" name="workshop_id" value="{{ workshop.id }}"> - {% csrf_token %} - <button class="btn btn-primary btn-sm" id="book-btn" data-toggle="popover" title="Please Note" data-content="Once Accepted you can't Reject, you have to personally contact the Coordinator if the workshop is to be cancelled"> Accept</button> - </form></td> - {% endif %} - {% endif %} - </tr> - </tbody> - - {% endfor %} - </table> - </div> - - -<!-- Deleted/Rejected View --> -<div class="container"> - <h3 align="center" style="color: #04a9cf;"><strong><u>Workshops Deleted/Rejected</u></strong></h3> - <table class="table table-striped"> - <thead> - <tr> - {% if request.user.profile.position == 'instructor' %} - <th>Coordinator Name</th> - {% else %} - <th>Instructor Name</th> - {% endif %} - <th>Workshop Name</th> - <th>Workshop Day</th> - <th>Status</th> - </tr> - </thead> - {% csrf_token %} - {% for workshop in workshops %} - <tbody> - <tr> - {% if workshop.status == 'DELETED' or workshop.status == 'REJECTED' %} - {% if request.user.profile.position == 'instructor' %} - <td>{{ workshop.coordinator.get_full_name }}</td> - {% else %} - <td>{{ workshop.instructor.get_full_name }}</td> - {% endif %} - <td>{{ workshop.title | capfirst }}</td> - <td>{{ workshop.date | date }}</td> - - <td><span class = "label label-danger">{{ workshop.status }}</span></td> - {% endif %} - </tr> - </tbody> - - {% endfor %} - </table> - </div> - - -{% else %} - {% if request.user.profile.position == 'instructor' %} - <div class="container"> - <div class="jumbotron"> - <h1>Welcome {{ user.first_name }}</h1> - <p>Your workshop related information will be shown here, Please navigate to <b>Workshop list</b> and depending upon - your expertise and availability create a workshop by going to - <b>Create Workshop</b>.</p> - </div> - </div> - {% else %} - <div class="container"> - <div class="jumbotron"> - <h1>Welcome {{ user.first_name }}</h1> - <p>Information Related to your workshops will be shown here, you can also - propose a Workshop as per your available date in <strong>Workshops > Propose a Workshop tab</strong> .</p> - </div> - </div> - {% endif %} -{% endif %} + <div class="myDialogP{{ forloop.counter }}" style="display: none;" + title="Select New Date"> + + <input type="text" class="pDate{{ forloop.counter }}"/><br> + <button class="btn btn-primary btn-xs" type="submit" + onclick="submitNewDate('{{ forloop.counter }},P,{{ workshop.instructor_id }},{{ workshop.coordinator_id }},{{ workshop.title_id }},{{ workshop.date | safe }}')"> + Update + </button> + </div> + </td> + {% else %} + <td>{{ workshop.date | date }}</td> + {% endif %} + <td><span class="label label-success">{{ workshop.status }}</span></td> + {% endif %} + </tr> + </tbody> + + {% endfor %} + + </table> + </div> + + + <!-- Proposed View --> + <div class="container"> + {% if request.user.profile.position == 'instructor' %} + <h3 align="center" style="color: #04a9cf;"><strong><u>Workshops Proposed By Coordinators</u></strong> + </h3> + {% else %} + <h3 align="center" style="color: #04a9cf;"><strong><u>Workshops Proposed By Me</u></strong></h3> + {% endif %} + <table class="table table-striped"> + <thead> + <tr> + {% if request.user.profile.position == 'instructor' %} + <th>Coordinator Name</th> + <th>Institute</th> + {% else %} + + {% endif %} + <th>Workshop Name</th> + <th>Workshop Day</th> + <th>Status</th> + </tr> + </thead> + {% csrf_token %} + {% for workshop in workshops %} + <tbody> + <tr> + {% if workshop.status == 0 and workshop.tnc_accepted %} + {% if request.user.profile.position == 'instructor' %} + + <td> + <a href="{{ URL_ROOT }}/view_comment_profile/{{ workshop.coordinator.profile.user.id }}"> + {{ workshop.coordinator.get_full_name }}</a></td> + <td>{{ workshop.coordinator.profile.institute }}</td> + {% endif %} + <td>{{ workshop.workshop_type }}</td> + <td>{{ workshop.date | date }}</td> + + <td><span class="label label-warning">{{ workshop.get_status }}</span></td> + {% if request.user.profile.position == 'instructor' and workshop.status == 0 %} + <td> + <form method="post"> + <input type="hidden" name="action" value="accept"> + <input type="hidden" name="workshop_id" value="{{ workshop.id }}"> + {% csrf_token %} + <button class="btn btn-primary btn-sm" id="book-btn" data-toggle="popover" + title="Please Note" + data-content="Once Accepted you can't Reject, you have to personally contact the Coordinator if the workshop is to be cancelled"> + Accept + </button> + </form> + </td> + {% endif %} + {% endif %} + </tr> + </tbody> + + {% endfor %} + </table> + </div> + + + <!-- Deleted/Rejected View --> + <div class="container"> + <h3 align="center" style="color: #04a9cf;"><strong><u>Workshops Deleted/Rejected</u></strong></h3> + <table class="table table-striped"> + <thead> + <tr> + {% if request.user.profile.position == 'instructor' %} + <th>Coordinator Name</th> + {% else %} + <th>Instructor Name</th> + {% endif %} + <th>Workshop Name</th> + <th>Workshop Day</th> + <th>Status</th> + </tr> + </thead> + {% csrf_token %} + {% for workshop in workshops %} + <tbody> + <tr> + {% if workshop.status == 'DELETED' or workshop.status == 'REJECTED' %} + {% if request.user.profile.position == 'instructor' %} + <td>{{ workshop.coordinator.get_full_name }}</td> + {% else %} + <td>{{ workshop.instructor.get_full_name }}</td> + {% endif %} + <td>{{ workshop.title | capfirst }}</td> + <td>{{ workshop.date | date }}</td> + + <td><span class="label label-danger">{{ workshop.status }}</span></td> + {% endif %} + </tr> + </tbody> + + {% endfor %} + </table> + </div> + + + {% else %} + {% if request.user.profile.position == 'instructor' %} + <div class="container"> + <div class="jumbotron"> + <h1>Welcome {{ user.first_name }}</h1> + <p>Your workshop related information will be shown here, Please navigate to <b>Workshop list</b> and + depending upon + your expertise and availability create a workshop by going to + <b>Create Workshop</b>.</p> + </div> + </div> + {% else %} + <div class="container"> + <div class="jumbotron"> + <h1>Welcome {{ user.first_name }}</h1> + <p>Information Related to your workshops will be shown here, you can also + propose a Workshop as per your available date in <strong>Workshops > Propose a Workshop + tab</strong> .</p> + </div> + </div> + {% endif %} + {% endif %} {% endblock %} - diff --git a/workshop_app/templates/workshop_app/view_workshoptype_details.html b/workshop_app/templates/workshop_app/workshop_type_details.html index 1504430..b8d6559 100644 --- a/workshop_app/templates/workshop_app/view_workshoptype_details.html +++ b/workshop_app/templates/workshop_app/workshop_type_details.html @@ -16,7 +16,7 @@ {% block content %} <div class="container"> - {{ workshoptype.workshoptype_description | safe }} + {{ workshop_type.description | safe }} </div> {% endblock %} diff --git a/workshop_app/templates/workshop_app/view_workshoptype_list.html b/workshop_app/templates/workshop_app/workshop_type_list.html index 2a561e7..0531864 100644 --- a/workshop_app/templates/workshop_app/view_workshoptype_list.html +++ b/workshop_app/templates/workshop_app/workshop_type_list.html @@ -63,13 +63,13 @@ </tr> </thead> - {% for w in workshoptype %} + {% for w in workshop_type %} <tbody> <tr > <td scope="row" id="{{ forloop.counter }}">{{ forloop.counter }}</td> - <td>{{ w.workshoptype_name }}</td> - <td>{{ w.workshoptype_duration }}</td> - <td><a href="{{URL_ROOT}}/view_workshoptype_details/{{ w.id }}" class="btn btn-default btn-sm" class="accordion-toggle" >View Workshop Details</a></td> + <td>{{ w.name }}</td> + <td>{{ w.duration }}</td> + <td><a href="{{URL_ROOT}}/workshop_type_details/{{ w.id }}" class="btn btn-default btn-sm" class="accordion-toggle" >View Workshop Details</a></td> </tr> </tbody> {% endfor %} @@ -101,17 +101,17 @@ <li class="page-item"> {% if workshoptype.has_previous %} <a class="page-link" tabindex="-1" - href="?page={{ workshoptype.previous_page_number }}">Previous</a> + href="?page={{ workshop_type.previous_page_number }}">Previous</a> {% endif %} </li> <li class="page-item"> <span class="current"> - Page {{ workshoptype.number }} of {{ workshoptype.paginator.num_pages }} + Page {{ workshop_type.number }} of {{ workshop_type.paginator.num_pages }} </span> </li> <li class="page-item"> - {% if workshoptype.has_next %} - <a class="page-link" href="?page={{ workshoptype.next_page_number }}">Next + {% if workshop_type.has_next %} + <a class="page-link" href="?page={{ workshop_type.next_page_number }}">Next </a> {% endif %} </li> diff --git a/workshop_app/urls.py b/workshop_app/urls.py index c58ba3b..059c1b5 100644 --- a/workshop_app/urls.py +++ b/workshop_app/urls.py @@ -15,7 +15,6 @@ Including another URLconf """ from django.conf.urls import url from workshop_app import views -import django js_info_dict = { 'packages': ('recurrence', ), @@ -30,21 +29,8 @@ urlpatterns = [ url(r'^logout/$', views.user_logout), url(r'^view_profile/$', views.view_profile), url(r'^edit_profile/$', views.edit_profile), - # url(r'^book/$', views.book), - # url(r'^book_workshop/$', views.book_workshop), url(r'^my_workshops/$', views.my_workshops), - # url(r'^how_to_participate/$', views.how_to_participate), - # url(r'^faq/$', views.faq), - # url(r'^manage/$', views.manage), - # url(r'^view_workshoptype_list/$', views.view_workshoptype_list), - # url(r'^view_workshoptype_details/([1-9][0-9]*)$', \ - # views.view_workshoptype_details), - # url(r'^create_workshop/$', views.create_workshop), url(r'^propose_workshop/$', views.propose_workshop), - # url(r'^workshop_stats/$', views.workshop_stats), - # url(r'^jsi18n/$', django.views.i18n.javascript_catalog, js_info_dict), - # url(r'^self_workshop', views.self_workshop), - # url(r'^view_comment_profile/([1-9][0-9]*)$', views.view_comment_profile), - # url(r'^download/',views.download_csv_data), + url(r'^workshop_type_list/$', views.workshop_type_list), + url(r'^workshop_type_details/([1-9][0-9]*)$', views.workshop_type_details), ] - diff --git a/workshop_app/views.py b/workshop_app/views.py index ac8fff3..65c08b2 100644 --- a/workshop_app/views.py +++ b/workshop_app/views.py @@ -1,8 +1,3 @@ -from os import listdir, path, sep -from zipfile import ZipFile - -from teams.models import Team - try: from StringIO import StringIO as string_io except ImportError: @@ -14,18 +9,15 @@ from django.contrib.auth.decorators import login_required from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger from django.shortcuts import render, redirect from django.utils import timezone -from django.http import HttpResponse from .forms import ( UserRegistrationForm, UserLoginForm, - ProfileForm, CreateWorkshop, - WorkshopForm + ProfileForm, WorkshopForm ) from .models import ( Profile, User, - has_profile, Workshop, - WorkshopType, - Testimonial, Banner + Workshop, + WorkshopType ) from .send_mails import send_email @@ -36,6 +28,8 @@ __credits__ = ["Mahesh Gudi", "Aditya P.", "Ankit Javalkar", "Arun KP"] +# Helper functions + def is_email_checked(user): if hasattr(user, 'profile'): return True if user.profile.is_email_verified else False @@ -43,63 +37,49 @@ def is_email_checked(user): return False -def is_superuser(user): - return True if user.is_superuser else False +def is_instructor(user): + """Check if the user is having instructor rights""" + return True if user.groups.filter(name='instructor').count() > 0 else False -def index(request): - '''Landing Page''' +def get_landing_page(user): + # For now, landing pages of both instructor and coordinator are same + if user.groups.filter(name='instructor').count() > 0: + return '/my_workshops/' + return '/my_workshops/' + +# View functions + +def index(request): + """Landing Page : Redirect to login page if not logged in + Redirect to respective landing page according to position""" user = request.user - form = UserLoginForm() - testimonials = Testimonial.objects.all() if user.is_authenticated and is_email_checked(user): - if user.groups.filter(name='instructor').count() > 0: - return redirect('/manage/') - return redirect('/book/') - elif request.method == "POST": - form = UserLoginForm(request.POST) - if form.is_valid(): - user = form.cleaned_data - login(request, user) - if is_superuser(user): - return redirect("/admin") - if user.groups.filter(name='instructor').count() > 0: - return redirect('/manage/') - return redirect('/book/') - - return render(request, "workshop_app/index.html", - { - "form": form, - "testimonials": testimonials, - "banners": Banner.objects.all(), - } - ) + return redirect(get_landing_page(user)) + return redirect('/login/') -def is_instructor(user): - '''Check if the user is having instructor rights''' - return True if user.groups.filter(name='instructor').count() > 0 else False +# User views def user_login(request): - '''User Login''' + """User Login""" user = request.user - if is_superuser(user): + if user.is_superuser: return redirect('/admin') if user.is_authenticated: - if user.groups.filter(name='instructor').count() > 0: - return redirect('/manage/') - return redirect('/book/') + return redirect(get_landing_page(user)) if request.method == "POST": form = UserLoginForm(request.POST) if form.is_valid(): user = form.cleaned_data - login(request, user) - if user.groups.filter(name='instructor').count() > 0: - return redirect('/manage/') - return redirect('/book/') + if user.profile.is_email_verified: + login(request, user) + return redirect(get_landing_page(user)) + else: + return render(request, 'workshop_app/activation.html') else: return render(request, 'workshop_app/login.html', {"form": form}) else: @@ -108,14 +88,14 @@ def user_login(request): def user_logout(request): - '''Logout''' + """Logout""" logout(request) return render(request, 'workshop_app/logout.html') def activate_user(request, key=None): user = request.user - if is_superuser(user): + if user.is_superuser: return redirect("/admin") if key is None: if user.is_authenticated and user.profile.is_email_verified == 0 and \ @@ -134,28 +114,25 @@ def activate_user(request, key=None): else: return redirect('/register/') - try: - user = Profile.objects.get(activation_key=key) - except: - return redirect('/register/') - - if key == user.activation_key: - user.is_email_verified = True - user.save() - status = "0" + user = Profile.objects.filter(activation_key=key) + if user.count() > 0: + user = user[0] else: logout(request) - return redirect('/logout/') + return redirect('/register/') + + user.is_email_verified = True + user.save() + status = "0" return render(request, 'workshop_app/activation.html', {"status": status}) def user_register(request): - '''User Registration form''' + """User Registration form""" if request.method == 'POST': form = UserRegistrationForm(request.POST) if form.is_valid(): - data = form.cleaned_data username, password, key = form.save() new_user = authenticate(username=username, password=password) login(request, new_user) @@ -165,7 +142,6 @@ def user_register(request): user_position=user_position, key=key ) - return render(request, 'workshop_app/activation.html') else: if request.user.is_authenticated: @@ -183,304 +159,93 @@ def user_register(request): return render(request, "workshop_app/registration/register.html", {"form": form}) -# This is shown to coordinator for booking workshops -# def book(request): -# user = request.user -# if user.is_authenticated: -# if is_email_checked(user): -# if user.groups.filter(name='instructor').count() > 0: -# return redirect('/manage/') -# -# workshop_details = Workshop.objects.all() -# -# workshop_occurence_list = [] -# today = datetime.now() + dt.timedelta(days=3) -# upto = datetime.now() + dt.timedelta(weeks=52) -# for workshops in workshop_details: -# dates = workshops.recurrences.between( -# today, -# upto, -# inc=True -# ) -# -# for d in range(len(dates)): -# workshop_occurence = [ -# dates[d].strftime("%d-%m-%Y"), -# workshops.workshop_instructor, -# workshops.workshop_title, -# workshops.workshop_instructor_id, -# workshops.workshop_title_id, -# workshops.workshop_title.workshoptype_description -# ] -# -# workshop_occurence_list.append(workshop_occurence) -# del workshop_occurence -# -# # Gives you the objects of BookedWorkshop -# bookedworkshop = BookedWorkshop.objects.all() -# if len(bookedworkshop) != 0: -# for b in bookedworkshop: -# ''' -# handles objects from bookedworkshop -# -requested -# -proposed -# ''' -# try: -# x = b.booked_workshop_requested.requested_workshop_date.strftime("%d-%m-%Y") -# y = b.booked_workshop_requested.requested_workshop_title -# except: -# x = b.booked_workshop_proposed.proposed_workshop_date.strftime("%d-%m-%Y") -# y = b.booked_workshop_proposed.proposed_workshop_title -# for a in workshop_occurence_list: -# if a[0] == x and a[2] == y: -# workshop_occurence_list.remove(a) -# del x, y -# -# # Objects of RequestedWorkshop for that particular coordinator -# rW_obj = RequestedWorkshop.objects.filter( -# requested_workshop_coordinator=request.user -# ) -# for r in rW_obj: -# x = r.requested_workshop_date.strftime("%d-%m-%Y") -# for a in workshop_occurence_list: -# if a[0] == x: -# workshop_occurence_list.remove(a) -# del x -# -# -# # Show upto 12 Workshops per page -# paginator = Paginator(workshop_occurence_list, 12) -# page = request.GET.get('page') -# try: -# workshop_occurences = paginator.page(page) -# except PageNotAnInteger: -# # If page is not an integer, deliver first page. -# workshop_occurences = paginator.page(1) -# except EmptyPage: -# # If page is out of range(e.g 999999), deliver last page. -# workshop_occurences = paginator.page(paginator.num_pages) -# -# return render( -# request, "workshop_app/booking.html", -# {"workshop_details": workshop_occurences} -# ) -# else: -# return redirect('/activate_user/') -# else: -# return redirect('/login/') -# -# -# @login_required -# def book_workshop(request): -# ''' -# Function for Updating RequestedWorkshop Model -# ''' -# if request.method == 'POST': -# user_position = request.user.profile.position -# client_data = request.body.decode("utf-8").split("&") -# client_data = client_data[0].split("%2C") -# workshop_date = client_data[0][2:] -# -# if client_data[-1] == '0': -# queue = RequestedWorkshop.objects.filter( -# requested_workshop_instructor=client_data[1], -# requested_workshop_date=datetime.strptime( -# client_data[0][2:], "%d-%m-%Y" -# ), -# requested_workshop_title=client_data[-2] -# ).count() + 1 -# -# return HttpResponse(str(queue)) -# -# workshops_list = Workshop.objects.filter( -# workshop_instructor=client_data[1], -# workshop_title_id=client_data[2] -# ) -# today = datetime.now() + dt.timedelta(days=3) -# upto = datetime.now() + dt.timedelta(weeks=52) -# for workshop in workshops_list: -# workshop_recurrence_list = workshop.recurrences.between( -# today, -# upto, -# inc=True -# ) -# -# rW_obj = RequestedWorkshop() -# if RequestedWorkshop.objects.filter( -# requested_workshop_instructor=workshop.workshop_instructor, -# requested_workshop_date=datetime.strptime( -# client_data[0][2:], "%d-%m-%Y", -# ), -# requested_workshop_coordinator=request.user, -# requested_workshop_title=client_data[-1] -# ).count() > 0: -# -# return HttpResponse(dedent("""You already have a booking -# for this workshop please check the -# instructors response in My Workshops tab and -# also check your email.""")) -# else: -# for w in workshop_recurrence_list: -# if workshop_date == (w.strftime("%d-%m-%Y")): -# rW_obj.requested_workshop_instructor = workshop.workshop_instructor -# rW_obj.requested_workshop_coordinator = request.user -# rW_obj.requested_workshop_date = datetime.strptime( -# workshop_date,"%d-%m-%Y" -# ) -# rW_obj.requested_workshop_title = workshop.workshop_title -# rW_obj.save() -# -# queue = RequestedWorkshop.objects.filter( -# requested_workshop_instructor=workshop.workshop_instructor, -# requested_workshop_date=datetime.strptime( -# workshop_date, "%d-%m-%Y", -# ), -# requested_workshop_title=client_data[-1] -# ).count() -# -# # Mail to instructor -# send_email(request, call_on='Booking', -# user_position='instructor', -# workshop_date=workshop_date, -# workshop_title=workshop.workshop_title.workshoptype_name, -# user_name=str(request.user.get_full_name()), -# other_email=workshop.workshop_instructor.email -# ) -# phone_number = workshop.workshop_instructor.profile.phone_number -# #Mail to coordinator -# send_email(request, call_on='Booking', -# workshop_date=workshop_date, -# workshop_title=workshop.workshop_title.workshoptype_name, -# user_name=workshop.workshop_instructor.profile.user.get_full_name(), -# other_email=workshop.workshop_instructor.email, -# phone_number=phone_number) -# -# return HttpResponse(dedent("""\ -# Your request has been successful, Please check -# your email for further information. Your request is number -# {0} in the queue.""".format(str(queue)))) -# else: -# logout(request) -# return HttpResponse("Some Error Occurred.") -# -# -# @login_required -# def manage(request): -# user = request.user -# -# if user.is_authenticated and is_email_checked(user): -# #Move user to the group via admin -# if user.groups.filter(name='instructor').count() > 0: -# try: -# #Can Handle Multiple Workshops -# workshop_details = Workshop.objects.filter( -# workshop_instructor=user.id -# ) -# -# workshop_occurence_list = [] -# today = datetime.now() + dt.timedelta(days=3) -# upto = datetime.now() + dt.timedelta(weeks=52) -# for workshop in workshop_details: -# workshop_occurence = workshop.recurrences.between( -# today, -# upto, -# inc=True -# ) -# for i in range(len(workshop_occurence)): -# -# workshop_occurence_list.append({ -# "user": str(user), -# "workshop": workshop.workshop_title, -# "date": workshop_occurence[i].date() -# }) -# -# requested_workshop = RequestedWorkshop.objects.filter( -# requested_workshop_instructor=user.id -# ) -# -# -# #Need to recheck logic -# for j in range(len(requested_workshop)): -# for i in workshop_occurence_list: -# a = requested_workshop[j].requested_workshop_date -# b = requested_workshop[j].requested_workshop_title -# if i['date'] == a and i['workshop'] == b: -# workshop_occurence_list.remove(i) -# del a, b -# -# -# #Show upto 12 Workshops per page -# paginator = Paginator(workshop_occurence_list, 12) -# page = request.GET.get('page') -# try: -# workshops = paginator.page(page) -# except PageNotAnInteger: -# #If page is not an integer, deliver first page. -# workshops = paginator.page(1) -# except EmptyPage: -# #If page is out of range(e.g 999999), deliver last page. -# workshops = paginator.page(paginator.num_pages) -# except: -# workshops = None -# -# return render( -# request, "workshop_app/manage.html", -# {"workshop_occurence_list": workshops} -# ) -# -# return redirect('/book/') -# else: -# return redirect('/activate_user/') -# -# +@login_required +def view_profile(request): + """ view instructor and coordinator profile """ + user = request.user + if user.is_superuser: + return redirect('/admin') + return render(request, "workshop_app/view_profile.html") + + +@login_required +def edit_profile(request): + """ edit profile details facility for instructor and coordinator """ + + user = request.user + if user.is_superuser: + return redirect('/admin') + + if request.method == 'POST': + form = ProfileForm(request.POST, user=user, instance=user.profile) + if form.is_valid(): + form_data = form.save(commit=False) + form_data.user = user + form_data.user.first_name = request.POST['first_name'] + form_data.user.last_name = request.POST['last_name'] + form_data.user.save() + form_data.save() + + return render( + request, 'workshop_app/profile_updated.html' + ) + else: + return render(request, 'workshop_app/edit_profile.html') + else: + form = ProfileForm(user=user, instance=user.profile) + return render(request, 'workshop_app/edit_profile.html', {'form': form}) + + +# Workshop views + @login_required def my_workshops(request): user = request.user - if user.is_authenticated and is_email_checked(user): + if user.is_authenticated: + # View for instructor if is_instructor(user): if request.method == 'POST': client_data = request.POST action = request.POST.get('action') - if action == 'accept' or action == 'approve': - workshop_status = Workshop.objects.get(id=client_data.get('workshop_id')) + if action == 'accept': + workshop = Workshop.objects.get(id=client_data.get('workshop_id')) # Change Status of the selected workshop - workshop_status.status = 1 - workshop_status.instructor = user - workshop_status.save() - ws = workshop_status + workshop.status = 1 + workshop.instructor = user + workshop.save() # Parameters for emails - cmail = ws.coordinator.email - cname = ws.coordinator.profile.user.get_full_name() - cnum = ws.coordinator.profile.phone_number - cinstitute = ws.coordinator.profile.institute - inum = request.user.profile.phone_number - wtitle = ws.workshop_type.name - workshop_date = str(ws.date) + coordinator_email = workshop.coordinator.email + coordinator_name = workshop.coordinator.profile.user.get_full_name() + coordinator_phone = workshop.coordinator.profile.phone_number + coordinator_institute = workshop.coordinator.profile.institute + instructor_phone = request.user.profile.phone_number + workshop_title = workshop.workshop_type.name + workshop_date = str(workshop.date) # For Instructor send_email(request, call_on='Booking Confirmed', user_position='instructor', workshop_date=workshop_date, - workshop_title=wtitle, - user_name=str(cname), - other_email=cmail, - phone_number=cnum, - institute=cinstitute + workshop_title=workshop_title, + user_name=str(coordinator_name), + other_email=coordinator_email, + phone_number=coordinator_phone, + institute=coordinator_institute ) # For Coordinator send_email(request, call_on='Booking Confirmed', workshop_date=workshop_date, - workshop_title=wtitle, - other_email=cmail, - phone_number=inum + workshop_title=workshop_title, + other_email=coordinator_email, + phone_number=instructor_phone ) elif action == 'change_date': cid = client_data.get('cid') new_workshop_date = datetime.strptime(client_data.get('new_date'), "%Y-%m-%d") - cemail = User.objects.get(id=cid) + coordinator_email = User.objects.get(id=cid) today = datetime.today() if today > new_workshop_date: # Invalid date @@ -490,21 +255,20 @@ def my_workshops(request): workshop_date = workshop[0].date workshop.update(date=new_workshop_date) - # For Instructor - send_email(request, call_on='Change Date', - user_position='instructor', - workshop_date=str(workshop_date), - new_workshop_date=str(new_workshop_date.date()) - ) + # For Instructor + send_email(request, call_on='Change Date', + user_position='instructor', + workshop_date=str(workshop_date), + new_workshop_date=str(new_workshop_date.date()) + ) - # For Coordinator - send_email(request, call_on='Change Date', - new_workshop_date=str(new_workshop_date.date()), - workshop_date=str(workshop_date), - other_email=cemail.email - ) + # For Coordinator + send_email(request, call_on='Change Date', + new_workshop_date=str(new_workshop_date.date()), + workshop_date=str(workshop_date), + other_email=coordinator_email.email + ) - workshops = [] today = datetime.today().date() proposed_workshop = Workshop.objects.filter( instructor=user.id, @@ -516,31 +280,19 @@ def my_workshops(request): ).order_by('-date') workshops = list(proposed_workshop) + list(proposed_workshop_pending) - print(workshops) - - # team_members = list(set(user.profile.team_set.all().values_list('members', flat=True))) - teams = Team.objects.filter(members=user.profile) - team_workshops = [] - if teams: - team_members = Profile.objects.filter(team__in=teams).exclude(id=user.profile.id).distinct() - team_member_ids = team_members.values_list('user__id') - team_workshops = Workshop.objects.filter( - date__gte=today, - instructor_id__in=team_member_ids, - ) return render(request, 'workshop_app/my_workshops.html', {"workshops": workshops, - "team_workshops": team_workshops, "today": today}) + # Coordinator view else: workshops = Workshop.objects.filter( coordinator=user.id ).order_by('-date') - print(workshops) return render(request, 'workshop_app/my_workshops.html', {"workshops": workshops}) + # Not logged in view else: return redirect('/login/') @@ -550,570 +302,76 @@ def propose_workshop(request): """Coordinator proposed a workshop and date""" user = request.user - if is_superuser(user): + if user.is_superuser: return redirect("/admin") - if is_email_checked(user): - if is_instructor(user): - return redirect('/manage/') - else: - if request.method == 'POST': - form = WorkshopForm(request.POST) - if form.is_valid(): - form_data = form.save(commit=False) - form_data.coordinator = user - # Avoiding Duplicate workshop entries for same date and workshop_title - if Workshop.objects.filter( - date=form_data.date, - workshop_type=form_data.workshop_type, - coordinator=form_data.coordinator - ).exists(): - return redirect('/my_workshops/') - else: - form_data.save() - instructors = Profile.objects.filter(position='instructor') - for i in instructors: - send_email(request, call_on='Proposed Workshop', - user_position='instructor', - workshop_date=str(form_data.date), - workshop_title=form_data.title, - user_name=str(user.get_full_name()), - other_email=i.user.email, - phone_number=user.profile.phone_number, - institute=user.profile.institute - ) - return redirect('/my_workshops/') - else: - form = WorkshopForm() - return render( - request, 'workshop_app/propose_workshop.html', - {"form": form} - ) - else: - return render(request, 'workshop_app/activation.html') - - -@login_required -def view_profile(request): - """ view instructor and coordinator profile """ - user = request.user - if is_superuser(user): - return redirect('/admin') - if is_email_checked(user) and user.is_authenticated: - return render(request, "workshop_app/view_profile.html") - else: - if user.is_authenticated: - return render(request, 'workshop_app/activation.html') - else: - try: - logout(request) - return redirect('/login/') - except: - return redirect('/register/') - - -@login_required -def edit_profile(request): - """ edit profile details facility for instructor and coordinator """ - - user = request.user - if is_superuser(user): - return redirect('/admin') - if is_email_checked(user): - if is_instructor(user): - template = 'workshop_app/manage.html' - else: - template = 'workshop_app/booking.html' - else: - try: - logout(request) - return redirect('/login/') - except: - return redirect('/register/') - - context = {'template': template} - if has_profile(user) and is_email_checked(user): - profile = Profile.objects.get(user_id=user.id) - else: - profile = None - - if request.method == 'POST': - form = ProfileForm(request.POST, user=user, instance=profile) - if form.is_valid(): - form_data = form.save(commit=False) - form_data.user = user - form_data.user.first_name = request.POST['first_name'] - form_data.user.last_name = request.POST['last_name'] - form_data.user.save() - form_data.save() - - return render( - request, 'workshop_app/profile_updated.html' - ) - else: - context['form'] = form - return render(request, 'workshop_app/edit_profile.html', context) + if is_instructor(user): + return redirect(get_landing_page(user)) else: - form = ProfileForm(user=user, instance=profile) - return render(request, 'workshop_app/edit_profile.html', {'form': form}) - - -@login_required -def create_workshop(request): - '''Instructor creates workshops''' - - user = request.user - if is_superuser(user): - return redirect("/admin") - if is_instructor(user) and is_email_checked(user): if request.method == 'POST': - form = CreateWorkshop(request.POST) + form = WorkshopForm(request.POST) if form.is_valid(): form_data = form.save(commit=False) - # form_data.profile_id = profile.id - form_data.workshop_instructor = user - form_data.workshop_instructor.save() - form_data.save() - return redirect('/manage/') - else: - form = CreateWorkshop() + form_data.coordinator = user + # Avoiding Duplicate workshop entries for same date and workshop_title + if Workshop.objects.filter( + date=form_data.date, + workshop_type=form_data.workshop_type, + coordinator=form_data.coordinator + ).exists(): + return redirect('/my_workshops/') + else: + form_data.save() + instructors = Profile.objects.filter(position='instructor') + for i in instructors: + send_email(request, call_on='Proposed Workshop', + user_position='instructor', + workshop_date=str(form_data.date), + workshop_title=form_data.workshop_type, + user_name=str(user.get_full_name()), + other_email=i.user.email, + phone_number=user.profile.phone_number, + institute=user.profile.institute + ) + return redirect('/my_workshops/') + # GET request + form = WorkshopForm() return render( - request, 'workshop_app/create_workshop.html', + request, 'workshop_app/propose_workshop.html', {"form": form} ) - else: - return redirect('/book/') -def view_workshoptype_details(request, workshoptype_id): - '''Gives the types of workshop details ''' +def workshop_type_details(request, workshop_type_id): + """Gives the types of workshop details """ user = request.user - if is_superuser(user): + if user.is_superuser: return redirect("/admin") - view_workshoptype_details = WorkshopType.objects.get(id=workshoptype_id) + workshop_type = WorkshopType.objects.get(id=workshop_type_id) return render( - request, 'workshop_app/view_workshoptype_details.html', \ - {'workshoptype': view_workshoptype_details} + request, 'workshop_app/workshop_type_details.html', {'workshop_type': workshop_type} ) -def view_workshoptype_list(request): - '''Gives the details for types of workshops.''' +def workshop_type_list(request): + """Gives the details for types of workshops.""" user = request.user - if is_superuser(user): + if user.is_superuser: return redirect("/admin") - workshoptype_list = WorkshopType.objects.all() + workshop_types = WorkshopType.objects.all() - paginator = Paginator(workshoptype_list, 12) # Show upto 12 workshops per page + paginator = Paginator(workshop_types, 12) # Show upto 12 workshops per page page = request.GET.get('page') try: - workshoptype = paginator.page(page) + workshop_type = paginator.page(page) except PageNotAnInteger: # If page is not an integer, deliver first page. - workshoptype = paginator.page(1) + workshop_type = paginator.page(1) except EmptyPage: # If page is out of range(e.g 999999), deliver last page. - workshoptype = paginator.page(paginator.num_pages) - - return render( - request, 'workshop_app/view_workshoptype_list.html', \ - {'workshoptype': workshoptype} - ) - - -def faq(request): - return render(request, 'workshop_app/view_faq.html') - - -def how_to_participate(request): - return render(request, 'workshop_app/how_to_participate.html') - - -def file_view(request, workshop_title): - if workshop_title == 'flowchart': - return render(request, 'workshop_app/how_to_participate.html') - else: - filename = WorkshopType.objects.get(id=workshop_title) - attachment_path = path.dirname(filename.workshoptype_attachments.path) - zipfile_name = string_io() - zipfile = ZipFile(zipfile_name, "w") - attachments = listdir(attachment_path) - for file in attachments: - file_path = sep.join((attachment_path, file)) - zipfile.write(file_path, path.basename(file_path)) - zipfile.close() - zipfile_name.seek(0) - response = HttpResponse(content_type='application/zip') - response['Content-Disposition'] = 'attachment; filename={0}.zip'.format( - filename.workshoptype_name.replace(" ", "_") - ) - response.write(zipfile_name.read()) - return response - - -def check_workshop_type(x): - try: - y = datetime.strftime(x.proposed_workshop_date, '%d-%m-%Y') - except: - y = datetime.strftime(x.requested_workshop_date, '%d-%m-%Y') - return y + workshop_type = paginator.page(paginator.num_pages) -# @login_required -# def workshop_stats(request): -# user = request.user -# today = datetime.now() -# upto = today + dt.timedelta(days=120) -# -# #For Monthly Chart -# workshop_count = [0] * 12 -# for x in range(12): -# workshop_count[x] +=RequestedWorkshop.objects.filter( -# requested_workshop_date__year=str(today.year), -# requested_workshop_date__month=str(x+1), -# status='ACCEPTED').count() -# workshop_count[x] +=ProposeWorkshopDate.objects.filter( -# proposed_workshop_date__year=str(today.year), -# proposed_workshop_date__month=str(x+1), -# status='ACCEPTED').count() -# -# # Count Total Number of workshops for each type -# workshop_titles = WorkshopType.objects.all() -# workshoptype_dict = {} -# for title in workshop_titles: -# workshoptype_dict[title]=0 -# -# for title in workshoptype_dict.keys(): -# workshoptype_dict[title] += RequestedWorkshop.objects.filter( -# requested_workshop_title=title, -# status='ACCEPTED').count() -# workshoptype_dict[title] += ProposeWorkshopDate.objects.filter( -# proposed_workshop_title=title, -# status='ACCEPTED').count() -# #For Pie Chart -# workshoptype_num = [] -# workshoptype_title = [] -# for title in workshoptype_dict.keys(): -# workshoptype_title.append(str(title)) -# -# for count in workshoptype_dict.values(): -# workshoptype_num.append(count) -# -# workshoptype_count = [workshoptype_title, workshoptype_num] -# del workshoptype_title, workshoptype_num -# -# # For India Map -# states = [ -# ['Code', 'State', 'Number'], -# ["IN-AP", "Andhra Pradesh", 0], -# ["IN-AR", "Arunachal Pradesh", 0], -# ["IN-AS", "Assam", 0], -# ["IN-BR", "Bihar", 0], -# ["IN-CT", "Chhattisgarh", 0], -# ["IN-GA", "Goa", 0], -# ["IN-GJ", "Gujarat", 0], -# ["IN-HR", "Haryana", 0], -# ["IN-HP", "Himachal Pradesh", 0], -# ["IN-JK", "Jammu and Kashmir", 0], -# ["IN-JH", "Jharkhand", 0], -# ["IN-KA", "Karnataka", 0], -# ["IN-KL", "Kerala", 0], -# ["IN-MP", "Madhya Pradesh", 0], -# ["IN-MH", "Maharashtra", 0], -# ["IN-MN", "Manipur", 0], -# ["IN-ML", "Meghalaya", 0], -# ["IN-MZ", "Mizoram", 0], -# ["IN-NL", "Nagaland", 0], -# ["IN-OR", "Odisha", 0], -# ["IN-PB", "Punjab", 0], -# ["IN-RJ", "Rajasthan", 0], -# ["IN-SK", "Sikkim", 0], -# ["IN-TN", "Tamil Nadu", 0], -# ["IN-TG", "Telangana", 0], -# ["IN-TR", "Tripura", 0], -# ["IN-UT", "Uttarakhand", 0], -# ["IN-UP", "Uttar Pradesh", 0], -# ["IN-WB", "West Bengal", 0], -# ["IN-AN", "Andaman and Nicobar Islands", 0], -# ["IN-CH", "Chandigarh", 0], -# ["IN-DN", "Dadra and Nagar Haveli", 0], -# ["IN-DD", "Daman and Diu", 0], -# ["IN-DL", "Delhi", 0], -# ["IN-LD", "Lakshadweep", 0], -# ["IN-PY", "Puducherry", 0] -# ] -# -# workshop_state = [] -# requestedWorkshops = RequestedWorkshop.objects.filter(status='ACCEPTED') -# proposedWorkshops = ProposeWorkshopDate.objects.filter(status='ACCEPTED') -# for workshop in requestedWorkshops: -# for s in states: -# if s[0] == workshop.requested_workshop_coordinator.profile.state: -# s[2] +=1 -# -# for workshop in proposedWorkshops: -# for s in states: -# if s[0] == workshop.proposed_workshop_coordinator.profile.state: -# s[2] +=1 -# -# #For Data Downloading and Viewing -# if request.method == 'POST': -# try: -# from_dates = request.POST.get('from') -# to_dates = request.POST.get('to') -# -# #Fetches Accepted workshops which were proposed by Coordinators -# proposed_workshops = ProposeWorkshopDate.objects.filter( -# proposed_workshop_date__range=(from_dates, to_dates), -# status='ACCEPTED' -# ) -# -# # Fetches Accepted workshops which were Accepted by -# # Instructors based on their Availability -# requested_workshops = RequestedWorkshop.objects.filter( -# requested_workshop_date__range=(from_dates, to_dates), -# status='ACCEPTED' -# ) -# -# upcoming_workshops = [] -# -# for workshop in proposed_workshops: -# upcoming_workshops.append(workshop) -# -# for workshop in requested_workshops: -# upcoming_workshops.append(workshop) -# -# upcoming_workshops = sorted(upcoming_workshops, -# key=lambda x: check_workshop_type(x)) -# -# download = request.POST.get('Download') -# if download: -# response = HttpResponse(content_type='text/csv') -# -# response['Content-Disposition'] = 'attachment;\ -# filename="records_from_{0}_to_{1}.csv"'.format( -# from_dates,to_dates -# ) -# -# writer = csv.writer(response) -# header = [ -# 'coordinator name', -# 'instructor name', -# 'workshop', -# 'date', -# 'status', -# 'institute name' -# ] -# -# writer.writerow(header) -# -# for workshop in upcoming_workshops: -# try: -# row = [ -# workshop.proposed_workshop_coordinator, -# workshop.proposed_workshop_instructor, -# workshop.proposed_workshop_title, -# workshop.proposed_workshop_date, -# workshop.status, -# workshop.proposed_workshop_coordinator.profile.institute -# ] -# -# except: -# row = [ -# workshop.requested_workshop_coordinator, -# workshop.requested_workshop_instructor, -# workshop.requested_workshop_title, -# workshop.requested_workshop_date, -# workshop.status, -# workshop.requested_workshop_coordinator.profile.institute -# ] -# -# writer.writerow(row) -# return response -# else: -# return render(request, 'workshop_app/workshop_stats.html', -# { -# "upcoming_workshops": upcoming_workshops, -# "show_workshop_stats": settings.SHOW_WORKSHOP_STATS, -# "workshop_count": workshop_count, -# "workshoptype_count": workshoptype_count, -# "india_map": states -# }) -# except: -# messages.info(request, 'Please enter Valid Dates') -# -# if is_instructor(user) and is_email_checked(user): -# try: -# #Fetches Accepted workshops which were proposed by Coordinators -# proposed_workshops = ProposeWorkshopDate.objects.filter( -# proposed_workshop_date__range=(today, upto), -# status='ACCEPTED' -# ) -# -# #Fetches Accepted workshops which were Accepted by -# # Instructors based on their Availability -# requested_workshops = RequestedWorkshop.objects.filter( -# requested_workshop_date__range=(today, upto), -# status='ACCEPTED' -# ) -# -# upcoming_workshops = [] -# for workshop in proposed_workshops: -# upcoming_workshops.append(workshop) -# -# for workshop in requested_workshops: -# upcoming_workshops.append(workshop) -# -# upcoming_workshops = sorted(upcoming_workshops, -# key=lambda x: check_workshop_type(x)) -# -# except: -# upcoming_workshops = None -# -# paginator = Paginator(upcoming_workshops, 12) -# -# page = request.GET.get('page') -# try: -# upcoming_workshops = paginator.page(page) -# except PageNotAnInteger: -# #If page is not an integer, deliver first page. -# upcoming_workshops = paginator.page(1) -# except EmptyPage: -# #If page is out of range(e.g 999999), deliver last page. -# upcoming_workshops = paginator.page(paginator.num_pages) -# -# -# return render(request, 'workshop_app/workshop_stats.html', -# { -# "upcoming_workshops": upcoming_workshops, -# "show_workshop_stats": settings.SHOW_WORKSHOP_STATS, -# "workshop_count": workshop_count, -# "workshoptype_count": workshoptype_count, -# "india_map": states -# }) -# else: -# return redirect('/manage/') -# -# -# def self_workshop(request): -# return render(request, "workshop_app/self_workshop.html") -# -# -# -# @login_required -# def view_comment_profile(request, user_id): -# '''instructor can view/post comments on coordinator profile ''' -# user = request.user -# if is_instructor(user) and is_email_checked(user): -# comment_form = ProfileCommentsForm() -# coordinator_profile = Profile.objects.get(user_id=user_id) -# requested_workshop = RequestedWorkshop.objects.filter(requested_workshop_coordinator=user_id).order_by( -# 'requested_workshop_title') -# propose_workshop = ProposeWorkshopDate.objects.filter(proposed_workshop_coordinator=user_id).order_by( -# 'proposed_workshop_date') -# workshops=[] -# for workshop in propose_workshop: -# workshops.append(workshop) -# -# for workshop in requested_workshop: -# workshops.append(workshop) -# try: -# comments = ProfileComments.objects.filter(coordinator_profile_id=user_id).order_by('-created_date') -# except: -# comments = None -# if request.method == 'POST': -# comment_formpost = ProfileCommentsForm(request.POST) -# if comment_formpost.is_valid(): -# form_data = comment_formpost.save(commit=False) -# form_data.coordinator_profile_id = user_id -# form_data.instructor_profile_id = user.id -# form_data.save() -# -# return render(request, "workshop_app/view_comment_profile.html", -# {"coordinator_profile": coordinator_profile, -# "comments": comments, -# "comment_form": comment_form -# }) -# else: -# if comments is not None: -# #Show upto 12 Workshops per page -# paginator = Paginator(comments, 12) -# page = request.GET.get('page') -# try: -# comments = paginator.page(page) -# except PageNotAnInteger: -# #If page is not an integer, deliver first page. -# comments = paginator.page(1) -# except EmptyPage: -# #If page is out of range(e.g 999999), deliver last page. -# comments = paginator.page(paginator.num_pages) -# workshop={} -# return render(request, "workshop_app/view_comment_profile.html", -# {"coordinator_profile": coordinator_profile, -# "comments": comments, -# "comment_form": comment_form, -# "Workshops":workshops}) -# return redirect('/book/') -# -# @login_required -# def download_csv_data(request): -# user=request.user -# if user.profile.position == 'instructor': -# requested_workshop = RequestedWorkshop.objects.filter(requested_workshop_instructor=user.id).order_by( -# 'requested_workshop_title') -# propose_workshop = ProposeWorkshopDate.objects.filter(proposed_workshop_instructor=user.id).order_by( -# 'proposed_workshop_date') -# upcoming_workshops = [] -# for workshop in propose_workshop: -# upcoming_workshops.append(workshop) -# -# for workshop in requested_workshop: -# upcoming_workshops.append(workshop) -# -# response = HttpResponse(content_type='text/csv') -# -# response['Content-Disposition'] = 'attachment;\ -# filename="records_of_{0}.csv"'.format( -# user.username -# ) -# -# writer = csv.writer(response) -# header = [ -# 'coordinator name', -# 'instructor name', -# 'workshop', -# 'date', -# 'status', -# 'institute name' -# ] -# -# writer.writerow(header) -# -# for workshop in upcoming_workshops: -# try: -# row = [ -# workshop.proposed_workshop_coordinator, -# workshop.proposed_workshop_instructor, -# workshop.proposed_workshop_title, -# workshop.proposed_workshop_date, -# workshop.status, -# workshop.proposed_workshop_coordinator.profile.institute -# ] -# -# except: -# row = [ -# workshop.requested_workshop_coordinator, -# workshop.requested_workshop_instructor, -# workshop.requested_workshop_title, -# workshop.requested_workshop_date, -# workshop.status, -# workshop.requested_workshop_coordinator.profile.institute -# ] -# -# writer.writerow(row) -# return response -# -# else: -# return redirect('/book/') + return render(request, 'workshop_app/workshop_type_list.html', {'workshop_type': workshop_type}) |