author | nishanth |
Thu, 25 Feb 2010 03:47:23 +0530 | |
changeset 90 | b2426897ff18 |
parent 86 | fcbdf372857c |
child 97 | 3699550991c6 |
permissions | -rw-r--r-- |
61 | 1 |
import os |
83 | 2 |
|
42
9b5b8c997598
started using django-registration default backend, removed browse users functionality.
anoop
parents:
40
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 redirect, render_to_response |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
5 |
from django.contrib.auth.models import User |
39 | 6 |
from django.contrib.auth.decorators import login_required |
7 |
||
83 | 8 |
from pytask.taskapp.models import Task, Profile, Request |
9 |
from pytask.taskapp.events.user import createUser, updateProfile |
|
10 |
from pytask.taskapp.forms.user import UserProfileEditForm |
|
17
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
11 |
|
21
c28774fe7ffd
implemented "add another mentor" functionality to a task.
nishanth
parents:
20
diff
changeset
|
12 |
def show_msg(message, redirect_url=None, url_desc=None): |
17
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
13 |
""" simply redirect to homepage """ |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
14 |
|
21
c28774fe7ffd
implemented "add another mentor" functionality to a task.
nishanth
parents:
20
diff
changeset
|
15 |
return render_to_response('show_msg.html',{'message':message, 'redirect_url':redirect_url, 'url_desc':url_desc}) |
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 |
|
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
17 |
def homepage(request): |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
18 |
""" check for authentication and display accordingly. """ |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
19 |
|
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
20 |
user = request.user |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
21 |
is_guest = False |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
22 |
is_mentor = False |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
23 |
can_create_task = False |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
24 |
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
|
25 |
|
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
26 |
if not user.is_authenticated(): |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
27 |
is_guest = True |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
28 |
disp_num = 10 |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
29 |
tasks_count = Task.objects.count() |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
30 |
if tasks_count <= disp_num: |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
31 |
task_list = Task.objects.order_by('id').reverse() |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
32 |
else: |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
33 |
task_list = Task.objects.order_by('id').reverse()[:10] |
21
c28774fe7ffd
implemented "add another mentor" functionality to a task.
nishanth
parents:
20
diff
changeset
|
34 |
|
c28774fe7ffd
implemented "add another mentor" functionality to a task.
nishanth
parents:
20
diff
changeset
|
35 |
return render_to_response('index.html', {'is_guest':is_guest, 'task_list':task_list}) |
c28774fe7ffd
implemented "add another mentor" functionality to a task.
nishanth
parents:
20
diff
changeset
|
36 |
|
17
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
37 |
else: |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
38 |
user_profile = user.get_profile() |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
39 |
is_mentor = True if user.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
|
40 |
can_create_task = False if user_profile.rights == u"CT" else True |
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
41 |
|
21
c28774fe7ffd
implemented "add another mentor" functionality to a task.
nishanth
parents:
20
diff
changeset
|
42 |
context = {'user':user, |
c28774fe7ffd
implemented "add another mentor" functionality to a task.
nishanth
parents:
20
diff
changeset
|
43 |
'is_guest':is_guest, |
c28774fe7ffd
implemented "add another mentor" functionality to a task.
nishanth
parents:
20
diff
changeset
|
44 |
'is_mentor':is_mentor, |
c28774fe7ffd
implemented "add another mentor" functionality to a task.
nishanth
parents:
20
diff
changeset
|
45 |
'task_list':task_list, |
c28774fe7ffd
implemented "add another mentor" functionality to a task.
nishanth
parents:
20
diff
changeset
|
46 |
'can_create_task':can_create_task, |
c28774fe7ffd
implemented "add another mentor" functionality to a task.
nishanth
parents:
20
diff
changeset
|
47 |
} |
c28774fe7ffd
implemented "add another mentor" functionality to a task.
nishanth
parents:
20
diff
changeset
|
48 |
|
c28774fe7ffd
implemented "add another mentor" functionality to a task.
nishanth
parents:
20
diff
changeset
|
49 |
return render_to_response('index.html', context) |
17
aa45fec40e7e
renamed users.py to user.py and tasks to task in views folder and updated urls.py accordingly .
nishanth
parents:
diff
changeset
|
50 |
|
39 | 51 |
@login_required |
42
9b5b8c997598
started using django-registration default backend, removed browse users functionality.
anoop
parents:
40
diff
changeset
|
52 |
def view_my_profile(request,uid=None): |
23 | 53 |
""" allows the user to view the profiles of users """ |
42
9b5b8c997598
started using django-registration default backend, removed browse users functionality.
anoop
parents:
40
diff
changeset
|
54 |
if uid == None: |
9b5b8c997598
started using django-registration default backend, removed browse users functionality.
anoop
parents:
40
diff
changeset
|
55 |
edit_profile = True |
9b5b8c997598
started using django-registration default backend, removed browse users functionality.
anoop
parents:
40
diff
changeset
|
56 |
profile = Profile.objects.get(user = request.user) |
69
49532a0f5071
added user context variable in view_profile and edit_profile.
nishanth
parents:
68
diff
changeset
|
57 |
return render_to_response('user/my_profile.html', {'edit_profile':edit_profile,'profile':profile, 'user':request.user}) |
23 | 58 |
edit_profile = True if request.user == User.objects.get(pk=uid) else False |
59 |
try: |
|
60 |
profile = Profile.objects.get(user = User.objects.get(pk=uid)) |
|
61 |
except Profile.DoesNotExist: |
|
62 |
raise Http404 |
|
69
49532a0f5071
added user context variable in view_profile and edit_profile.
nishanth
parents:
68
diff
changeset
|
63 |
return render_to_response('user/my_profile.html', {'edit_profile':edit_profile,'profile':profile, 'user':request.user}) |
23 | 64 |
|
45 | 65 |
@login_required |
23 | 66 |
def edit_my_profile(request): |
67 |
""" enables the user to edit his/her user profile """ |
|
68 |
if request.method == 'POST': |
|
69 |
form = UserProfileEditForm(request.POST) |
|
70 |
# if not form.is_valid(): |
|
71 |
# edit_profile_form = UserProfileEditForm(instance = form) |
|
72 |
# return render_to_response('user/edit_profile.html',{'edit_profile_form' : edit_profile_form}) |
|
73 |
if request.user.is_authenticated() == True: |
|
74 |
profile = Profile.objects.get(user = request.user) |
|
75 |
data = request.POST#form.cleaned_data |
|
61 | 76 |
properties = {'aboutme':data['aboutme'], |
77 |
'foss_comm':data['foss_comm'], |
|
78 |
'phonenum':data['phonenum'], |
|
79 |
'homepage':data['homepage'], |
|
80 |
'street':data['street'], |
|
81 |
'city':data['city'], |
|
82 |
'country':data['country'], |
|
83 |
'nick':data['nick']} |
|
84 |
uploaded_photo = request.FILES.get('photo',None) |
|
85 |
prev_photo = profile.photo |
|
86 |
if uploaded_photo: |
|
87 |
if prev_photo: |
|
88 |
os.remove(prev_photo.path) |
|
89 |
properties['photo'] = uploaded_photo |
|
23 | 90 |
#fields = ['dob','gender','credits','aboutme','foss_comm','phonenum','homepage','street','city','country','nick'] |
91 |
updateProfile(profile,properties) |
|
92 |
return redirect('/user/view/uid='+str(profile.user_id)) |
|
93 |
else: |
|
94 |
profile = Profile.objects.get(user = request.user) |
|
95 |
edit_profile_form = UserProfileEditForm(instance = profile) |
|
69
49532a0f5071
added user context variable in view_profile and edit_profile.
nishanth
parents:
68
diff
changeset
|
96 |
return render_to_response('user/edit_profile.html',{'edit_profile_form' : edit_profile_form, 'user':request.user}) |
28
e137b605b888
added browse users functionality, added user/browse.html, fixed view my profile template.
anoop
parents:
27
diff
changeset
|
97 |
|
83 | 98 |
@login_required |
99 |
def browse_requests(request): |
|
100 |
||
101 |
user = request.user |
|
86 | 102 |
active_reqs = user.request_sent_to.filter(is_replied=False) |
83 | 103 |
reqs = active_reqs.order_by('creation_date').reverse() |
104 |
for pos, req in enumerate(reversed(reqs)): |
|
105 |
req.pos = pos |
|
106 |
context = { |
|
107 |
'user':user, |
|
108 |
'reqs':reqs, |
|
109 |
} |
|
110 |
||
111 |
return render_to_response('user/browse_requests.html', context) |
|
112 |
||
113 |
@login_required |
|
114 |
def view_request(request, rid): |
|
115 |
""" please note that request variable in this method is that of django. |
|
116 |
our app request is called user_request. |
|
117 |
""" |
|
118 |
||
119 |
user = request.user |
|
86 | 120 |
reqs = user.request_sent_to.filter(is_replied=False).order_by('creation_date') |
83 | 121 |
user_request = reqs[int(rid)] |
122 |
||
123 |
context = { |
|
124 |
'user':user, |
|
125 |
'req':user_request, |
|
86 | 126 |
'sent_users':user_request.sent_to.all() |
83 | 127 |
} |
128 |
||
129 |
return render_to_response('user/view_request.html', context) |
|
130 |
||
131 |
@login_required |
|
132 |
def process_request(request, rid, reply): |
|
133 |
""" check if the method is post and then update the request. |
|
134 |
if it is get, display a 404 error. |
|
135 |
""" |
|
136 |
||
137 |
if request.method=="POST": |
|
138 |
user = request.user |
|
139 |
browse_request_url= '/user/requests' |
|
86 | 140 |
reqs = user.request_sent_to.filter(is_replied=False).order_by('creation_date') |
83 | 141 |
user_request = reqs[int(rid)] |
86 | 142 |
|
83 | 143 |
return show_msg("Your reply has been processed", browse_request_url, "view other requests") |
144 |
else: |
|
145 |
return show_msg("You are not authorised to do this", browse_request_url, "view other requests") |