Project

General

Profile

Download (11.3 KB) Statistics
| Branch: | Tag: | Revision:

calebasse / calebasse / personnes / views.py @ b5f052b7

1
# -*- coding: utf-8 -*-
2
from collections import defaultdict
3
from datetime import date
4
from interval import IntervalSet
5

    
6
from dateutil.relativedelta import relativedelta
7

    
8
from django.http import HttpResponseRedirect, Http404
9
from django.db.models import Q
10
from django.contrib.auth.models import User
11
from django.contrib import messages
12
from django.core.urlresolvers import reverse
13
from django.utils.dateformat import format as date_format
14

    
15
from calebasse import cbv, models as cb_models
16
from calebasse.ressources.models import Service
17

    
18
from calebasse.decorators import super_user_only
19

    
20
import forms
21
import models
22

    
23

    
24
FILTER_CRITERIA = (
25
        'username',
26
        'first_name',
27
        'last_name',
28
        'email',
29
        'userworker__worker__display_name',
30
)
31

    
32
class AccessView(cbv.ListView):
33
    model = User
34
    template_name = 'personnes/acces.html'
35

    
36
    def get_queryset(self):
37
        qs = super(AccessView, self).get_queryset()
38
        identifier = self.request.GET.get('identifier')
39
        if identifier:
40
            for part in identifier.split():
41
                filters = []
42
                for criteria in FILTER_CRITERIA:
43
                    q = Q(**{criteria+'__contains': part})
44
                    filters.append(q)
45
                qs = qs.filter(reduce(Q.__or__, filters))
46
        qs = qs.prefetch_related('userworker__worker')
47
        return qs
48

    
49
    def get_context_data(self, **kwargs):
50
        ctx = super(AccessView, self).get_context_data(**kwargs)
51
        ctx['active_list'] = ctx['object_list'].filter(is_active=True)
52
        ctx['inactive_list'] = ctx['object_list'].filter(is_active=False)
53
        return ctx
54

    
55

    
56
class AccessUpdateView(cbv.ServiceFormMixin, cbv.UpdateView):
57
    model = User
58
    template_name = 'personnes/acces-update.html'
59
    form_class = forms.UserForm
60
    success_url = '../'
61

    
62

    
63
class WorkerView(cbv.ListView):
64
    model = models.Worker
65
    template_name = 'personnes/workers.html'
66

    
67
    def get_form(self):
68
        return forms.WorkerSearchForm(data=self.request.GET or None)
69

    
70
    def get_queryset(self):
71
        qs = super(WorkerView, self).get_queryset()
72
        qs = qs.select_related()
73
        qs = qs.prefetch_related('services')
74
        form = self.get_form()
75
        if form.is_valid():
76
            cleaned_data = form.cleaned_data
77
            last_name = cleaned_data.get('last_name')
78
            first_name = cleaned_data.get('first_name')
79
            profession = cleaned_data.get('profession')
80
            intervene_status = cleaned_data.get('intervene_status')
81
            if last_name:
82
                qs = qs.filter(last_name__icontains=last_name)
83
            if first_name:
84
                qs = qs.filter(first_name__icontains=first_name)
85
            if profession:
86
                qs = qs.filter(type=profession)
87
            if intervene_status and 0 < len(intervene_status) < 2:
88
                qs = qs.filter(enabled=intervene_status[0] == 'a')
89
        else:
90
            # only display current workers by default
91
            qs = qs.filter(enabled=True)
92
        today = date.today()
93
        if models.Holiday.objects.for_service(self.service).future() \
94
                .filter(start_date__lte=today).exists():
95
            for worker in qs:
96
                worker.holiday = True
97
        else:
98
            qs2 = models.Holiday.objects.today()
99
            worker_dict = dict(((w.id, w) for w in qs))
100
            for worker in qs:
101
                worker.holiday = False
102
            for holiday in qs2:
103
                if holiday.worker.id in worker_dict:
104
                    worker_dict[holiday.worker.id].holiday = True
105
        return qs
106

    
107
    def get_context_data(self, **kwargs):
108
        ctx = super(WorkerView, self).get_context_data(**kwargs)
109
        ctx['search_form'] = self.get_form()
110
        return ctx
111

    
112
homepage = cbv.TemplateView.as_view(template_name='personnes/index.html')
113

    
114

    
115
user_listing = super_user_only(AccessView.as_view())
116

    
117

    
118
class UserCreateView(cbv.ServiceFormMixin, cbv.CreateView):
119
    model=User
