admin.py 6 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)
    drop_special_schedules.short_description = 'Clear all special schedules'
33

34
    def assign_bulk_schedules(self, request, queryset):
35
36
37
38
39
40
41
42
43
        num = queryset.count()
        if 'bulk_schedule' in request.POST:
            print('request', 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()
44
45
                self.message_user(request,
                                  "Set %s as the main schedule for %d facilities." % (name, num))
46
            except ObjectDoesNotExist:
47
48
                self.message_user(request,
                                  "Unable to set a new main schedule for %d facilities." % num)
49
            return HttpResponseRedirect(request.get_full_path())
50
51
52
53
        return render(request,
                      'bulk_schedules_intermediate.html',
                      context = {'facilities': queryset,
                                 'schedules': Schedule.objects.all()})
54
    assign_bulk_schedules.short_description = 'Set a main schedule for multiple facilities'
55

56
57
58
59
60
61
62
63
64
65
    def assign_bulk_special_schedules(self, request, queryset):
        num = queryset.count()
        if 'bulk_special_schedule' in request.POST:
            print('request', 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()
66
67
                self.message_user(request,
                                  "Added %s as a special schedule to %d facilities." % (name, num))
68
            except ObjectDoesNotExist:
69
70
                self.message_user(request,
                                  "Unable to add additional special schedule to %d facilities." % num)
71
72
73
74
75
76
77
            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'

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

David Haynes's avatar
David Haynes committed
82
    # Allow filtering by the following fields
David Haynes's avatar
David Haynes committed
83
    list_filter = ['facility_category', 'facility_location']
David Haynes's avatar
David Haynes committed
84
85
    # Modify the rendered layout of the "create a new facility" page
    # We are basically reordering things to look nicer to the user here
86
87
    fieldsets = (
        (None, {
David Haynes's avatar
David Haynes committed
88
89
90
91
92
            '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'),
93
        }),
94
    )
95

96
97
98
99
100
101
102
103
104
105
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
106
107
108
109
110
111
112
113
114
115
    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')
            ),
        }),
    )
116

David Haynes's avatar
David Haynes committed
117
@admin.register(Schedule)
118
class ScheduleAdmin(admin.ModelAdmin):
119
    """
David Haynes's avatar
David Haynes committed
120
121
122
123
124
    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.
125
    """
David Haynes's avatar
David Haynes committed
126
    # Allow filtering by the following fields
127
    list_display = ['name', 'modified']
David Haynes's avatar
David Haynes committed
128
    # Append the OpenTimeInline table to the end of our admin panel
129
    inlines = [OpenTimeInline, ]
David Haynes's avatar
David Haynes committed
130
    # Modify the rendered layout of the "create a new facility" page
131
132
    fieldsets = (
        (None, {
133
134
135
            'fields': ('name',
                       # Pair valid_start and valid_end together on the same
                       # line
David Haynes's avatar
David Haynes committed
136
                       ('valid_start', 'valid_end'),
137
                       'twenty_four_hours',
138
139
                       'schedule_for_removal',
                       'promote_to_main')
David Haynes's avatar
David Haynes committed
140
        }),
141
    )
142

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