Completed
Push — master ( a732f9...22e740 )
by Vijay
01:54
created

workshop_details()   F

Complexity

Conditions 13

Size

Total Lines 22

Duplication

Lines 0
Ratio 0 %

Importance

Changes 5
Bugs 0 Features 0
Metric Value
cc 13
c 5
b 0
f 0
dl 0
loc 22
rs 3.5179

How to fix   Complexity   

Complexity

Complex classes like workshop_details() often do a lot of different things. To break such a class down, we need to identify a cohesive component within that class. A common approach to find such a component is to look for fields/methods that share the same prefixes, or suffixes.

Once you have determined the fields that belong together, you can apply the Extract Class refactoring. If the component makes sense as a sub-class, Extract Subclass is also a candidate, and is often faster.

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