diff --git a/admin/config.py b/admin/config.py index 6bdd552d..d9d05a4b 100644 --- a/admin/config.py +++ b/admin/config.py @@ -50,6 +50,7 @@ SoilRockResultsAdmin, StratigraphyAdmin, SurfaceWaterDataAdmin, + SurfaceWaterPhotosAdmin, ThingAdmin, TransducerObservationAdmin, WeatherDataAdmin, @@ -78,6 +79,7 @@ NMA_Soil_Rock_Results, NMA_Stratigraphy, NMA_SurfaceWaterData, + NMA_SurfaceWaterPhotos, NMA_WeatherData, ) from db.notes import Notes @@ -187,6 +189,8 @@ def create_admin(app): # SoilRockResults admin.add_view(SoilRockResultsAdmin(NMA_Soil_Rock_Results)) + # Surface Water Photos + admin.add_view(SurfaceWaterPhotosAdmin(NMA_SurfaceWaterPhotos)) # Weather admin.add_view(WeatherDataAdmin(NMA_WeatherData)) diff --git a/admin/views/__init__.py b/admin/views/__init__.py index 4760122f..37027930 100644 --- a/admin/views/__init__.py +++ b/admin/views/__init__.py @@ -49,6 +49,7 @@ from admin.views.soil_rock_results import SoilRockResultsAdmin from admin.views.stratigraphy import StratigraphyAdmin from admin.views.surface_water import SurfaceWaterDataAdmin +from admin.views.surface_water_photos import SurfaceWaterPhotosAdmin from admin.views.thing import ThingAdmin from admin.views.transducer_observation import TransducerObservationAdmin from admin.views.weather_data import WeatherDataAdmin @@ -83,6 +84,7 @@ "SoilRockResultsAdmin", "StratigraphyAdmin", "SurfaceWaterDataAdmin", + "SurfaceWaterPhotosAdmin", "ThingAdmin", "TransducerObservationAdmin", "WeatherDataAdmin", diff --git a/admin/views/surface_water_photos.py b/admin/views/surface_water_photos.py new file mode 100644 index 00000000..2d2b7329 --- /dev/null +++ b/admin/views/surface_water_photos.py @@ -0,0 +1,71 @@ +from admin.views.base import OcotilloModelView + + +class SurfaceWaterPhotosAdmin(OcotilloModelView): + """ + Admin view for legacy SurfaceWaterPhotos model (NMA_SurfaceWaterPhotos). + """ + + # ========== Basic Configuration ========== + name = "NMA Surface Water Photos" + label = "NMA Surface Water Photos" + icon = "fa fa-water" + + # Pagination + page_size = 50 + page_size_options = [25, 50, 100, 200] + + # ========== List View ========== + list_fields = [ + "surface_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", + "global_id", + "ole_path", + ] + + # ========== Detail View ========== + fields = [ + "surface_id", + "point_id", + "ole_path", + "object_id", + "global_id", + ] + + # ========== Legacy Field Labels ========== + field_labels = { + "surface_id": "SurfaceID", + "point_id": "PointID", + "ole_path": "OLEPath", + "object_id": "OBJECTID", + "global_id": "GlobalID", + } + + # ========== 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