taskapp/views/task.py
author nishanth
Mon, 01 Mar 2010 05:18:44 +0530
changeset 158 c43e0114e593
parent 157 65d5e9737d1c
child 159 a74a32a5a3e1
permissions -rw-r--r--
removing user deletes all the pending requests that request giving him pynts.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
17
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
     1
from datetime import datetime
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
     2
151
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
     3
from django.http import HttpResponse, Http404
17
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
     4
from django.shortcuts import render_to_response, redirect
18
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
     5
156
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
     6
from pytask.taskapp.models import User, Task, Comment, Claim, Request, Notification
120
aad4e6065d85 moved the getTask method to task_utilities.
nishanth
parents: 114
diff changeset
     7
from pytask.taskapp.utilities.task import getTask
94
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
     8
from pytask.taskapp.forms.task import TaskCreateForm, AddMentorForm, AddTaskForm, ChoiceForm, AssignCreditForm, RemoveUserForm
126
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
     9
from pytask.taskapp.events.task import createTask, reqMentor, publishTask, addSubTask, addDep, addClaim, assignTask, updateTask, removeTask, removeUser, assignCredits, completeTask, closeTask
18
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
    10
from pytask.taskapp.views.user import show_msg
138
c452c699a8af now all the pages show number of unread beside requests and notifications link in sidebar.
nishanth
parents: 136
diff changeset
    11
from pytask.taskapp.utilities.user import get_user
17
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    12
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
    13
## everywhere if there is no task, django should display 500 message.. but take care of that in sensitive views like add mentor and all
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
    14
## do not create su user thro syncdb
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
    15
17
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    16
def browse_tasks(request):
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    17
    """ display all the tasks """
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    18
    
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
    19
    user = get_user(request.user) if request.user.is_authenticated() else request.user
124
6d92b7cd2a37 taking care if publish task post request is made again. added published_date field to task.
nishanth
parents: 120
diff changeset
    20
    task_list = Task.objects.exclude(status="UP").exclude(status="DL").order_by('published_datetime').reverse()
17
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    21
    
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    22
    context = {'user':user,
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    23
               'task_list':task_list,
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    24
               }
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    25
    return render_to_response('task/browse.html', context)
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    26
111
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    27
def publish_task(request, tid):
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    28
    """ check if user is the mentor and also if the task status is UP.
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    29
    """
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    30
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    31
    task_url = "/task/view/tid=%s"%tid
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    32
    
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
    33
    user = get_user(request.user) if request.user.is_authenticated() else request.user
111
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    34
    task = getTask(tid)
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    35
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    36
    is_guest = True if not user.is_authenticated() else False
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    37
    is_mentor = True if user in task.mentors.all() else False
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    38
124
6d92b7cd2a37 taking care if publish task post request is made again. added published_date field to task.
nishanth
parents: 120
diff changeset
    39
    if user == task.created_by:
111
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    40
        context = {
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    41
            'user':user,
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    42
        }
124
6d92b7cd2a37 taking care if publish task post request is made again. added published_date field to task.
nishanth
parents: 120
diff changeset
    43
        if task.status == "UP":
6d92b7cd2a37 taking care if publish task post request is made again. added published_date field to task.
nishanth
parents: 120
diff changeset
    44
            if request.method == "POST":
6d92b7cd2a37 taking care if publish task post request is made again. added published_date field to task.
nishanth
parents: 120
diff changeset
    45
                publishTask(task)
6d92b7cd2a37 taking care if publish task post request is made again. added published_date field to task.
nishanth
parents: 120
diff changeset
    46
                return show_msg(user, "The task has been published", task_url, "view the task")
6d92b7cd2a37 taking care if publish task post request is made again. added published_date field to task.
nishanth
parents: 120
diff changeset
    47
            else:
6d92b7cd2a37 taking care if publish task post request is made again. added published_date field to task.
nishanth
parents: 120
diff changeset
    48
                return render_to_response('task/publish.html', context)
111
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    49
        else:
124
6d92b7cd2a37 taking care if publish task post request is made again. added published_date field to task.
nishanth
parents: 120
diff changeset
    50
            return show_msg(user, "The task is already published", task_url, "view the task")
111
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    51
    else:
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    52
        return show_msg(user, "You are not authorised to do this", '/task/browse/', "browse tasks")
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    53
17
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    54
def view_task(request, tid):
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    55
    """ get the task depending on its tid and display accordingly if it is a get.
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    56
    check for authentication and add a comment if it is a post request.
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    57
    """
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    58
    
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    59
    task_url = "/task/view/tid=%s"%tid
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    60
    
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
    61
    user = get_user(request.user) if request.user.is_authenticated() else request.user
55
ca2486e29178 added a utility called getTask in task events and made changes in task views accordingly
nishanth
parents: 36
diff changeset
    62
    task = getTask(tid)
110
3685c2333448 now deleted tasks cannot be viewed by anyone
nishanth
parents: 109
diff changeset
    63
3685c2333448 now deleted tasks cannot be viewed by anyone
nishanth
parents: 109
diff changeset
    64
    if task.status == "DL":