120
    success_url='../'
121
    form_class=forms.UserForm
122
    template_name='calebasse/simple-form.html'
123
    template_name_suffix='_new.html'
124

    
125
class UserDeleteView(cbv.DeleteView):
126
    model = User
127
    success_url = "../../"
128
    template_name = 'calebasse/generic_confirm_delete.html'
129

    
130

    
131
user_new = super_user_only(UserCreateView.as_view())
132
user_update = super_user_only(AccessUpdateView.as_view())
133
user_delete = super_user_only(UserDeleteView.as_view())
134

    
135

    
136
class WorkerUpdateView(cbv.MultiUpdateView):
137
    model = models.Worker
138
    forms_classes = {
139
            'id': forms.WorkerIdForm,
140
            'services': forms.WorkerServiceForm
141
    }
142
    template_name = 'personnes/worker_update.html'
143
    success_url = './'
144

    
145
    def get_context_data(self, **kwargs):
146
        ctx = super(WorkerUpdateView, self).get_context_data(**kwargs)
147
        _timetables = defaultdict(lambda: [])
148
        for timetable in self.object.timetable_set.order_by('start_time'):
149
            _timetables[timetable.weekday].append(timetable)
150
        timetable = []
151
        for weekday, name in models.TimeTable.WEEKDAYS:
152
            timetable.append({
153
                'weekday': name,
154
                'schedules': _timetables[weekday]})
155
        ctx['weekdays'] = list(models.TimeTable.WEEKDAYS)
156
        ctx['timetables'] = timetable
157
        ctx['holidays'] = models.Holiday.objects \
158
                            .for_worker(self.object) \
159
                            .future() \
160
                            .order_by('start_date')
161
        try:
162
            holiday = models.Holiday.objects \
163
                    .for_worker(self.object) \
164
                    .today()[0]
165
        except IndexError:
166
            holiday = None
167
        ctx['holiday'] = holiday
168
        return ctx
169

    
170
    def form_valid(self, form):
171
        messages.add_message(self.request, messages.INFO, u'Modification enregistrée avec succès.')
172
        return super(WorkerUpdateView, self).form_valid(form)
173

    
174

    
175
class WorkerScheduleUpdateView(cbv.UpdateView):
176
    model = models.Worker
177
    form_class = forms.TimetableFormSet
178
    success_url = '../'
179
    template_name = 'personnes/worker_schedule_update.html'
180

    
181
    def get_form_kwargs(self):
182
        kwargs = super(WorkerScheduleUpdateView, self).get_form_kwargs()
183
        kwargs['queryset'] = models.TimeTable.objects.filter(weekday=self.weekday).prefetch_related('services')
184
        kwargs['initial'] = [{ 'services': Service.objects.all().values_list('pk', flat=True) }] * 3
185
        return kwargs
186

    
187
    def get_context_data(self, **kwargs):
188
        ctx = super(WorkerScheduleUpdateView, self).get_context_data(**kwargs)
189
        ctx['weekday'] = models.TimeTable.WEEKDAYS[self.weekday][1]
190
        return ctx
191

    
192
    def dispatch(self, *args, **kwargs):
193
        self.weekday = int(kwargs['weekday'])
194
        if self.weekday > 6:
195
            raise Http404()
196
        return super(WorkerScheduleUpdateView, self).dispatch(*args, **kwargs)
197

    
198
    def form_valid(self, form):
199
        instances = form.save(commit=False)
200
        for instance in instances:
201
            instance.weekday = self.weekday
202
            instance.save()
203
        form.save_m2m()
204
        return HttpResponseRedirect('')
205

    
206

    
207
class WorkerHolidaysUpdateView(cbv.UpdateView):
208
    model = models.Worker
209
    form_class = forms.HolidayFormSet
210
    success_url = '../'
211
    template_name = 'personnes/worker_holidays_update.html'
212

    
213
    def get_success_url(self):
214
        return self.success_url
215

    
216

    
217
worker_listing = WorkerView.as_view()
218
worker_new = cbv.CreateView.as_view(model=models.Worker,
219
        template_name='calebasse/simple-form.html',
220
        success_url='../')
