diff --git a/admin/config.py b/admin/config.py index 9621d28f..5d533106 100644 --- a/admin/config.py +++ b/admin/config.py @@ -51,6 +51,7 @@ SurfaceWaterDataAdmin, ThingAdmin, TransducerObservationAdmin, + WeatherDataAdmin, FieldParametersAdmin, ) from db import NMA_FieldParameters @@ -75,6 +76,7 @@ NMA_Soil_Rock_Results, NMA_Stratigraphy, NMA_SurfaceWaterData, + NMA_WeatherData, ) from db.notes import Notes from db.observation import Observation @@ -180,6 +182,9 @@ def create_admin(app): # SoilRockResults admin.add_view(SoilRockResultsAdmin(NMA_Soil_Rock_Results)) + # Weather + admin.add_view(WeatherDataAdmin(NMA_WeatherData)) + # Future: Add more views here as they are implemented # admin.add_view(SampleAdmin) # admin.add_view(GroupAdmin) diff --git a/admin/views/__init__.py b/admin/views/__init__.py index 419fb9ac..d6809a5b 100644 --- a/admin/views/__init__.py +++ b/admin/views/__init__.py @@ -50,6 +50,7 @@ from admin.views.surface_water import SurfaceWaterDataAdmin from admin.views.thing import ThingAdmin from admin.views.transducer_observation import TransducerObservationAdmin +from admin.views.weather_data import WeatherDataAdmin __all__ = [ "AssetAdmin", @@ -82,4 +83,5 @@ "SurfaceWaterDataAdmin", "ThingAdmin", "TransducerObservationAdmin", + "WeatherDataAdmin", ] diff --git a/admin/views/weather_data.py b/admin/views/weather_data.py new file mode 100644 index 00000000..662721c3 --- /dev/null +++ b/admin/views/weather_data.py @@ -0,0 +1,66 @@ +from admin.views.base import OcotilloModelView + + +class WeatherDataAdmin(OcotilloModelView): + """ + Admin view for legacy WeatherData model (NMA_WeatherData). + """ + + # ========== Basic Configuration ========== + name = "NMA Weather Data" + label = "NMA Weather Data" + icon = "fa fa-cloud-sun" + + # Pagination + page_size = 50 + page_size_options = [25, 50, 100, 200] + + # ========== List View ========== + list_fields = [ + "location_id", + "point_id", + "weather_id", + "object_id", + ] + + sortable_fields = [ + "object_id", + "point_id", + ] + + fields_default_sort = [("point_id", False), ("object_id", False)] + + searchable_fields = [ + "point_id", + "weather_id", + ] + + # ========== Detail View ========== + fields = [ + "location_id", + "point_id", + "weather_id", + "object_id", + ] + + # ========== Legacy Field Labels ========== + field_labels = { + "location_id": "LocationId", + "point_id": "PointID", + "weather_id": "WeatherID", + "object_id": "OBJECTID", + } + + # ========== READ ONLY ========== + enable_publish_actions = ( + False # hides publish/unpublish actions inherited from base + ) + + def can_create(self, request) -> bool: + return False + + def can_edit(self, request) -> bool: + return False + + def can_delete(self, request) -> bool: + return False