admin.py 6.1 KB
Newer Older
David Haynes's avatar
David Haynes committed
1
2
#!/usr/bin/env python
# -*- coding: utf-8 -*-
3
"""
4
5
api/admin.py

6
7
8
9
Django admin interface configuration.

https://docs.djangoproject.com/en/1.11/ref/contrib/admin/
"""
10
# Django Imports
11
from django.contrib import admin
David Haynes's avatar
David Haynes committed
12
from django.contrib.gis.admin import OSMGeoAdmin
13
14
from django.core.exceptions import ObjectDoesNotExist
from django.http import HttpResponseRedirect
15
from django.shortcuts import render
16
# App Imports
David Haynes's avatar
David Haynes committed
17
from .models import Facility, Schedule, OpenTime, Category, Location, Alert
18

19

David Haynes's avatar
David Haynes committed
20
@admin.register(Facility)
Ben Waters's avatar
Ben Waters committed
21
class FacilityAdmin(admin.ModelAdmin):
22
    """
David Haynes's avatar
David Haynes committed
23
24
25
    Custom Admin panel for the Facility model.

    Allows admins to create new facilities through the admin interface.
26
    """
27
28
    def drop_special_schedules(self, request, queryset):
        num = queryset.count()
29
30
        for facility in queryset:
            facility.special_schedules.clear()
31
32
        self.message_user(request,
                          "Successfully cleared all special schedules for %d facilities." % num)
33
    drop_special_schedules.short_description = 'Clear all special schedules'
34

35
    def assign_bulk_schedules(self, request, queryset):
36
        num = queryset.count()
37
38
        # all admin actions-related requests are post requests, so we're looking for
        # the one that has the associated value with our confirmation input button
39
40
41
42
43
44
45
        if 'bulk_schedule' in request.POST:
            try:
                new_schedule = Schedule.objects.get(pk=request.POST['schedule'])
                name = new_schedule.name
                for facility in queryset:
                   facility.main_schedule = new_schedule
                   facility.save()
46
47
                self.message_user(request,
                                  "Set %s as the main schedule for %d facilities." % (name, num))
48
            except ObjectDoesNotExist:
49
50
                self.message_user(request,
                                  "Unable to set a new main schedule for %d facilities." % num)
51
            return HttpResponseRedirect(request.get_full_path())
52
53
54
55
        return render(request,
                      'bulk_schedules_intermediate.html',
                      context = {'facilities': queryset,
                                 'schedules': Schedule.objects.all()})
56
    assign_bulk_schedules.short_description = 'Set a main schedule for multiple facilities'
57

58
59
60
61
62
63
64
65
66
    def assign_bulk_special_schedules(self, request, queryset):
        num = queryset.count()
        if 'bulk_special_schedule' in request.POST:
            try:
                new_special_schedule = Schedule.objects.get(pk=request.POST['special_schedule'])
                name = new_special_schedule.name
                for facility in queryset:
                   facility.special_schedules.add(new_special_schedule)
                   facility.save()
67
68
                self.message_user(request,
                                  "Added %s as a special schedule to %d facilities." % (name, num))
69
            except ObjectDoesNotExist:
70
71
                self.message_user(request,
                                  "Unable to add additional special schedule to %d facilities." % num)
72
73
74
75
76
77
78
            return HttpResponseRedirect(request.get_full_path())
        return render(request,
                      'bulk_special_schedules_intermediate.html',
                      context = {'facilities': queryset,
                                 'schedules': Schedule.objects.all()})
    assign_bulk_special_schedules.short_description = 'Add a special schedule to multiple facilities'

79
    # a list of all actions to be added
80
81
    actions = [drop_special_schedules,
               assign_bulk_schedules, assign_bulk_special_schedules ]
82

David Haynes's avatar
David Haynes committed
83
    # Allow filtering by the following fields
David Haynes's avatar
David Haynes committed
84
    list_filter = ['facility_category', 'facility_location']
David Haynes's avatar
David Haynes committed
85
86
    # Modify the rendered layout of the "create a new facility" page
    # We are basically reordering things to look nicer to the user here
87
88
    fieldsets = (
        (None, {
David Haynes's avatar
David Haynes committed
89
90
91
92
93
            'fields': ('facility_name', 'logo', 'facility_category',
                       'facility_location', 'main_schedule', 'special_schedules',
                       ('facility_product_tags', 'facility_labels',
                        'facility_classifier'),
                       'tapingo_url', 'phone_number', 'note', 'owners'),
94
        }),
95
    )
96

97
98
99
100
101
102
103
104
105
106
class OpenTimeInline(admin.TabularInline):
    """
    A table of time periods that represent an "open time" for a Facility.

    https://docs.djangoproject.com/en/1.11/ref/contrib/admin/#django.contrib.admin.TabularInline
    """
    # Columns correspond to each attribute in the OpenTime table
    model = OpenTime
    # 7 days of the week, so only have 7 rows
    max_num = 7
107
108
109
110
111
112
113
114
115
116
    extra = 7
    # We are basically reordering things to look nicer to the user here
    fieldsets = (
        (None, {
            'fields': (
                ('start_day', 'start_time'),
                ('end_day', 'end_time')
            ),
        }),
    )
117

David Haynes's avatar
David Haynes committed
118
@admin.register(Schedule)
119
class ScheduleAdmin(admin.ModelAdmin):
120
    """
David Haynes's avatar
David Haynes committed
121
122
123
124
125
    Custom Admin panel for the Schedule model.

    Allows admins to create new schedules through the admin interface.
    Additionally, we append the OpenTimeInline table to allow for open times to
    be defined for the schedule we are creating.
126
    """
David Haynes's avatar
David Haynes committed
127
    # Allow filtering by the following fields
128
    list_display = ['name', 'modified']
David Haynes's avatar
David Haynes committed
129
    # Append the OpenTimeInline table to the end of our admin panel
130
    inlines = [OpenTimeInline, ]
David Haynes's avatar
David Haynes committed
131
    # Modify the rendered layout of the "create a new facility" page
132
133
    fieldsets = (
        (None, {
134
135
136
            'fields': ('name',
                       # Pair valid_start and valid_end together on the same
                       # line
David Haynes's avatar
David Haynes committed
137
                       ('valid_start', 'valid_end'),
138
                       'twenty_four_hours',
139
140
                       'schedule_for_removal',
                       'promote_to_main')
David Haynes's avatar
David Haynes committed
141
        }),
142
    )
143

David Haynes's avatar
David Haynes committed
144
# https://docs.djangoproject.com/en/1.11/ref/contrib/gis/admin/#osmgeoadmin
145
146
147
OSMGeoAdmin.default_lon = -8605757.16502
OSMGeoAdmin.default_lat = 4697457.00333
OSMGeoAdmin.default_zoom = 15
David Haynes's avatar
David Haynes committed
148
admin.site.register(Location, OSMGeoAdmin)
149
150
# Use the default ModelAdmin interface for these
admin.site.register(Category)
David Haynes's avatar
David Haynes committed
151
admin.site.register(Alert)