3685c2333448 now deleted tasks cannot be viewed by anyone
nishanth
parents: 109
diff changeset
    65
        return show_msg(user, 'This task no longer exists', '/task/browse/','browse the tasks')
155
52958289d81f now if a task has subs, it will remain locked forever.
nishanth
parents: 154
diff changeset
    66
    comments = task.comment_set.filter(is_deleted=False).order_by('creation_datetime')
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
    67
    mentors = task.mentors.all()
90
b2426897ff18 our task model does not meet out needs. so modified it and added a model called map. made the changes in views accordingly.phew!!!. this one took the hell out of me :( .
nishanth
parents: 89
diff changeset
    68
b2426897ff18 our task model does not meet out needs. so modified it and added a model called map. made the changes in views accordingly.phew!!!. this one took the hell out of me :( .
nishanth
parents: 89
diff changeset
    69
    deps, subs = task.deps, task.subs
b2426897ff18 our task model does not meet out needs. so modified it and added a model called map. made the changes in views accordingly.phew!!!. this one took the hell out of me :( .
nishanth
parents: 89
diff changeset
    70
    
17
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    71
    is_guest = True if not user.is_authenticated() else False
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    72
    is_mentor = True if user in task.mentors.all() else False
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    73
    context = {'user':user,
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    74
               'task':task,
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    75
               'comments':comments,
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
    76
               'mentors':mentors,
66
f670de53402b modified view task template and view to suit new design.
nishanth
parents: 64
diff changeset
    77
               'subs':subs,
f670de53402b modified view task template and view to suit new design.
nishanth
parents: 64
diff changeset
    78
               'deps':deps,
17
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    79
               'is_guest':is_guest,
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
    80
               'is_mentor':is_mentor,
66
f670de53402b modified view task template and view to suit new design.
nishanth
parents: 64
diff changeset
    81
              }
f670de53402b modified view task template and view to suit new design.
nishanth
parents: 64
diff changeset
    82
156
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
    83
    context['task_viewable'] = True if ( task.status != "UP" ) or is_mentor else False
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
    84
111
c272d4c601cd added the functionality to publish a task.
nishanth
parents: 110
diff changeset
    85
    context['can_publish'] = True if task.status == "UP" and user == task.created_by else False
156
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
    86
    context['can_edit'] = True if task.status in ["UP", "LO", "OP"] and is_mentor else False
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
    87
    context['can_close'] = True if task.status not in ["UP", "CD", "CM"] and is_mentor else False
66
f670de53402b modified view task template and view to suit new design.
nishanth
parents: 64
diff changeset
    88
f670de53402b modified view task template and view to suit new design.
nishanth
parents: 64
diff changeset
    89
    context['can_mod_mentors'] = True if task.status in ["UP", "OP", "LO", "WR"] and is_mentor else False
f670de53402b modified view task template and view to suit new design.
nishanth
parents: 64
diff changeset
    90
    context['can_mod_tasks'] = True if task.status in ["UP", "OP", "LO"] and is_mentor else False
156
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
    91
66
f670de53402b modified view task template and view to suit new design.
nishanth
parents: 64
diff changeset
    92
    context['can_assign_credits'] = True if task.status in ["OP", "WR"] and is_mentor else False
156
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
    93
    context['task_claimable'] = True if task.status in ["OP", "WR"] and not is_guest else False
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
    94
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
    95
    if task.status == "CD":
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
    96
        context['closing_notification'] =  Notification.objects.filter(task=task,role="CD")[0]
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
    97
    elif task.status == "CM":
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
    98
        context['completed_notification'] =  Notifications.objects.filter(task=task,role="CM")[0]
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
    99
    elif task.status == "WR":
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
   100
        context['assigned_users'] = task.assigned_users.all()
64
e743fe1f0f99 updated view task in views to suit the new design .
nishanth
parents: 55
diff changeset
   101
   
17
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
   102
    if request.method == 'POST':
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
   103
        if not is_guest:
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
   104
            data = request.POST["data"]
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
   105
            new_comment = Comment(task=task, data=data, created_by=user, creation_datetime=datetime.now())
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
   106
            new_comment.save()
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
   107
            return redirect(task_url)
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
   108
        else:
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
   109
            errors.append("You must be logged in to post a comment")
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
   110
            return render_to_response('task/view.html', context)
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
   111
    else:
aa45fec40e7e renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff changeset
   112
        return render_to_response('task/view.html', context)
18
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   113
        
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   114
def create_task(request):
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   115
    """ check for rights and create a task if applicable.
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   116
    if user cannot create a task, redirect to homepage.
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   117
    """
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   118
    
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
   119
    user = get_user(request.user) if request.user.is_authenticated() else request.user
18
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   120
    is_guest = True if not user.is_authenticated() else False
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   121
    
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   122
    if not is_guest:
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   123
        user_profile = user.get_profile()
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   124
        can_create_task = False if user_profile.rights == "CT" else True
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   125
        if can_create_task:
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   126
            if request.method == "POST":
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   127
                form = TaskCreateForm(request.POST)
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   128
                if form.is_valid():
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   129
                    data = form.cleaned_data
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   130
                    title = data['title']
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   131
                    desc = data['desc']
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   132
                    credits = data['credits']
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   133
                    publish = data['publish']
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   134
                    task = createTask(title,desc,user,credits)
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   135
                    
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   136
                    if not task:
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   137
                        error_msg = "Another task with the same title exists"
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   138
                        return render_to_response('task/create.html',{'form':form, 'error_msg':error_msg})
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   139
                    
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   140
                    addMentor(task, user)
66
f670de53402b modified view task template and view to suit new design.
nishanth
parents: 64
diff changeset
   141
                    updateTask(task,tags_field=data['tags_field'])
18
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   142
                    if publish: publishTask(task)    
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   143
                    task_url = '/task/view/tid=%s'%task.id
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   144
                    return redirect(task_url)
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   145
                else:
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   146
                    return render_to_response('task/create.html',{'form':form})
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   147
            else:
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   148
                form = TaskCreateForm()
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   149
                return render_to_response('task/create.html',{'form':form})
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   150
        else:
108
131554cc3434 updated show_msg method to also use the user variable in the context.
nishanth
parents: 105
diff changeset
   151
            return show_msg(user, 'You are not authorised to create a task.')
18
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   152
    else:
108
131554cc3434 updated show_msg method to also use the user variable in the context.
nishanth
parents: 105
diff changeset
   153
        return show_msg(user, 'You are not authorised to create a task.')
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   154
        
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   155
def add_mentor(request, tid):
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   156
    """ check if the current user has the rights to edit the task and add him.
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   157
    if user is not authenticated, redirect him to concerned page. """
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   158
    
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   159
    task_url = "/task/view/tid=%s"%tid
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   160
    
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
   161
    user = get_user(request.user) if request.user.is_authenticated() else request.user
55
ca2486e29178 added a utility called getTask in task events and made changes in task views accordingly
nishanth
parents: 36
diff changeset
   162
    task = getTask(tid)
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   163
    errors = []
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   164
    
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   165
    is_guest = True if not user.is_authenticated() else False
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   166
    
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   167
    if (not is_guest) and user in task.mentors.all():
149
3395960549e8 now a user cannot make two requests to another user for mentoring a task.
nishanth
parents: 141
diff changeset
   168
3395960549e8 now a user cannot make two requests to another user for mentoring a task.
nishanth
parents: 141
diff changeset
   169
        pending_requests = Request.objects.filter(is_replied=False,is_valid=True,role="MT",task=task).order_by('creation_date').reverse()
3395960549e8 now a user cannot make two requests to another user for mentoring a task.
nishanth
parents: 141
diff changeset
   170
        user_pending_requests = pending_requests.filter(sent_by=user)
3395960549e8 now a user cannot make two requests to another user for mentoring a task.
nishanth
parents: 141
diff changeset
   171
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   172
        ## now iam going for a brute force method
76
00a41fbf4958 fixed a bug in add_claim view in views/task .
nishanth
parents: 75
diff changeset
   173
        user_list = list(User.objects.filter(is_active=True))
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   174
        for mentor in task.mentors.all():
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   175
            user_list.remove(mentor)
34
22f302094806 fixed a bug in views/task/add_mentor method .
nishanth
parents: 33
diff changeset
   176
            
22f302094806 fixed a bug in views/task/add_mentor method .
nishanth
parents: 33
diff changeset
   177
        for a_user in task.claimed_users.all():
22f302094806 fixed a bug in views/task/add_mentor method .
nishanth
parents: 33
diff changeset
   178
            user_list.remove(a_user)
76
00a41fbf4958 fixed a bug in add_claim view in views/task .
nishanth
parents: 75
diff changeset
   179
00a41fbf4958 fixed a bug in add_claim view in views/task .
nishanth
parents: 75
diff changeset
   180
        for a_user in task.assigned_users.all():
00a41fbf4958 fixed a bug in add_claim view in views/task .
nishanth
parents: 75
diff changeset
   181
            user_list.remove(a_user)
149
3395960549e8 now a user cannot make two requests to another user for mentoring a task.
nishanth
parents: 141
diff changeset
   182
3395960549e8 now a user cannot make two requests to another user for mentoring a task.
nishanth
parents: 141
diff changeset
   183
        for req in user_pending_requests:
3395960549e8 now a user cannot make two requests to another user for mentoring a task.
nishanth
parents: 141
diff changeset
   184
            user_list.remove(req.sent_to.all()[0])
34
22f302094806 fixed a bug in views/task/add_mentor method .
nishanth
parents: 33
diff changeset
   185
            
151
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   186
        non_mentors = ((_.id, _.username) for _ in user_list)
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   187
        non_mentor_ids = [ str(a_user.id) for a_user in user_list ]
34
22f302094806 fixed a bug in views/task/add_mentor method .
nishanth
parents: 33
diff changeset
   188
        ## code till must be made elegant and not brute force like above
149
3395960549e8 now a user cannot make two requests to another user for mentoring a task.
nishanth
parents: 141
diff changeset
   189
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   190
        form = AddMentorForm(non_mentors)
151
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   191
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   192
        context = {
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   193
            'user':user,
156
7cad1e92713d finalised the view_task page.
nishanth
parents: 155
diff changeset
   194
            'task':task,
151
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   195
            'pending_requests':pending_requests,
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   196
            'form':form,
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   197
        }
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   198
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   199
        if request.method == "POST":
151
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   200
            data = request.POST
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   201
            uid = data.get('mentor', None)
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   202
            if uid in non_mentor_ids:
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   203
                new_mentor = User.objects.get(id=int(uid))
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   204
                reqMentor(task, new_mentor, user)
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   205
                return redirect('/task/addmentor/tid=%s'%task.id)
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   206
            else:
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   207
                ## bogus post request
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   208
                raise Http404
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   209
        else:
151
d0cb85ba462a no bogus post request can be made now in addmentor page.
nishanth
parents: 149
diff changeset
   210
            return render_to_response('task/addmentor.html', context)
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   211
    else:
108
131554cc3434 updated show_msg method to also use the user variable in the context.
nishanth
parents: 105
diff changeset
   212
        return show_msg(user, 'You are not authorised to add mentors for this task', task_url, 'view the task')
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   213
    
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   214
def add_tasks(request, tid):
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   215
    """ first display tasks which can be subtasks for the task and do the rest.
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   216
    """
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   217
    
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   218
    task_url = "/task/view/tid=%s"%tid
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   219
    
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
   220
    user = get_user(request.user) if request.user.is_authenticated() else request.user
55
ca2486e29178 added a utility called getTask in task events and made changes in task views accordingly
nishanth
parents: 36
diff changeset
   221
    task = getTask(tid)
89
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   222
90
b2426897ff18 our task model does not meet out needs. so modified it and added a model called map. made the changes in views accordingly.phew!!!. this one took the hell out of me :( .
nishanth
parents: 89
diff changeset
   223
    deps, subs = task.deps, task.subs
89
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   224
    is_plain = False if deps or subs else True
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   225
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   226
    ## again a brute force method
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   227
    valid_tasks = []
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   228
    for a_task in Task.objects.all():
90
b2426897ff18 our task model does not meet out needs. so modified it and added a model called map. made the changes in views accordingly.phew!!!. this one took the hell out of me :( .
nishanth
parents: 89
diff changeset
   229
        if not ( a_task in deps or a_task in subs or a_task.status=="CD" or a_task==task ):
89
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   230
            valid_tasks.append(a_task)
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   231
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   232
    task_choices = [ (_.id,_.title) for _ in valid_tasks ]
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   233
    errors = []
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   234
    
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   235
    is_guest = True if not user.is_authenticated() else False
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   236
    
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   237
    if (not is_guest) and user in task.mentors.all():
89
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   238
        if task.status in ["UP", "OP", "LO"]:
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   239
            form = AddTaskForm(task_choices, is_plain)
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   240
            if request.method == "POST":
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   241
                ## first decide if adding subs and deps can be in same page
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   242
                ## only exclude tasks with status deleted
89
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   243
                data = request.POST
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   244
                if is_plain and not data.get('type', None): errors.append('Please choose which type of task(s) do you want to add.')
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   245
                if not data.get('task', None): errors.append('Please choose a one task')
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   246
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   247
                if not errors:
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   248
                    if is_plain:
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   249
                        update_method = addDep if data['type'] == "D" else addSubTask
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   250
                    elif deps:
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   251
                        update_method = addDep
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   252
                    elif subs:
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   253
                        update_method = addSubTask
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   254
                    else:
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   255
                        print "Screw you"
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   256
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   257
                    ## we might iterate over a task list later on
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   258
                    task_id = data['task']
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   259
                    sub_or_dep = getTask(task_id)
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   260
                    update_method(task, sub_or_dep)
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   261
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   262
                    return redirect(task_url)
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   263
                else:
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   264
                    return render_to_response('task/addtask.html', {'user':user, 'form':form, 'errors':errors})
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   265
            else:
89
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   266
                return render_to_response('task/addtask.html', {'user':user, 'form':form, 'errors':errors})
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   267
        else:
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   268
            errors = ["The task cannot be added subtasks or dependencies in this state"]
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   269
#            return render_to_response('task/add.html', {'form':form, 'errors':errors})
108
131554cc3434 updated show_msg method to also use the user variable in the context.
nishanth
parents: 105
diff changeset
   270
            return show_msg(user, 'The task cannot be added subtasks or dependencies now', task_url, 'view the task')
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   271
    else:
108
131554cc3434 updated show_msg method to also use the user variable in the context.
nishanth
parents: 105
diff changeset
   272
        return show_msg(user, 'You are not authorised to add subtasks or dependencies for this task', task_url, 'view the task')
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   273
    
89
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   274
def remove_task(request, tid):
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   275
    """ display a list of tasks and remove the selectes ones.
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   276
    """
1cc03941ed5d added the capability of adding subtasks/dependencies .
nishanth
parents: 76
diff changeset
   277
92
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   278
    task_url = "/task/view/tid=%s"%tid
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   279
    
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
   280
    user = get_user(request.user) if request.user.is_authenticated() else request.user
92
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   281
    task = getTask(tid)
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   282
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   283
    is_guest = True if not user.is_authenticated() else False
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   284
    if (not is_guest) and user in task.mentors.all():
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   285
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   286
        deps, subs = task.deps, task.subs
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   287
        task_list = deps if task.sub_type == "D" else subs
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   288
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   289
        if task_list:
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   290
            choices = [(_.id,_.title) for _ in task_list ]
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   291
            form = ChoiceForm(choices)
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   292
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   293
            errors = []
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   294
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   295
            if request.method == "POST":
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   296
                data = request.POST
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   297
                if not data.get('choice', None): errors.append("Please choose a task to remove.")
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   298
                if not errors:
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   299
                    tid = data['choice']
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   300
                    sub_task = getTask(tid)
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   301
                    removeTask(task, sub_task)
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   302
                    return redirect(task_url)
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   303
                else:
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   304
                    return render_to_response('task/removetask.html', {'user':user, 'form':form, 'errors':errors})
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   305
            else:
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   306
                return render_to_response('task/removetask.html', {'user':user, 'form':form, 'errors':errors})
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   307
        else:
108
131554cc3434 updated show_msg method to also use the user variable in the context.
nishanth
parents: 105
diff changeset
   308
            return show_msg(user, "The task has no subtasks/dependencies to be removed", task_url, "view the task")
92
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   309
    else:
108
131554cc3434 updated show_msg method to also use the user variable in the context.
nishanth
parents: 105
diff changeset
   310
        return show_msg(user, "You are not authorised to do this", task_url, "view the task")
92
c99f09bebe56 added the capability to remove subtasks/dependencies .
nishanth
parents: 91
diff changeset
   311
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   312
def claim_task(request, tid):
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   313
    """ display a list of claims for get and display submit only if claimable """
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   314
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   315
    ## create claims model and create a new database with required tables for it
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   316
    ## see if that "one to n" or "n to one" relationship has a special field
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   317
    
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   318
    task_url = "/task/view/tid=%s"%tid
25
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   319
    claim_url = "/task/claim/tid=%s"%tid
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   320
    
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   321
    errors = []
21
c28774fe7ffd implemented "add another mentor" functionality to a task.
nishanth
parents: 18
diff changeset
   322
    
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
   323
    user = get_user(request.user) if request.user.is_authenticated() else request.user
55
ca2486e29178 added a utility called getTask in task events and made changes in task views accordingly
nishanth
parents: 36
diff changeset
   324
    task = getTask(tid)
22
36d3173ab7f9 addded link to view claims in 'view task' page .
nishanth
parents: 21
diff changeset
   325
    claims = Claim.objects.filter(task=task)
72
9fc60a221016 modified claim_task view to suit the new design
nishanth
parents: 66
diff changeset
   326
9fc60a221016 modified claim_task view to suit the new design
nishanth
parents: 66
diff changeset
   327
    mentors = task.mentors.all()
9fc60a221016 modified claim_task view to suit the new design
nishanth
parents: 66
diff changeset
   328
    claimed_users = task.claimed_users.all()
76
00a41fbf4958 fixed a bug in add_claim view in views/task .
nishanth
parents: 75
diff changeset
   329
    assigned_users = task.assigned_users.all()
22
36d3173ab7f9 addded link to view claims in 'view task' page .
nishanth
parents: 21
diff changeset
   330
    
36d3173ab7f9 addded link to view claims in 'view task' page .
nishanth
parents: 21
diff changeset
   331
    is_guest = True if not user.is_authenticated() else False
72
9fc60a221016 modified claim_task view to suit the new design
nishanth
parents: 66
diff changeset
   332
    is_mentor = True if user in mentors else False
22
36d3173ab7f9 addded link to view claims in 'view task' page .
nishanth
parents: 21
diff changeset
   333
72
9fc60a221016 modified claim_task view to suit the new design
nishanth
parents: 66
diff changeset
   334
    task_claimable = True if task.status in ["OP", "WR"] else False
76
00a41fbf4958 fixed a bug in add_claim view in views/task .
nishanth
parents: 75
diff changeset
   335
    user_can_claim = True if  task_claimable and not ( is_guest or is_mentor ) and ( user not in claimed_users ) and ( user not in assigned_users )  else False
72
9fc60a221016 modified claim_task view to suit the new design
nishanth
parents: 66
diff changeset
   336
    task_claimed = True if claimed_users else False
25
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   337
    
72
9fc60a221016 modified claim_task view to suit the new design
nishanth
parents: 66
diff changeset
   338
    context = {'user':user,
9fc60a221016 modified claim_task view to suit the new design
nishanth
parents: 66
diff changeset
   339
               'is_mentor':is_mentor,
25
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   340
               'task':task,
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   341
               'claims':claims,
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   342
               'user_can_claim':user_can_claim,
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   343
               'task_claimable':task_claimable,
33
0d0ea7b188d5 fixed a bug in templates/task/claim.html which required modification of views/task.py; also changed the no.of char limit on task title .
nishanth
parents: 25
diff changeset
   344
               'task_claimed':task_claimed,
25
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   345
               'errors':errors}
22
36d3173ab7f9 addded link to view claims in 'view task' page .
nishanth
parents: 21
diff changeset
   346
    
36d3173ab7f9 addded link to view claims in 'view task' page .
nishanth
parents: 21
diff changeset
   347
    if not is_guest:
25
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   348
        if request.method == "POST":
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   349
            claim_proposal = request.POST['message']
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   350
            if claim_proposal:
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   351
                addClaim(task, claim_proposal, user)
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   352
                return redirect(claim_url)
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   353
            else:
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   354
                errors.append('Please fill up proposal in the field below')
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   355
                return render_to_response('task/claim.html', context)
22
36d3173ab7f9 addded link to view claims in 'view task' page .
nishanth
parents: 21
diff changeset
   356
        else:
25
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   357
            return render_to_response('task/claim.html', context)
22
36d3173ab7f9 addded link to view claims in 'view task' page .
nishanth
parents: 21
diff changeset
   358
    else:
108
131554cc3434 updated show_msg method to also use the user variable in the context.
nishanth
parents: 105
diff changeset
   359
        return show_msg(user, 'You are not logged in to view claims for this task', task_url, 'view the task')
18
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   360
    
94
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   361
def rem_user(request, tid):
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   362
    """ show a list of working users and ask for a message/reason for removing user.
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   363
    """
18
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   364
    
94
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   365
    task_url = "/task/view/tid=%s"%tid
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   366
    
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
   367
    user = get_user(request.user) if request.user.is_authenticated() else request.user
94
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   368
    task = getTask(tid)
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   369
    
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   370
    is_guest = True if not user.is_authenticated() else False
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   371
    is_mentor = True if user in task.mentors.all() else False
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   372
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   373
    if (not is_guest) and is_mentor:
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   374
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   375
        assigned_users = task.assigned_users.all()
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   376
        choices = [ (_.id,_.username) for _ in assigned_users ]
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   377
        context = {
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   378
            'user':user,
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   379
            'task':task,
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   380
        }
158
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   381
        
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   382
        if task.status in ["OP", "WR"]:
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   383
            if assigned_users:
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   384
                form = RemoveUserForm(choices)
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   385
                context['form'] = form
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   386
                if request.method == "POST":
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   387
                    data = request.POST
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   388
                    form = RemoveUserForm(choices, data)
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   389
                    if form.is_valid():
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   390
                        data = form.cleaned_data
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   391
                        uid = data['user']
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   392
                        reason = data['reason']
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   393
                        rem_user = User.objects.get(id=uid)
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   394
                        removeUser(task, rem_user, user, reason)
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   395
                        return redirect(task_url)
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   396
                    else:
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   397
                        context['form'] = form
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   398
                        return render_to_response('task/remove_user.html', context)
94
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   399
                else:
158
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   400
                    return render_to_response('task/remove_user.html',context)
94
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   401
            else:
158
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   402
                return show_msg(user, "There is no one working on this task to be kicked off", task_url, "view the task")
94
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   403
        else:
158
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   404
            return show_msg(user, "This is not the stage to remove users", task_url, "view the task")
94
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   405
    else:
108
131554cc3434 updated show_msg method to also use the user variable in the context.
nishanth
parents: 105
diff changeset
   406
        return show_msg(user, "You are not authorised to do this", task_url, "view the task")
94
d1f59bbc2685 added capability to remove an assigned user.
nishanth
parents: 93
diff changeset
   407
25
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   408
def assign_task(request, tid):
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   409
    """ first get the status of the task and then assign it to one of claimed users
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   410
    generate list of claimed users by passing it as an argument to a function.
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   411
    """
18
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   412
    
25
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   413
    task_url = "/task/view/tid=%s"%tid
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   414
    
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
   415
    user = get_user(request.user) if request.user.is_authenticated() else request.user
55
ca2486e29178 added a utility called getTask in task events and made changes in task views accordingly
nishanth
parents: 36
diff changeset
   416
    task = getTask(tid)
25
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   417
    
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   418
    is_guest = True if not user.is_authenticated() else False
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   419
    is_mentor = True if user in task.mentors.all() else False
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   420
75
fa59955a340b modified the assign task view to suit the new design
nishanth
parents: 72
diff changeset
   421
    claimed_users = task.claimed_users.all()
fa59955a340b modified the assign task view to suit the new design
nishanth
parents: 72
diff changeset
   422
    assigned_users = task.assigned_users.all()
fa59955a340b modified the assign task view to suit the new design
nishanth
parents: 72
diff changeset
   423
fa59955a340b modified the assign task view to suit the new design
nishanth
parents: 72
diff changeset
   424
    task_claimed = True if claimed_users else False
18
a39549bd5b08 implemented create task view which needed task.py in events. added a method show_msg to views/user.py and used it in logoff view.
nishanth
parents: 17
diff changeset
   425
    
25
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   426
    if (not is_guest) and is_mentor:
157
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   427
        if task.status in ["OP", "WR"]:
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   428
            if task_claimed:
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   429
                user_list = ((user.id,user.username) for user in claimed_users)
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   430
                form = ChoiceForm(user_list)
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   431
        
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   432
                if request.method == "POST":
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   433
                    uid = request.POST['choice']
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   434
                    assigned_user = User.objects.get(id=uid)
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   435
                    assignTask(task, assigned_user, user)
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   436
                    return redirect(task_url)
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   437
                else:
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   438
                    return render_to_response('task/assign.html',{'user':user, 'task':task,'form':form})
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   439
            elif assigned_users:
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   440
                return show_msg(user, 'When the no of users you need for the task is more than the no of users willing to do the task, I\'d say please re consider the task :P',task_url, 'view the task')
25
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   441
            else:
157
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   442
                return show_msg(user, 'Wait for ppl to claim dude... slow and steady wins the race :)', task_url, 'view the task')
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   443
        else: 
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   444
            return show_msg(user, "The task cannot be assigned to users at this stage", task_url, 'view the task')
25
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   445
    else:
108
131554cc3434 updated show_msg method to also use the user variable in the context.
nishanth
parents: 105
diff changeset
   446
        return show_msg(user, 'You are not authorised to perform this action', task_url, 'view the task')
93
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   447
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   448
def assign_credits(request, tid):
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   449
    """ Check if the user is a mentor and credits can be assigned.
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   450
    Then display all the approved credits.
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   451
    Then see if mentor can assign credits to users also or only mentors.
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   452
    Then put up a form for mentor to assign credits accordingly.
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   453
    """
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   454
    
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   455
    task_url = "/task/view/tid=%s"%tid
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   456
    
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
   457
    user = get_user(request.user) if request.user.is_authenticated() else request.user
93
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   458
    task = getTask(tid)
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   459
157
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   460
    ## the moment we see that user had requested credits, it means he had worked and hence we change the status to WR
158
c43e0114e593 removing user deletes all the pending requests that request giving him pynts.
nishanth
parents: 157
diff changeset
   461
    ## we have to discuss on this since, credits may also be given to mentor
157
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   462
    task.status = "WR"
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   463
    task.save()
65d5e9737d1c fixed assign_task method to display a not_allowed message if task status not in OP WR.
nishanth
parents: 156
diff changeset
   464
93
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   465
    is_guest = True if not user.is_authenticated() else False
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   466
    is_mentor = True if (not is_guest) and user in task.mentors.all() else False
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   467
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   468
    if is_mentor:
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   469
        if task.status in ["OP", "WR"]:
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   470
            choices = [(_.id,_.username) for _ in task.mentors.all()]
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   471
            if task.status == "WR":
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   472
                choices.extend([(_.id, _.username) for _  in task.assigned_users.all() ])
136
8632a44b743d deducing previous credits for a task using the request model. with a few changes, we can ditchax the credits model.
nishanth
parents: 135
diff changeset
   473
            prev_credits = task.request_task.filter(role="PY",is_valid=True,is_replied=True,reply=True).count()
135
0ede6b2c5cd1 now view credits page shows all the credits.. including the pending and rejected ones.
nishanth
parents: 131
diff changeset
   474
            credit_requests = task.request_task.filter(role="PY",is_valid=True).order_by('creation_date').reverse()
93
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   475
            form = AssignCreditForm(choices)
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   476
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   477
            context = {
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   478
                'user':user,
96
2881ed1c52b0 added events addCredits and assignCredits and modified assign_credits view accordingly.
nishanth
parents: 94
diff changeset
   479
                'task':task,
93
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   480
                'prev_credits':prev_credits,
135
0ede6b2c5cd1 now view credits page shows all the credits.. including the pending and rejected ones.
nishanth
parents: 131
diff changeset
   481
                'credit_requests':credit_requests,
93
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   482
                'form':form,
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   483
            }
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   484
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   485
            if request.method == "POST":
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   486
                data = request.POST
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   487
                form = AssignCreditForm(choices, data)
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   488
                if form.is_valid():
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   489
                    data = form.cleaned_data
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   490
                    uid = data['user']
136
8632a44b743d deducing previous credits for a task using the request model. with a few changes, we can ditchax the credits model.
nishanth
parents: 135
diff changeset
   491
                    points = data['pynts']
93
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   492
                    given_to = User.objects.get(id=uid)
96
2881ed1c52b0 added events addCredits and assignCredits and modified assign_credits view accordingly.
nishanth
parents: 94
diff changeset
   493
                    assignCredits(task=task, given_by=user, given_to=given_to, points=points)
93
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   494
                    return redirect('/task/assigncredits/tid=%s'%task.id)
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   495
                else:
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   496
                    context['form'] = form
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   497
                    return render_to_response('task/assigncredits.html', context)
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   498
            else:
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   499
                return render_to_response('task/assigncredits.html', context)
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   500
        else:
108
131554cc3434 updated show_msg method to also use the user variable in the context.
nishanth
parents: 105
diff changeset
   501
            return show_msg(user, "Credits cannot be assigned at this stage", task_url, "view the task")
93
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   502
    else:
108
131554cc3434 updated show_msg method to also use the user variable in the context.
nishanth
parents: 105
diff changeset
   503
        return show_msg(user, "You are not authorised to perform this action", task_url, "view the task")
93
1a1e712e60fd finished assign_credits view. hav to integrate it with requests now.
nishanth
parents: 92
diff changeset
   504
36
0f10deac0a9b made urls.py look better and added an empty method edit_task to taskViews .
nishanth
parents: 34
diff changeset
   505
def edit_task(request, tid):
0f10deac0a9b made urls.py look better and added an empty method edit_task to taskViews .
nishanth
parents: 34
diff changeset
   506
    """ see what are the attributes that can be edited depending on the current status
0f10deac0a9b made urls.py look better and added an empty method edit_task to taskViews .
nishanth
parents: 34
diff changeset
   507
    and then give the user fields accordingly.
0f10deac0a9b made urls.py look better and added an empty method edit_task to taskViews .
nishanth
parents: 34
diff changeset
   508
    """
25
c0e4fc8b8b5b added the functionality to assign a task to one of the claimed users.
nishanth
parents: 22
diff changeset
   509
    
72
9fc60a221016 modified claim_task view to suit the new design
nishanth
parents: 66
diff changeset
   510
    task = Task.objects.get(id=tid) 
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
   511
    user = get_user(request.user) if request.user.is_authenticated() else request.user
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
   512
114
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   513
def complete_task(request, tid):
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   514
    """ call the event called complete task.
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   515
    and also pass it the current user to know who marked it as complete. 
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   516
    """
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   517
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   518
    task_url = "/task/view/tid=%s"%tid
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   519
    
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
   520
    user = get_user(request.user) if request.user.is_authenticated() else request.user
114
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   521
    task = getTask(tid)
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   522
    
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   523
    is_guest = True if not user.is_authenticated() else False
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   524
    is_mentor = True if user in task.mentors.all() else False
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   525
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   526
    claimed_users = task.claimed_users.all()
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   527
    assigned_users = task.assigned_users.all()
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   528
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   529
    assign_credits_url = '/task/assigncredits/tid=%s'%task.id
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   530
    task_assigned_credits = task.credit_set.all()
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   531
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   532
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   533
    if is_mentor:
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   534
        if task.status in ["OP", "WR"]:
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   535
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   536
            context = {
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   537
                'user':user,
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   538
                'task':task,
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   539
            }
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   540
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   541
            if task_assigned_credits:
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   542
                if request.method=="POST":
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   543
                    completeTask(task, user)
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   544
                    return redirect(task_url)
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   545
                else:
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   546
                    return render_to_response('task/complete.html', context)
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   547
            else:
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   548
                return show_msg(user, "Nobody has been credited for doing this task.", assign_credits_url, "assign credits")
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   549
        else:
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   550
            return show_msg(user, "The task cannot be marked as completed at this stage", task_url, "view the task")
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   551
    else:
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   552
        return show_msg(user, "You are not authorised to do this", task_url, "view the task")
38793914921b mark task as complete functionality is added.
nishanth
parents: 112
diff changeset
   553
126
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   554
def close_task(request, tid):
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   555
    """ task can be closed only if task is published.
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   556
    call the event close task if everything is fine.
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   557
    """
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   558
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   559
    task_url = "/task/view/tid=%s"%tid
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   560
    
141
2489392ffb56 added the functionality to request a user to be AD MG DV.
nishanth
parents: 138
diff changeset
   561
    user = get_user(request.user) if request.user.is_authenticated() else request.user
126
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   562
    task = getTask(tid)
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   563
    
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   564
    is_guest = True if not user.is_authenticated() else False
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   565
    is_mentor = True if user in task.mentors.all() else False
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   566
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   567
    if is_mentor:
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   568
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   569
        context = {
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   570
            'user':user,
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   571
            'task':task,
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   572
        }
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   573
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   574
        if not task.status in ["UP", "CD", "DL", "CM"]:
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   575
            if request.method == "POST":
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   576
                data = request.POST
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   577
                if not data.get("reason", None):
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   578
                    context["error"] = "Please enter a reason for closing the task"
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   579
                    return render_to_response('task/close.html', context)
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   580
                else:
153
925af1b4ee65 ditchaxed credit model.
nishanth
parents: 151
diff changeset
   581
                    closeTask(task, user, data['reason'])
126
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   582
                    return show_msg(user, "The task has been closed.", task_url, "view the task.")
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   583
            else:
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   584
                return render_to_response('task/close.html', context)
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   585
        else:
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   586
            return show_msg(user, "The task is already closed or the task cannot be closed at this stage", task_url, "view the task")
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   587
    else:
e5377fdaf110 added the functionality to close a task.
nishanth
parents: 124
diff changeset
   588
        return show_msg(user, "You are not authorised to do this", task_url, "view the task")