Completed
Push — master ( 1cc9aa...36e22f )
by Vijay
02:03
created

workshop_list()   B

Complexity

Conditions 6

Size

Total Lines 39

Duplication

Lines 0
Ratio 0 %

Importance

Changes 2
Bugs 0 Features 0
Metric Value
cc 6
c 2
b 0
f 0
dl 0
loc 39
rs 7.5384
1
from django.contrib.auth.decorators import login_required
2
from django.core.urlresolvers import reverse, reverse_lazy
3
from django.db.models import Q
4
from django.http import HttpResponseRedirect
5
from django.shortcuts import get_object_or_404
6
from django.shortcuts import redirect, render
7
from django.template import loader
8
from django.views import generic
9
10
from braces import views
11
from wye.base.emailer_html import send_email_to_list
12
from wye.organisations.models import Organisation
13
from wye.profiles.models import Profile
14
from wye.regions.models import RegionalLead
15
from wye.base.constants import WorkshopStatus
16
17
from wye.social.sites.twitter import send_tweet
18
from wye.base.views import verify_user_profile
19
from .forms import WorkshopForm, WorkshopEditForm, WorkshopFeedbackForm
20
from .mixins import (
21
    WorkshopEmailMixin,
22
    WorkshopAccessMixin
23
    )
24
from .models import Workshop
25
26
27
@login_required
28
@verify_user_profile
29
def workshop_list(request):
30
    template_name = 'workshops/workshop_list.html'
31
    user_profile, created = Profile.objects.get_or_create(
32
        user__id=request.user.id)
33
    if not user_profile.is_profile_filled:
34
        return redirect('profiles:profile-edit', slug=request.user.username)
35
    context_dict = {}
36
    workshop_list = Workshop.objects.all().order_by('-expected_date')
37
    workshop_list = workshop_list.filter(
38
        requester__location__id__in=[ x.id for x in
39
                request.user.profile.interested_locations.all()])
40
    # if Profile.is_organiser(request.user):
41
    #     workshop_list = workshop_list.filter(
42
    #         requester__user=request.user)
43
    # elif Profile.is_presenter(request.user):
44
    #     workshop_list = workshop_list.filter(
45
    #         Q(presenter=request.user) | Q
46
    #         (requester__location__id__in=[
47
    #             x.id for x in
48
    #             request.user.profile.interested_locations.all()]))
49
    # elif Profile.is_regional_lead(request.user):
50
    #     regions = RegionalLead.objects.filter(leads=request.user)
51
    #     workshop_list = workshop_list.filter(
52
    #         location__id__in=[x.location.id for x in regions])
53
    print(workshop_list)
54
    context_dict['workshop_list'] = workshop_list
55
    context_dict['user'] = request.user
56
    # need to improve the part
57
    context_dict['is_not_tutor'] = False
58
    # as user can be tutor and regional lead hence we need to verify like
59
    # this
60
    if (Profile.is_regional_lead(request.user) or
61
            Profile.is_organiser(request.user) or
62
            Profile.is_admin(request.user)):
63
        context_dict['is_not_tutor'] = True
64
65
    return render(request, template_name, context_dict)
66
67
68
def workshop_details(request, pk):
69
    template_name = 'workshops/workshop_detail.html'
70
    workshop_obj = get_object_or_404(Workshop, id=pk)
71
    context_dict = {'workshop': workshop_obj}
72
    return render(request, template_name, context_dict)
73
74
75
@login_required
76
@verify_user_profile
77
def workshop_create(request):
78
    template_name = 'workshops/workshop_create.html'
79
    context_dict = {}
80
    if not Organisation.list_user_organisations(request.user).exists():
81
        msg = """
82
                To request workshop you need to create organisaiton.\n\n
83
                Please use organisation tab above to create your organisation
84
            """
85
        return render(request, 'error.html', {'message': msg})
86
    if request.method == 'GET':
87
        form = WorkshopForm(user=request.user)
88
        context_dict['form'] = form
89
        return render(request, template_name, context_dict)
90
    form = WorkshopForm(user=request.user, data=request.POST)
91
    if not form.is_valid():
92
        context_dict['form'] = form
93
        context_dict['errors'] = form.errors
94
        return render(request, template_name, context_dict)
95
    workshop = form.save()
96
    context = {
97
        'workshop': workshop,
98
        'date': workshop.expected_date,
99
        'workshop_url': '/workshop/{}/'.format(workshop.id)
100
    }
101
    # Collage POC and admin email
102
    poc_admin_user = Profile.get_user_with_type(
103
        user_type=['Collage POC', 'admin']
104
        ).values_list('email', flat=True)
105
106
    org_user_emails = workshop.requester.user.filter(
107
        is_active=True).values_list('email', flat=True)
108
    # all presenter if any
109
    all_presenter_email = workshop.presenter.values_list(
110
        'email', flat=True)
111
    # List of tutor who have shown interest in that location
