diff --git a/Core/LAMBDA/viz_functions/viz_publish_service/services/reference/static_public_critical_infrastructure_points.mapx b/Core/LAMBDA/viz_functions/viz_publish_service/services/reference/static_public_critical_infrastructure_points.mapx
new file mode 100644
index 00000000..9265a3b0
--- /dev/null
+++ b/Core/LAMBDA/viz_functions/viz_publish_service/services/reference/static_public_critical_infrastructure_points.mapx
@@ -0,0 +1,900 @@
+{
+ "type" : "CIMMapDocument",
+ "version" : "2.7.0",
+ "build" : 26828,
+ "mapDefinition" : {
+ "type" : "CIMMap",
+ "name" : "Map",
+ "uRI" : "CIMPATH=map/map.xml",
+ "sourceModifiedTime" : {
+ "type" : "TimeInstant"
+ },
+ "useSourceMetadata" : true,
+ "illumination" : {
+ "type" : "CIMIlluminationProperties",
+ "ambientLight" : 75,
+ "sunPositionX" : -0.61237243569579003,
+ "sunPositionY" : 0.61237243569579003,
+ "sunPositionZ" : 0.5,
+ "illuminationSource" : "AbsoluteSunPosition",
+ "sunAzimuth" : 315,
+ "sunAltitude" : 30,
+ "showStars" : true,
+ "enableAmbientOcclusion" : true,
+ "enableEyeDomeLighting" : true
+ },
+ "layers" : [
+ "CIMPATH=map/is_hydrovis_static_public_critical_infrastructure_points.xml"
+ ],
+ "defaultViewingMode" : "Map",
+ "mapType" : "Map",
+ "defaultExtent" : {
+ "xmin" : -10270366.9492253959,
+ "ymin" : 3710521.33466028515,
+ "xmax" : -9939055.65712730587,
+ "ymax" : 3836046.85290640406,
+ "spatialReference" : {
+ "wkid" : 102100,
+ "latestWkid" : 3857
+ }
+ },
+ "elevationSurfaces" : [
+ {
+ "type" : "CIMMapElevationSurface",
+ "elevationMode" : "BaseGlobeSurface",
+ "name" : "Ground",
+ "verticalExaggeration" : 1,
+ "mapElevationID" : "{1DC6D0F9-620F-48D0-B3C2-57D811BE753D}",
+ "color" : {
+ "type" : "CIMRGBColor",
+ "values" : [
+ 255,
+ 255,
+ 255,
+ 100
+ ]
+ },
+ "surfaceTINShadingMode" : "Smooth",
+ "visibility" : true,
+ "expanded" : true
+ }
+ ],
+ "generalPlacementProperties" : {
+ "type" : "CIMMaplexGeneralPlacementProperties",
+ "invertedLabelTolerance" : 2,
+ "unplacedLabelColor" : {
+ "type" : "CIMRGBColor",
+ "values" : [
+ 255,
+ 0,
+ 0,
+ 100
+ ]
+ },
+ "keyNumberGroups" : [
+ {
+ "type" : "CIMMaplexKeyNumberGroup",
+ "delimiterCharacter" : ".",
+ "horizontalAlignment" : "Left",
+ "maximumNumberOfLines" : 20,
+ "minimumNumberOfLines" : 2,
+ "name" : "Default",
+ "numberResetType" : "None",
+ "keyNumberMethod" : "PreventUnplacedLabels"
+ }
+ ],
+ "placementQuality" : "High"
+ },
+ "snappingProperties" : {
+ "type" : "CIMSnappingProperties",
+ "xYTolerance" : 10,
+ "xYToleranceUnit" : "SnapXYToleranceUnitPixel",
+ "snapToSketchEnabled" : true,
+ "snapRequestType" : "SnapRequestType_GeometricAndVisualSnapping",
+ "isZSnappingEnabled" : true
+ },
+ "spatialReference" : {
+ "wkid" : 102100,
+ "latestWkid" : 3857
+ },
+ "timeDisplay" : {
+ "type" : "CIMMapTimeDisplay",
+ "defaultTimeIntervalUnits" : "esriTimeUnitsUnknown",
+ "timeValue" : {
+ "type" : "TimeExtent",
+ "start" : null,
+ "end" : null,
+ "empty" : false
+ },
+ "timeRelation" : "esriTimeRelationOverlaps"
+ },
+ "colorModel" : "RGB",
+ "scaleDisplayFormat" : "Value",
+ "clippingMode" : "None",
+ "nearPlaneClipDistanceMode" : "Automatic",
+ "rGBColorProfile" : "sRGB IEC61966-2-1 noBPC",
+ "cMYKColorProfile" : "U.S. Web Coated (SWOP) v2"
+ },
+ "layerDefinitions" : [
+ {
+ "type" : "CIMFeatureLayer",
+ "name" : "static_public_critical_infrastructure_points",
+ "uRI" : "CIMPATH=map/is_hydrovis_static_public_critical_infrastructure_points.xml",
+ "sourceModifiedTime" : {
+ "type" : "TimeInstant"
+ },
+ "useSourceMetadata" : true,
+ "description" : "hydrovis.hydrovis.static_public_critical_infrastructure_points",
+ "layerElevation" : {
+ "type" : "CIMLayerElevationSurface",
+ "mapElevationID" : "{1DC6D0F9-620F-48D0-B3C2-57D811BE753D}"
+ },
+ "expanded" : true,
+ "layerType" : "Operational",
+ "showLegends" : true,
+ "visibility" : true,
+ "displayCacheType" : "Permanent",
+ "maxDisplayCacheAge" : 5,
+ "showPopups" : true,
+ "serviceLayerID" : -1,
+ "refreshRate" : -1,
+ "refreshRateUnit" : "esriTimeUnitsSeconds",
+ "blendingMode" : "Alpha",
+ "autoGenerateFeatureTemplates" : true,
+ "featureElevationExpression" : "0",
+ "featureTable" : {
+ "type" : "CIMFeatureTable",
+ "displayField" : "name",
+ "editable" : true,
+ "dataConnection" : {
+ "type" : "CIMSqlQueryDataConnection",
+ "workspaceConnectionString" : "ENCRYPTED_PASSWORD=00022e68704e547642676d7033392f6e43444a4a2f754855616e544850664f622f63692f6b5752345251746d792b6d777a524d75623242333132766575447161664b58782a00;SERVER=hv-ti-egis-rds-pg-egdb.c4vzypepnkx3.us-east-1.rds.amazonaws.com;INSTANCE=sde:postgresql:hv-ti-egis-rds-pg-egdb.c4vzypepnkx3.us-east-1.rds.amazonaws.com;DBCLIENT=postgresql;DB_CONNECTION_PROPERTIES=hv-ti-egis-rds-pg-egdb.c4vzypepnkx3.us-east-1.rds.amazonaws.com;DATABASE=hydrovis;USER=hydrovis;AUTHENTICATION_MODE=DBMS",
+ "workspaceFactory" : "SDE",
+ "dataset" : "hydrovis.hydrovis.%static_public_critical_infrastructure_points",
+ "datasetType" : "esriDTFeatureClass",
+ "sqlQuery" : "select country,naics_code,specialty,excess_bed,val_method,tot_enroll,city,latitude,county,level_,source,type,st_grade,sourcedate,st_grade_1,alias,state,id,helipad,build_type,end_grade,longitude,zip,trauma,naics_desc,website,address,naicscode,telephone,addressbui,tot_emp,population,enrollment,val_date,zipcode,alt_name,naicsdescr,ft_teacher,name,beds,objectid,status,geometry,oid from hydrovis.reference.static_public_critical_infrastructure_points_fema",
+ "srid" : "3857",
+ "spatialReference" : {
+ "wkid" : 102100,
+ "latestWkid" : 3857
+ },
+ "oIDFields" : "oid",
+ "geometryType" : "esriGeometryPoint",
+ "extent" : {
+ "xmin" : -19663709.1926999986,
+ "ymin" : -1613687.87180000171,
+ "xmax" : 19077762.1308000013,
+ "ymax" : 11514228.6788000017,
+ "spatialReference" : {
+ "wkid" : 102100,
+ "latestWkid" : 3857
+ }
+ },
+ "queryFields" : [
+ {
+ "name" : "country",
+ "type" : "esriFieldTypeString",
+ "alias" : "country",
+ "length" : 60000
+ },
+ {
+ "name" : "naics_code",
+ "type" : "esriFieldTypeString",
+ "alias" : "naics_code",
+ "length" : 60000
+ },
+ {
+ "name" : "specialty",
+ "type" : "esriFieldTypeString",
+ "alias" : "specialty",
+ "length" : 60000
+ },
+ {
+ "name" : "excess_bed",
+ "type" : "esriFieldTypeDouble",
+ "alias" : "excess_bed"
+ },
+ {
+ "name" : "val_method",
+ "type" : "esriFieldTypeString",
+ "alias" : "val_method",
+ "length" : 60000
+ },
+ {
+ "name" : "tot_enroll",
+ "type" : "esriFieldTypeDouble",
+ "alias" : "tot_enroll"
+ },
+ {
+ "name" : "city",
+ "type" : "esriFieldTypeString",
+ "alias" : "city",
+ "length" : 60000
+ },
+ {
+ "name" : "latitude",
+ "type" : "esriFieldTypeDouble",
+ "alias" : "latitude"
+ },
+ {
+ "name" : "county",
+ "type" : "esriFieldTypeString",
+ "alias" : "county",
+ "length" : 60000
+ },
+ {
+ "name" : "level_",
+ "type" : "esriFieldTypeString",
+ "alias" : "level_",
+ "length" : 60000
+ },
+ {
+ "name" : "source",
+ "type" : "esriFieldTypeString",
+ "alias" : "source",
+ "length" : 60000
+ },
+ {
+ "name" : "type",
+ "type" : "esriFieldTypeString",
+ "alias" : "type",
+ "length" : 60000
+ },
+ {
+ "name" : "st_grade",
+ "type" : "esriFieldTypeString",
+ "alias" : "st_grade",
+ "length" : 60000
+ },
+ {
+ "name" : "sourcedate",
+ "type" : "esriFieldTypeDouble",
+ "alias" : "sourcedate"
+ },
+ {
+ "name" : "st_grade_1",
+ "type" : "esriFieldTypeString",
+ "alias" : "st_grade_1",
+ "length" : 60000
+ },
+ {
+ "name" : "alias",
+ "type" : "esriFieldTypeString",
+ "alias" : "alias",
+ "length" : 60000
+ },
+ {
+ "name" : "state",
+ "type" : "esriFieldTypeString",
+ "alias" : "state",
+ "length" : 60000
+ },
+ {
+ "name" : "id",
+ "type" : "esriFieldTypeString",
+ "alias" : "id",
+ "length" : 60000
+ },
+ {
+ "name" : "helipad",
+ "type" : "esriFieldTypeString",
+ "alias" : "helipad",
+ "length" : 60000
+ },
+ {
+ "name" : "build_type",
+ "type" : "esriFieldTypeString",
+ "alias" : "build_type",
+ "length" : 60000
+ },
+ {
+ "name" : "end_grade",
+ "type" : "esriFieldTypeString",
+ "alias" : "end_grade",
+ "length" : 60000
+ },
+ {
+ "name" : "longitude",
+ "type" : "esriFieldTypeDouble",
+ "alias" : "longitude"
+ },
+ {
+ "name" : "zip",
+ "type" : "esriFieldTypeString",
+ "alias" : "zip",
+ "length" : 60000
+ },
+ {
+ "name" : "trauma",
+ "type" : "esriFieldTypeString",
+ "alias" : "trauma",
+ "length" : 60000
+ },
+ {
+ "name" : "naics_desc",
+ "type" : "esriFieldTypeString",
+ "alias" : "naics_desc",
+ "length" : 60000
+ },
+ {
+ "name" : "website",
+ "type" : "esriFieldTypeString",
+ "alias" : "website",
+ "length" : 60000
+ },
+ {
+ "name" : "address",
+ "type" : "esriFieldTypeString",
+ "alias" : "address",
+ "length" : 60000
+ },
+ {
+ "name" : "naicscode",
+ "type" : "esriFieldTypeString",
+ "alias" : "naicscode",
+ "length" : 60000
+ },
+ {
+ "name" : "telephone",
+ "type" : "esriFieldTypeString",
+ "alias" : "telephone",
+ "length" : 60000
+ },
+ {
+ "name" : "addressbui",
+ "type" : "esriFieldTypeString",
+ "alias" : "addressbui",
+ "length" : 60000
+ },
+ {
+ "name" : "tot_emp",
+ "type" : "esriFieldTypeDouble",
+ "alias" : "tot_emp"
+ },
+ {
+ "name" : "population",
+ "type" : "esriFieldTypeDouble",
+ "alias" : "population"
+ },
+ {
+ "name" : "enrollment",
+ "type" : "esriFieldTypeDouble",
+ "alias" : "enrollment"
+ },
+ {
+ "name" : "val_date",
+ "type" : "esriFieldTypeDouble",
+ "alias" : "val_date"
+ },
+ {
+ "name" : "zipcode",
+ "type" : "esriFieldTypeString",
+ "alias" : "zipcode",
+ "length" : 60000
+ },
+ {
+ "name" : "alt_name",
+ "type" : "esriFieldTypeString",
+ "alias" : "alt_name",
+ "length" : 60000
+ },
+ {
+ "name" : "naicsdescr",
+ "type" : "esriFieldTypeString",
+ "alias" : "naicsdescr",
+ "length" : 60000
+ },
+ {
+ "name" : "ft_teacher",
+ "type" : "esriFieldTypeDouble",
+ "alias" : "ft_teacher"
+ },
+ {
+ "name" : "name",
+ "type" : "esriFieldTypeString",
+ "alias" : "name",
+ "length" : 60000
+ },
+ {
+ "name" : "beds",
+ "type" : "esriFieldTypeDouble",
+ "alias" : "beds"
+ },
+ {
+ "name" : "objectid",
+ "type" : "esriFieldTypeDouble",
+ "alias" : "objectid"
+ },
+ {
+ "name" : "status",
+ "type" : "esriFieldTypeString",
+ "alias" : "status",
+ "length" : 60000
+ },
+ {
+ "name" : "geometry",
+ "type" : "esriFieldTypeGeometry",
+ "alias" : "geometry",
+ "geometryDef" : {
+ "avgNumPoints" : 0,
+ "geometryType" : "esriGeometryPoint",
+ "hasM" : false,
+ "hasZ" : false,
+ "spatialReference" : {
+ "wkid" : 102100,
+ "latestWkid" : 3857
+ }
+ }
+ },
+ {
+ "name" : "oid",
+ "type" : "esriFieldTypeInteger",
+ "alias" : "oid"
+ }
+ ],
+ "spatialStorageType" : 8
+ },
+ "studyAreaSpatialRel" : "esriSpatialRelUndefined",
+ "searchOrder" : "esriSearchOrderSpatial"
+ },
+ "htmlPopupEnabled" : true,
+ "selectable" : true,
+ "featureCacheType" : "Session",
+ "displayFiltersType" : "ByScale",
+ "featureBlendingMode" : "Alpha",
+ "labelClasses" : [
+ {
+ "type" : "CIMLabelClass",
+ "expressionTitle" : "Custom",
+ "expression" : "$feature.NAME",
+ "expressionEngine" : "Arcade",
+ "featuresToLabel" : "AllVisibleFeatures",
+ "maplexLabelPlacementProperties" : {
+ "type" : "CIMMaplexLabelPlacementProperties",
+ "featureType" : "Point",
+ "avoidPolygonHoles" : true,
+ "canOverrunFeature" : true,
+ "canPlaceLabelOutsidePolygon" : true,
+ "canRemoveOverlappingLabel" : true,
+ "canStackLabel" : true,
+ "connectionType" : "Unambiguous",
+ "constrainOffset" : "NoConstraint",
+ "contourAlignmentType" : "Page",
+ "contourLadderType" : "Straight",
+ "contourMaximumAngle" : 90,
+ "enableConnection" : true,
+ "enablePointPlacementPriorities" : true,
+ "featureWeight" : 0,
+ "fontHeightReductionLimit" : 4,
+ "fontHeightReductionStep" : 0.5,
+ "fontWidthReductionLimit" : 90,
+ "fontWidthReductionStep" : 5,
+ "graticuleAlignmentType" : "Straight",
+ "keyNumberGroupName" : "Default",
+ "labelBuffer" : 15,
+ "labelLargestPolygon" : true,
+ "labelPriority" : -1,
+ "labelStackingProperties" : {
+ "type" : "CIMMaplexLabelStackingProperties",
+ "stackAlignment" : "ChooseBest",
+ "maximumNumberOfLines" : 3,
+ "minimumNumberOfCharsPerLine" : 3,
+ "maximumNumberOfCharsPerLine" : 24,
+ "separators" : [
+ {
+ "type" : "CIMMaplexStackingSeparator",
+ "separator" : " ",
+ "splitAfter" : true
+ },
+ {
+ "type" : "CIMMaplexStackingSeparator",
+ "separator" : ",",
+ "visible" : true,
+ "splitAfter" : true
+ }
+ ]
+ },
+ "lineFeatureType" : "General",
+ "linePlacementMethod" : "OffsetCurvedFromLine",
+ "maximumLabelOverrun" : 36,
+ "maximumLabelOverrunUnit" : "Point",
+ "minimumFeatureSizeUnit" : "Map",
+ "multiPartOption" : "OneLabelPerPart",
+ "offsetAlongLineProperties" : {
+ "type" : "CIMMaplexOffsetAlongLineProperties",
+ "placementMethod" : "BestPositionAlongLine",
+ "labelAnchorPoint" : "CenterOfLabel",
+ "distanceUnit" : "Percentage",
+ "useLineDirection" : true
+ },
+ "pointExternalZonePriorities" : {
+ "type" : "CIMMaplexExternalZonePriorities",
+ "aboveLeft" : 4,
+ "aboveCenter" : 2,
+ "aboveRight" : 1,
+ "centerRight" : 3,
+ "belowRight" : 5,
+ "belowCenter" : 7,
+ "belowLeft" : 8,
+ "centerLeft" : 6
+ },
+ "pointPlacementMethod" : "AroundPoint",
+ "polygonAnchorPointType" : "GeometricCenter",
+ "polygonBoundaryWeight" : 0,
+ "polygonExternalZones" : {
+ "type" : "CIMMaplexExternalZonePriorities",
+ "aboveLeft" : 4,
+ "aboveCenter" : 2,
+ "aboveRight" : 1,
+ "centerRight" : 3,
+ "belowRight" : 5,
+ "belowCenter" : 7,
+ "belowLeft" : 8,
+ "centerLeft" : 6
+ },
+ "polygonFeatureType" : "General",
+ "polygonInternalZones" : {
+ "type" : "CIMMaplexInternalZonePriorities",
+ "center" : 1
+ },
+ "polygonPlacementMethod" : "CurvedInPolygon",
+ "primaryOffset" : 1,
+ "primaryOffsetUnit" : "Point",
+ "removeExtraWhiteSpace" : true,
+ "repetitionIntervalUnit" : "Point",
+ "rotationProperties" : {
+ "type" : "CIMMaplexRotationProperties",
+ "rotationType" : "Arithmetic",
+ "alignmentType" : "Straight"
+ },
+ "secondaryOffset" : 100,
+ "strategyPriorities" : {
+ "type" : "CIMMaplexStrategyPriorities",
+ "stacking" : 1,
+ "overrun" : 2,
+ "fontCompression" : 3,
+ "fontReduction" : 4,
+ "abbreviation" : 5
+ },
+ "thinningDistanceUnit" : "Point",
+ "truncationMarkerCharacter" : ".",
+ "truncationMinimumLength" : 1,
+ "truncationPreferredCharacters" : "aeiou",
+ "truncationExcludedCharacters" : "0123456789",
+ "polygonAnchorPointPerimeterInsetUnit" : "Point"
+ },
+ "name" : "Class 1",
+ "priority" : -1,
+ "standardLabelPlacementProperties" : {
+ "type" : "CIMStandardLabelPlacementProperties",
+ "featureType" : "Line",
+ "featureWeight" : "None",
+ "labelWeight" : "High",
+ "numLabelsOption" : "OneLabelPerName",
+ "lineLabelPosition" : {
+ "type" : "CIMStandardLineLabelPosition",
+ "above" : true,
+ "inLine" : true,
+ "parallel" : true
+ },
+ "lineLabelPriorities" : {
+ "type" : "CIMStandardLineLabelPriorities",
+ "aboveStart" : 3,
+ "aboveAlong" : 3,
+ "aboveEnd" : 3,
+ "centerStart" : 3,
+ "centerAlong" : 3,
+ "centerEnd" : 3,
+ "belowStart" : 3,
+ "belowAlong" : 3,
+ "belowEnd" : 3
+ },
+ "pointPlacementMethod" : "AroundPoint",
+ "pointPlacementPriorities" : {
+ "type" : "CIMStandardPointPlacementPriorities",
+ "aboveLeft" : 2,
+ "aboveCenter" : 2,
+ "aboveRight" : 1,
+ "centerLeft" : 3,
+ "centerRight" : 2,
+ "belowLeft" : 3,
+ "belowCenter" : 3,
+ "belowRight" : 2
+ },
+ "rotationType" : "Arithmetic",
+ "polygonPlacementMethod" : "AlwaysHorizontal"
+ },
+ "textSymbol" : {
+ "type" : "CIMSymbolReference",
+ "symbol" : {
+ "type" : "CIMTextSymbol",
+ "blockProgression" : "TTB",
+ "depth3D" : 1,
+ "extrapolateBaselines" : true,
+ "fontEffects" : "Normal",
+ "fontEncoding" : "Unicode",
+ "fontFamilyName" : "Tahoma",
+ "fontStyleName" : "Regular",
+ "fontType" : "Unspecified",
+ "haloSize" : 1,
+ "height" : 10,
+ "hinting" : "Default",
+ "horizontalAlignment" : "Left",
+ "kerning" : true,
+ "letterWidth" : 100,
+ "ligatures" : true,
+ "lineGapType" : "ExtraLeading",
+ "symbol" : {
+ "type" : "CIMPolygonSymbol",
+ "symbolLayers" : [
+ {
+ "type" : "CIMSolidFill",
+ "enable" : true,
+ "color" : {
+ "type" : "CIMRGBColor",
+ "values" : [
+ 0,
+ 0,
+ 0,
+ 100
+ ]
+ }
+ }
+ ]
+ },
+ "textCase" : "Normal",
+ "textDirection" : "LTR",
+ "verticalAlignment" : "Bottom",
+ "verticalGlyphOrientation" : "Right",
+ "wordSpacing" : 100,
+ "billboardMode3D" : "FaceNearPlane"
+ }
+ },
+ "useCodedValue" : true,
+ "visibility" : true,
+ "iD" : -1
+ }
+ ],
+ "renderer" : {
+ "type" : "CIMUniqueValueRenderer",
+ "defaultSymbolPatch" : "Default",
+ "fields" : [
+ "build_type"
+ ],
+ "groups" : [
+ {
+ "type" : "CIMUniqueValueGroup",
+ "classes" : [
+ {
+ "type" : "CIMUniqueValueClass",
+ "label" : "Colleges",
+ "patch" : "Default",
+ "symbol" : {
+ "type" : "CIMSymbolReference",
+ "symbol" : {
+ "type" : "CIMPointSymbol",
+ "symbolLayers" : [
+ {
+ "type" : "CIMPictureMarker",
+ "enable" : true,
+ "anchorPointUnits" : "Relative",
+ "dominantSizeAxis3D" : "Z",
+ "size" : 18,
+ "billboardMode3D" : "FaceNearPlane",
+ "invertBackfaceTexture" : true,
+ "scaleX" : 1,
+ "textureFilter" : "Picture",
+ "url" : ""
+ }
+ ],
+ "haloSize" : 1,
+ "scaleX" : 1,
+ "angleAlignment" : "Display"
+ }
+ },
+ "values" : [
+ {
+ "type" : "CIMUniqueValue",
+ "fieldValues" : [
+ "COLLEGES"
+ ]
+ }
+ ],
+ "visible" : true
+ },
+ {
+ "type" : "CIMUniqueValueClass",
+ "label" : "Fire/EMS",
+ "patch" : "Default",
+ "symbol" : {
+ "type" : "CIMSymbolReference",
+ "symbol" : {
+ "type" : "CIMPointSymbol",
+ "symbolLayers" : [
+ {
+ "type" : "CIMPictureMarker",
+ "enable" : true,
+ "anchorPointUnits" : "Relative",
+ "dominantSizeAxis3D" : "Z",
+ "size" : 18,
+ "billboardMode3D" : "FaceNearPlane",
+ "invertBackfaceTexture" : true,
+ "scaleX" : 1,
+ "textureFilter" : "Picture",
+ "url" : ""
+ }
+ ],
+ "haloSize" : 1,
+ "scaleX" : 1,
+ "angleAlignment" : "Display"
+ }
+ },
+ "values" : [
+ {
+ "type" : "CIMUniqueValue",
+ "fieldValues" : [
+ "FIRE/EMS"
+ ]
+ }
+ ],
+ "visible" : true
+ },
+ {
+ "type" : "CIMUniqueValueClass",
+ "label" : "Hospitals",
+ "patch" : "Default",
+ "symbol" : {
+ "type" : "CIMSymbolReference",
+ "symbol" : {
+ "type" : "CIMPointSymbol",
+ "symbolLayers" : [
+ {
+ "type" : "CIMPictureMarker",
+ "enable" : true,
+ "anchorPointUnits" : "Relative",
+ "dominantSizeAxis3D" : "Z",
+ "size" : 18,
+ "billboardMode3D" : "FaceNearPlane",
+ "invertBackfaceTexture" : true,
+ "scaleX" : 1,
+ "textureFilter" : "Picture",
+ "url" : ""
+ }
+ ],
+ "haloSize" : 1,
+ "scaleX" : 1,
+ "angleAlignment" : "Display"
+ }
+ },
+ "values" : [
+ {
+ "type" : "CIMUniqueValue",
+ "fieldValues" : [
+ "HOSPITALS"
+ ]
+ }
+ ],
+ "visible" : true
+ },
+ {
+ "type" : "CIMUniqueValueClass",
+ "label" : "Nursing Home",
+ "patch" : "Default",
+ "symbol" : {
+ "type" : "CIMSymbolReference",
+ "symbol" : {
+ "type" : "CIMPointSymbol",
+ "symbolLayers" : [
+ {
+ "type" : "CIMPictureMarker",
+ "enable" : true,
+ "anchorPointUnits" : "Relative",
+ "dominantSizeAxis3D" : "Z",
+ "size" : 18,
+ "billboardMode3D" : "FaceNearPlane",
+ "invertBackfaceTexture" : true,
+ "scaleX" : 1,
+ "textureFilter" : "Picture",
+ "url" : ""
+ }
+ ],
+ "haloSize" : 1,
+ "scaleX" : 1,
+ "angleAlignment" : "Display"
+ }
+ },
+ "values" : [
+ {
+ "type" : "CIMUniqueValue",
+ "fieldValues" : [
+ "NURSING HOME"
+ ]
+ }
+ ],
+ "visible" : true
+ },
+ {
+ "type" : "CIMUniqueValueClass",
+ "label" : "Police",
+ "patch" : "Default",
+ "symbol" : {
+ "type" : "CIMSymbolReference",
+ "symbol" : {
+ "type" : "CIMPointSymbol",
+ "symbolLayers" : [
+ {
+ "type" : "CIMPictureMarker",
+ "enable" : true,
+ "anchorPointUnits" : "Relative",
+ "dominantSizeAxis3D" : "Z",
+ "size" : 18,
+ "billboardMode3D" : "FaceNearPlane",
+ "invertBackfaceTexture" : true,
+ "scaleX" : 1,
+ "textureFilter" : "Picture",
+ "url" : ""
+ }
+ ],
+ "haloSize" : 1,
+ "scaleX" : 1,
+ "angleAlignment" : "Display"
+ }
+ },
+ "values" : [
+ {
+ "type" : "CIMUniqueValue",
+ "fieldValues" : [
+ "POLICE"
+ ]
+ }
+ ],
+ "visible" : true
+ },
+ {
+ "type" : "CIMUniqueValueClass",
+ "label" : "Schools",
+ "patch" : "Default",
+ "symbol" : {
+ "type" : "CIMSymbolReference",
+ "symbol" : {
+ "type" : "CIMPointSymbol",
+ "symbolLayers" : [
+ {
+ "type" : "CIMPictureMarker",
+ "enable" : true,
+ "anchorPointUnits" : "Relative",
+ "dominantSizeAxis3D" : "Z",
+ "size" : 18,
+ "billboardMode3D" : "FaceNearPlane",
+ "invertBackfaceTexture" : true,
+ "scaleX" : 1,
+ "textureFilter" : "Picture",
+ "url" : ""
+ }
+ ],
+ "haloSize" : 1,
+ "scaleX" : 1,
+ "angleAlignment" : "Display"
+ },
+ "symbolName" : "Level_1"
+ },
+ "values" : [
+ {
+ "type" : "CIMUniqueValue",
+ "fieldValues" : [
+ "SCHOOLS"
+ ]
+ }
+ ],
+ "visible" : true
+ }
+ ]
+ }
+ ],
+ "polygonSymbolColorTarget" : "Fill"
+ },
+ "scaleSymbols" : true,
+ "snappable" : true
+ }
+ ]
+}
\ No newline at end of file
diff --git a/Core/LAMBDA/viz_functions/viz_publish_service/services/reference/static_public_critical_infrastructure_points.yml b/Core/LAMBDA/viz_functions/viz_publish_service/services/reference/static_public_critical_infrastructure_points.yml
new file mode 100644
index 00000000..9dcd9d3a
--- /dev/null
+++ b/Core/LAMBDA/viz_functions/viz_publish_service/services/reference/static_public_critical_infrastructure_points.yml
@@ -0,0 +1,9 @@
+service: static_public_critical_infrastructure_points
+summary: Critical infrastructure as points
+description: Depicts the locations of colleges, fire stations, hospitals, nursing homes, police stations, and schools throughout the United States and its territories
+tags: national water model, nwm, reference
+credits: NOAA/NWS National Water Center
+egis_server: server
+egis_folder: reference
+feature_service: true
+public_service: false
\ No newline at end of file
diff --git a/Core/Manual_Workflows/static_services/Critical_Infrastructure_Service.ipynb b/Core/Manual_Workflows/static_services/Critical_Infrastructure_Service.ipynb
new file mode 100644
index 00000000..84de89b6
--- /dev/null
+++ b/Core/Manual_Workflows/static_services/Critical_Infrastructure_Service.ipynb
@@ -0,0 +1,268 @@
+{
+ "cells": [
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## This script ingests the Critical Infrastructure Service into the HydroVIS EGIS Database. ##"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "Importing necessary modules and helper functions"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 1,
+ "metadata": {},
+ "outputs": [
+ {
+ "data": {
+ "text/html": [
+ ""
+ ],
+ "text/plain": [
+ ""
+ ]
+ },
+ "metadata": {},
+ "output_type": "display_data"
+ }
+ ],
+ "source": [
+ "import requests\n",
+ "import geopandas as gdp\n",
+ "import sys\n",
+ "import os\n",
+ "from shapely.geometry import shape\n",
+ "from arcgis.gis import GIS\n",
+ "\n",
+ "#Adding parent folder to the Python path to grab helper functions.\n",
+ "sys.path.append(os.path.dirname(os.path.abspath('')))\n",
+ "\n",
+ "#Importing necessary helper functions.\n",
+ "from helper_functions.shared_functions import get_db_engine, move_data_from_viz_to_egis"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "The Critical Infrastructure point layer is hosted as a feature service for storage and accessibility purposes. To retreive it within this script, you'll have to login to your TI ArcGIS Online account. You must setup environment variables \"EKS_EGIS_TI_USERNAME\" and \"EKS_EGIS_TI_PASSWORD\" in the windows environment variables. Once done, you'll need to close/reopen your IDE for it to successfully find your environment variables. \n",
+ "\n",
+ "This data is from https://services2.arcgis.com/C8EMgrsFcRFL6LrL/arcgis/rest/services/All_Infrastructure_Merge/FeatureServer/0. This data can still be accessed by logging in to https://noaa.maps.arcgis.com/home/ and finding the \"All_Infrastructure_Merge\" feature service. This data is derived from FEMA infrastructure datasaets. \n",
+ "\n",
+ "To get an editable copy of this data, the services2.arcgis.com link was used to connect to a new server in ArcGIS Pro. Feature service -> feature service in the geoprocessing toolbox was used to save it as a new local geodatabase. Then, for future accessbility, the data was published as a feature service within the EKS EGIS TI portal with organization wide access. This feature service is then connected to below for ingestion to the egis database."
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "#Defining constants\n",
+ "FEATURE_SERVICE_URL = \"https://eks-maps-testing.water.noaa.gov/server/rest/services/Hosted/static_public_critical_infrastructure_points_fema/FeatureServer/0/\"\n",
+ "DB_TABLE_NAME = \"static_public_critical_infrastructure_points_fema\"\n",
+ "\n",
+ "#User Crednetials for the TI portal that contains the servce.\n",
+ "#You must setup environment variables EKS_EGIS_TI_USERNAME and EKS_EGIS_TI_PASSWORD\n",
+ "username = os.getenv(\"EKS_EGIS_TI_USERNAME\")\n",
+ "password = os.getenv(\"EKS_EGIS_TI_PASSWORD\")\n",
+ "\n",
+ "if not username or not password:\n",
+ " raise EnvironmentError(\"Environment variables EKS_EGIS_TI_USERNAME and/or EKS_EGIS_TI_PASSWORD are not set.\")\n",
+ "\n",
+ "#Logging into the testing ArcGIS Portal\n",
+ "print(\"Attempting to login...\")\n",
+ "gis = GIS(url=\"https://eks-maps-testing.water.noaa.gov/server/\", username=username, password=password, verify_cert=False)\n",
+ "\n",
+ "if gis is None or gis.users.me is None:\n",
+ " print(\"Login failed.\")\n",
+ "else:\n",
+ " print(\"Succesfully logged in as \" + str(gis.properties.user.username))\n",
+ "\n",
+ "#Retrieving the token\n",
+ "token = gis.session.auth.token"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "This section fetches the data from the ArcGIS Server. The arcgis API restricts the number of rows that can be fetched to 2000. To get around this, we implement pagination with a while loop to keep grabbing a maximum of 2000 rows until we have all of the data. It should take no more than a couple of minutes to grab the data and store the features in an array variable called all_features. You'll run this section once, inspect the printed statement to ensure you're getting all of the data, then run the next functions."
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 4,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "def fetch_feature_service_data(feature_service_url):\n",
+ " #Pagination variables to deal with ArcGIS Feature Service row limit of 2000\n",
+ " max_record_count = 2000 #Row request limit\n",
+ " offset = 0\n",
+ " all_features = []\n",
+ "\n",
+ " while True:\n",
+ " #Fetches data from the ArcGIS Server and prints some of the resulting GeoJSON for testing\n",
+ " query_url = f\"{feature_service_url}/query?where=1%3D1&outFields=*&outSR=3857&f=geojson&token={token}&resultOffset={offset}&resultRecordCount={max_record_count}\"\n",
+ "\n",
+ " #Request the data\n",
+ " response = requests.get(query_url)\n",
+ " response.raise_for_status() # Raise an error if the request fails\n",
+ "\n",
+ " #Parse it as a GeoJSON\n",
+ " geojson = response.json()\n",
+ " \n",
+ " #Creating shapely geometries\n",
+ " features = geojson.get('features', [])\n",
+ " if not features:\n",
+ " print(\"No more features found.\")\n",
+ " break\n",
+ " \n",
+ " #Append fetched feature to list\n",
+ " all_features.extend(features)\n",
+ " print(f\"Fetched {len(features)} features. Total so far: {len(all_features)}\")\n",
+ "\n",
+ " #Increment offset for next query\n",
+ " offset += max_record_count\n",
+ " \n",
+ " print(f\"Total features fetched: {len(all_features)}\") \n",
+ " return all_features"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "This function takes the all_features array the previous function returns, and stores it in a GeoDataFrame that it returns as df. It also creates the necessary oid field that's used in the VPP. "
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 1,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "def create_dataframe_from_features(features):\n",
+ " attributes = [f['properties'] for f in features]\n",
+ " geom = [shape(f['geometry']) for f in features]\n",
+ "\n",
+ " #Create GeoDataFrame\n",
+ " df = gdp.GeoDataFrame(attributes, geometry = geom, crs = 'EPSG:3857')\n",
+ "\n",
+ " #Add oid column\n",
+ " df = df.copy()\n",
+ " if \"ObjectID\" in df.columns:\n",
+ " print(\"ObjectID column found. Copying to the new oid column.\")\n",
+ " df[\"oid\"] = df[\"ObjectID\"].astype(int)\n",
+ " else:\n",
+ " print(\"No ObjectID column found. Making it from scratch.\")\n",
+ " df[\"oid\"] = range(1, len(df) +1)\n",
+ "\n",
+ " #Print to see final GeoDataFrame before exporting to PostGIS\n",
+ " print(\"\\nSample of the GeoDataFrame with the added 'oid' column:\")\n",
+ " print(df.head(5).to_string(index=False))\n",
+ "\n",
+ " #Print the column names\n",
+ " print(\"\\nColumns in the GeoDataFrame\")\n",
+ " print(df.columns.to_list())\n",
+ "\n",
+ " #Print the number of rows in the dataframe\n",
+ " print(\"\\nNumber of rows in datraframe: \")\n",
+ " print(len(df))\n",
+ "\n",
+ " return df"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "Now we're ready to execute the fetch_feature_service_data function."
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "#Fetch the data\n",
+ "print(f\"Fetching data from: {FEATURE_SERVICE_URL}\")\n",
+ "features = fetch_feature_service_data(FEATURE_SERVICE_URL)"
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "#Create GeoDataFrame from the downloaded features\n",
+ "df = create_dataframe_from_features(features)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "In this section we actually save the data to our postgis database. You'll need to setup your environment variables with the host address, username and password for the viz and egis database. These can be found in the RDS and Secrets Manager tools within the AWS TI platform.\n",
+ "\n",
+ "When writing to the viz database, the 'if_exists' clause is set to 'replace' by default. Use caution, as this will overwrite the table. If you have updated the reference feature service and want to add new rows to the table, set if_exists = 'append'. If you are running this and want to be sure the table exists, set if_exists = 'fail' which will stop the script from altering the current table. "
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": 11,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "#Save to DB\n",
+ "df.to_postgis(\"static_public_critical_infrastructure_points_fema\", get_db_engine('viz'), schema='dev', if_exists='replace')"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "After checking the viz database for any issues and reviewing the data in ArcGIS Pro, we can migrate the table from the viz database to the egis database."
+ ]
+ },
+ {
+ "cell_type": "code",
+ "execution_count": null,
+ "metadata": {},
+ "outputs": [],
+ "source": [
+ "move_data_from_viz_to_egis('dev.static_public_critical_infrastructure_points_fema', 'reference.static_public_critical_infrastructure_points_fema')"
+ ]
+ }
+ ],
+ "metadata": {
+ "kernelspec": {
+ "display_name": "base",
+ "language": "python",
+ "name": "python3"
+ },
+ "language_info": {
+ "codemirror_mode": {
+ "name": "ipython",
+ "version": 3
+ },
+ "file_extension": ".py",
+ "mimetype": "text/x-python",
+ "name": "python",
+ "nbconvert_exporter": "python",
+ "pygments_lexer": "ipython3",
+ "version": "3.12.7"
+ }
+ },
+ "nbformat": 4,
+ "nbformat_minor": 2
+}