1
0
Fork 0
satnogs-network/network/base/admin.py

96 lines
2.9 KiB
Python
Raw Normal View History

from django.contrib import admin
2015-07-23 09:18:01 -06:00
from network.base.models import (Antenna, Satellite, Station, Transmitter,
Observation, Mode, Tle, Rig, DemodData)
2018-09-24 02:20:02 -06:00
from network.base.utils import export_as_csv
@admin.register(Rig)
class RigAdmin(admin.ModelAdmin):
list_display = ('name', 'rictld_number')
list_filter = ('name', )
2016-05-05 08:50:11 -06:00
@admin.register(Mode)
class ModeAdmin(admin.ModelAdmin):
list_display = ('name', )
readonly_fields = ('name', )
@admin.register(Antenna)
class AntennaAdmin(admin.ModelAdmin):
2018-08-17 03:23:44 -06:00
list_display = ('id', '__unicode__', 'antenna_count', 'station_list', )
list_filter = ('band', 'antenna_type', )
def antenna_count(self, obj):
return obj.stations.all().count()
def station_list(self, obj):
return ",\n".join([str(s.id) for s in obj.stations.all()])
@admin.register(Station)
class StationAdmin(admin.ModelAdmin):
2018-09-24 02:20:02 -06:00
list_display = ('id', 'name', 'owner', 'get_email', 'lng', 'lat', 'qthlocator',
'client_version', 'created_date', 'state')
list_filter = ('status', 'created', 'client_version')
2015-05-06 04:06:00 -06:00
2018-09-24 02:20:02 -06:00
actions = [export_as_csv]
export_as_csv.short_description = "Export selected as CSV"
2015-05-06 04:06:00 -06:00
def created_date(self, obj):
return obj.created.strftime('%d.%m.%Y, %H:%M')
2018-09-24 02:20:02 -06:00
def get_email(self, obj):
return obj.owner.email
get_email.admin_order_field = 'email'
get_email.short_description = 'Owner Email'
@admin.register(Satellite)
class SatelliteAdmin(admin.ModelAdmin):
list_display = ('name', 'norad_cat_id')
2016-01-22 10:48:07 -07:00
readonly_fields = ('name', 'names', 'image')
@admin.register(Tle)
class TleAdmin(admin.ModelAdmin):
list_display = ('satellite_name', 'tle0', 'tle1', 'updated_date')
list_filter = ('satellite__name',)
2015-05-06 04:06:00 -06:00
def updated_date(self, obj):
return obj.updated.strftime('%d.%m.%Y, %H:%M')
def satellite_name(self, obj):
return obj.satellite.name
@admin.register(Transmitter)
2015-07-23 09:18:01 -06:00
class TransmitterAdmin(admin.ModelAdmin):
list_display = ('uuid', 'description', 'satellite', 'uplink_low',
2014-10-16 07:42:44 -06:00
'uplink_high', 'downlink_low', 'downlink_high')
search_fields = ('satellite', 'uuid')
list_filter = ('mode', 'invert')
readonly_fields = ('uuid', 'description', 'satellite', 'uplink_low', 'uplink_high',
'downlink_low', 'downlink_high', 'baud', 'invert', 'alive', 'mode')
2015-05-06 04:06:00 -06:00
class DataDemodInline(admin.TabularInline):
model = DemodData
@admin.register(Observation)
2015-05-06 04:06:00 -06:00
class ObservationAdmin(admin.ModelAdmin):
2015-07-23 09:18:01 -06:00
list_display = ('id', 'author', 'satellite', 'transmitter', 'start_date', 'end_date')
2015-05-06 04:06:00 -06:00
list_filter = ('start', 'end')
search_fields = ('satellite', 'author')
inlines = [
DataDemodInline,
]
2015-05-06 04:06:00 -06:00
def start_date(self, obj):
return obj.start.strftime('%d.%m.%Y, %H:%M')
2015-05-06 04:06:00 -06:00
def end_date(self, obj):
return obj.end.strftime('%d.%m.%Y, %H:%M')