112
    region_interested_member = Profile.objects.filter(
113
        interested_locations=workshop.requester.location,
114
        usertype__slug='tutor'
115
        ).values_list('user__email', flat=True)
116
    all_email = []
117
    all_email.extend(org_user_emails)
118
    all_email.extend(all_presenter_email)
119
    all_email.extend(poc_admin_user)
120
    all_email.extend(region_interested_member)
121
    all_email = set(all_email)
122
    send_tweet(context)
123
124
    subject = '[PythonExpress] Workshop request status.'
125
    email_body = loader.get_template(
126
        'email_messages/workshop/create_workshop/message.html').render(context)
127
    text_body = loader.get_template(
128
        'email_messages/workshop/create_workshop/message.txt').render(context)
129
    send_email_to_list(
130
        subject,
131
        body=email_body,
132
        users_list=all_email,
133
        text_body=text_body)
134
    success_url = reverse_lazy('workshops:workshop_list')
135
    return HttpResponseRedirect(success_url)
136
137
138
class WorkshopUpdate(views.LoginRequiredMixin, WorkshopAccessMixin,
139
                     generic.UpdateView):
140
    model = Workshop
141
    form_class = WorkshopEditForm
142
    template_name = 'workshops/workshop_update.html'
143
144
    def get_success_url(self):
145
        # pk = self.kwargs.get(self.pk_url_kwarg, None)
146
        self.success_url = reverse("workshops:workshop_list")
147
        return super(WorkshopUpdate, self).get_success_url()
148
149
    def get_initial(self):
150
        return {
151
            "requester": self.object.requester.name,
152
        }
153
154
    def get_form_kwargs(self):
155
        kwargs = super(WorkshopUpdate, self).get_form_kwargs()
156
        kwargs['request'] = self.request
157
        return kwargs
158
159
160
class WorkshopToggleActive(views.LoginRequiredMixin, views.CsrfExemptMixin,
161
                           views.JSONResponseMixin, WorkshopAccessMixin,
162
                           generic.UpdateView):
163
    model = Workshop
164
    fields = ('is_active', 'id')
165
166
    def post(self, request, *args, **kwargs):
167
        self.object = self.get_object()
168
        response = self.object.toggle_active(request.user, **kwargs)
169
        return self.render_json_response(response)
170
171
172
class WorkshopAction(views.CsrfExemptMixin, views.LoginRequiredMixin,
173
                     views.JSONResponseMixin, WorkshopEmailMixin,
174
                     generic.UpdateView):
175
176
    model = Workshop
177
    email_dir = 'email_messages/workshop/assign_me/'
178
179
    def post(self, request, *args, **kwargs):
180
        self.object = self.get_object()
181
        response = self.object.manage_action(request.user, **kwargs)
182
183
        if response['status'] and response.get('notify') is not None:
184
            self.send_mail(request.user, response['assigned'])
185
            del response['notify']
186
        return self.render_json_response(response)
187
188
    def send_mail(self, user, assigned):
189
        """Send email to presenter and org users."""
190
191
        workshop = self.object
192
        context = {
193
            'presenter': True,
194
            'assigned': assigned,
195
            'date': workshop.expected_date,
196
            'presenter_name': user.username,
197
            'workshop_organization': workshop.requester,
198
            'workshop_url': self.request.build_absolute_uri(reverse(
199
                'workshops:workshop_detail', args=[workshop.pk]
200
            ))
201
        }
202
        # email to presenter and group
203
        self.send_mail_to_presenter(user, context)
204
        context['presenter'] = False
205
        self.send_mail_to_group(context, exclude_emails=[user.email])
206
207
208
class WorkshopFeedbackView(views.LoginRequiredMixin,
209
                           generic.FormView):
210
    form_class = WorkshopFeedbackForm
211
    template_name = "workshops/workshop_feedback.html"
212
    success_url = reverse_lazy('workshops:workshop_list')
213
214
    def form_valid(self, form):
215
        workshop_id = self.kwargs.get('pk')
216
        form.save(self.request.user, workshop_id)
217
        return super(WorkshopFeedbackView, self).form_valid(form)
218
219
    def get_context_data(self, *args, **kwargs):
220
        context = super(WorkshopFeedbackView, self).get_context_data(
221
            *args, **kwargs)
222
        context['workshop'] = Workshop.objects.get(pk=self.kwargs.get('pk'))
223
        return context
224
225
226
def upcoming_workshops(request):
227
    template_name = 'upcoming.html'
228
    workshop_list = Workshop.objects.filter(is_active=True).filter(
229
        status__in=[WorkshopStatus.REQUESTED,
230
            WorkshopStatus.ACCEPTED]).order_by('-expected_date')
231
    for workshop in workshop_list:
232
        print(workshop.presenter)
233
    context_dict = {}
234
    context_dict['workshop_list'] = workshop_list
235
236
    return render(request, template_name, context_dict)
237