diff --git a/admin/config.py b/admin/config.py index c738fa6c..9a1a3775 100644 --- a/admin/config.py +++ b/admin/config.py @@ -50,6 +50,7 @@ SurfaceWaterDataAdmin, ThingAdmin, TransducerObservationAdmin, + WeatherPhotosAdmin, ) from db.asset import Asset from db.aquifer_system import AquiferSystem @@ -71,6 +72,7 @@ SoilRockResults, Stratigraphy, SurfaceWaterData, + WeatherPhotos, ) from db.notes import Notes from db.observation import Observation @@ -109,70 +111,71 @@ def create_admin(app): ) # Register model views - # Geography - admin.add_view(LocationAdmin(Location)) - - # Things (Wells, Springs, etc.) - admin.add_view(ThingAdmin(Thing)) + # Assets + admin.add_view(AssetAdmin(Asset)) - # Observations (Water Levels) - admin.add_view(ObservationAdmin(Observation)) + # Aquifer + admin.add_view(AquiferSystemAdmin(AquiferSystem)) + admin.add_view(AquiferTypeAdmin(AquiferType)) - # Contacts (Owners) + # Contacts admin.add_view(ContactAdmin(Contact)) - # Equipment - admin.add_view(SensorAdmin(Sensor)) + # Data provenance + admin.add_view(DataProvenanceAdmin(DataProvenance)) + + # Deployment / Equipment admin.add_view(DeploymentAdmin(Deployment)) + admin.add_view(SensorAdmin(Sensor)) - # Assets - admin.add_view(AssetAdmin(Asset)) + # Field + admin.add_view(FieldActivityAdmin(FieldActivity)) + admin.add_view(FieldEventAdmin(FieldEvent)) - # Aquifer - admin.add_view(AquiferSystemAdmin(AquiferSystem)) - admin.add_view(AquiferTypeAdmin(AquiferType)) + # Geology + admin.add_view(GeologicFormationAdmin(GeologicFormation)) + + # Geography + admin.add_view(LocationAdmin(Location)) # Groups admin.add_view(GroupAdmin(Group)) - # Notes - admin.add_view(NotesAdmin(Notes)) - - # Samples - admin.add_view(SampleAdmin(Sample)) - admin.add_view(ChemistrySampleInfoAdmin(ChemistrySampleInfo)) - admin.add_view(SurfaceWaterDataAdmin(SurfaceWaterData)) - # Hydraulics admin.add_view(HydraulicsDataAdmin(NMAHydraulicsData)) - admin.add_view(RadionuclidesAdmin(NMARadionuclides)) admin.add_view(MinorTraceChemistryAdmin(NMAMinorTraceChemistry)) + admin.add_view(RadionuclidesAdmin(NMARadionuclides)) - # Field - admin.add_view(FieldEventAdmin(FieldEvent)) - admin.add_view(FieldActivityAdmin(FieldActivity)) + # Lexicon + admin.add_view(LexiconCategoryAdmin(LexiconCategory)) + admin.add_view(LexiconTermAdmin(LexiconTerm)) + + # Notes + admin.add_view(NotesAdmin(Notes)) + + # Observations + admin.add_view(ObservationAdmin(Observation)) # Parameters admin.add_view(ParameterAdmin(Parameter)) - # Geology - admin.add_view(GeologicFormationAdmin(GeologicFormation)) + # Samples + admin.add_view(ChemistrySampleInfoAdmin(ChemistrySampleInfo)) + admin.add_view(SampleAdmin(Sample)) + admin.add_view(SurfaceWaterDataAdmin(SurfaceWaterData)) - # Data provenance - admin.add_view(DataProvenanceAdmin(DataProvenance)) + # Soil & Stratigraphy + admin.add_view(SoilRockResultsAdmin(SoilRockResults)) + admin.add_view(StratigraphyAdmin(Stratigraphy)) + + # Things (Wells, Springs, etc.) + admin.add_view(ThingAdmin(Thing)) # Transducer observations admin.add_view(TransducerObservationAdmin(TransducerObservation)) - # Lexicon - admin.add_view(LexiconTermAdmin(LexiconTerm)) - admin.add_view(LexiconCategoryAdmin(LexiconCategory)) - - # Stratigraphy - admin.add_view(StratigraphyAdmin(Stratigraphy)) - - # SoilRockResults - admin.add_view(SoilRockResultsAdmin(SoilRockResults)) + # Weather + admin.add_view(WeatherPhotosAdmin(WeatherPhotos)) # Future: Add more views here as they are implemented # admin.add_view(SampleAdmin) diff --git a/admin/views/__init__.py b/admin/views/__init__.py index 5061ba72..1af1fbb3 100644 --- a/admin/views/__init__.py +++ b/admin/views/__init__.py @@ -48,6 +48,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_photos import WeatherPhotosAdmin __all__ = [ "AssetAdmin", @@ -78,4 +79,5 @@ "SurfaceWaterDataAdmin", "ThingAdmin", "TransducerObservationAdmin", + "WeatherPhotosAdmin", ] diff --git a/admin/views/weather_photos.py b/admin/views/weather_photos.py new file mode 100644 index 00000000..403fcc3d --- /dev/null +++ b/admin/views/weather_photos.py @@ -0,0 +1,56 @@ +from admin.views.base import OcotilloModelView + + +class WeatherPhotosAdmin(OcotilloModelView): + """ + Admin view for legacy WeatherPhotos model (NMA_WeatherPhotos). + """ + + # ========== Basic Configuration ========== + name = "NMA Weather Photos" + label = "NMA Weather Photos" + icon = "fa fa-cloud" + + # Pagination + page_size = 50 + page_size_options = [25, 50, 100, 200] + + # ========== List View ========== + list_fields = [ + "weather_id", + "point_id", + "ole_path", + "object_id", + "global_id", + ] + + sortable_fields = [ + "global_id", + "object_id", + "point_id", + ] + + fields_default_sort = [("point_id", False), ("object_id", False)] + + searchable_fields = [ + "point_id", + "ole_path", + ] + + # ========== Detail View ========== + fields = [ + "weather_id", + "point_id", + "ole_path", + "object_id", + "global_id", + ] + + # ========== Legacy Field Labels ========== + field_labels = { + "weather_id": "WeatherID", + "point_id": "PointID", + "ole_path": "OLEPath", + "object_id": "OBJECTID", + "global_id": "GlobalID", + }