221
worker_update = WorkerUpdateView.as_view()
222
worker_schedule_update = WorkerScheduleUpdateView.as_view()
223
worker_holidays_update = WorkerHolidaysUpdateView.as_view()
224
worker_delete = cbv.DeleteView.as_view(model=models.Worker,
225
        template_name='calebasse/simple-form.html',
226
        success_url='../../')
227

    
228

    
229
class HolidayView(cbv.TemplateView):
230
    months = 3
231
    template_name='personnes/holidays.html'
232

    
233
    def get_form(self):
234
        return forms.HolidaySearchForm(data=self.request.GET)
235

    
236
    def get_context_data(self, **kwargs):
237
        ctx = super(HolidayView, self).get_context_data(**kwargs)
238
        form = forms.HolidaySearchForm(data=self.request.GET)
239

    
240
        today = date.today()
241
        filter_start_date = today
242
        filter_end_date = date.today() + relativedelta(months=self.months)
243

    
244
        if form.is_valid():
245
            if form.cleaned_data.get('start_date'):
246
                filter_start_date = form.cleaned_data.get('start_date')
247
            if form.cleaned_data.get('end_date'):
248
                filter_end_date = form.cleaned_data.get('end_date')
249

    
250
        workers = models.Worker.objects.filter(enabled=True)
251
        holidays = models.Holiday.objects \
252
                .filter(end_date__gte=filter_start_date,
253
                        start_date__lte=filter_end_date) \
254
                .select_related('worker', 'service')
255
        holiday_by_worker = defaultdict(lambda: [])
256
        all_holidays = holidays.filter(worker__isnull=True)
257

    
258
        for worker in workers:
259
            holiday_by_worker[worker] = list(all_holidays)
260

    
261
        for holiday in holidays.filter(worker__isnull=False):
262
            holiday_by_worker[holiday.worker].append(holiday)
263

    
264
        def holiday_url(holiday):
265
            if holiday.worker:
266
                return reverse('worker-holidays-update', kwargs=dict(
267
                    service=self.service.slug, pk=holiday.worker.pk))
268
            else:
269
                slug = holiday.service.slug if holiday.service else self.service.slug
270
                return reverse('group-holiday-update', kwargs=dict(
271
                    service=slug))
272

    
273
        currents = []
274
        futures = defaultdict(lambda: [])
275
        for worker, holidays in holiday_by_worker.iteritems():
276
            for holiday in holidays:
277
                url = holiday_url(holiday)
278
                holiday_tpl = dict(worker=worker.display_name, holiday=holiday, url=url)
279
                if holiday.start_date <= today <= holiday.end_date:
280
                    currents.append(holiday_tpl)
281
                start_date = max(holiday.start_date, filter_start_date)
282
                month_name = date_format(start_date, 'F')
283
                key = start_date.year, start_date.month, month_name
284
                futures[key].append(holiday_tpl)
285

    
286
        future_holidays = []
287
        for key in sorted(futures.keys()):
288
            future_holidays.append(dict(
289
                month=key[2],
290
                holidays=futures[key]))
291
        future_holidays2 = []
292
        for i in range(0, len(future_holidays), 2):
293
            future_holidays2.append(future_holidays[i:i+2])
294

    
295
        ctx['end_date'] = filter_end_date
296
        ctx['current_holidays'] = currents
297
        ctx['future_holidays'] = future_holidays2
298
        ctx['group_holidays'] = all_holidays.order_by('-start_date')
299
        ctx['search_form'] = form
300
        return ctx
301

    
302

    
303
holiday_listing = HolidayView.as_view()
304

    
305

    
306
class GroupHolidayUpdateView(cbv.FormView):
307
    form_class = forms.GroupHolidayFormSet
308
    template_name = 'personnes/group_holiday_update.html'
309
    success_url = '.'
310

    
311
    def get_form_kwargs(self):
312
        kwargs = super(GroupHolidayUpdateView, self).get_form_kwargs()
313
        qs = models.Holiday.objects.for_service(self.service)
314
        kwargs['queryset'] = qs
315
        kwargs['service'] = self.service
316
        return kwargs
317

    
318
    def form_valid(self, form):
319
        form.save()
320
        return super(GroupHolidayUpdateView, self).form_valid(form)
321

    
322

    
323
group_holiday_update = GroupHolidayUpdateView.as_view()
324

    
325

    
326
#user_delete = UserCreateView.as_view()
327

    
(8-8/8)