From 9a11ccbcceae22f300b2f1dc54555c7fcb2c4b3e Mon Sep 17 00:00:00 2001 From: Chris Hodgson Date: Thu, 30 May 2024 17:28:06 -0700 Subject: [PATCH] added support for message-based passing of test result data --- ols-demo/index.html | 75 ++++++++++++++++++++++++--------------------- 1 file changed, 40 insertions(+), 35 deletions(-) diff --git a/ols-demo/index.html b/ols-demo/index.html index 163deb2..8de87b5 100644 --- a/ols-demo/index.html +++ b/ols-demo/index.html @@ -1685,7 +1685,7 @@

Examples:

overlays["Internal Segment Ids"] = segIdLayer; if(queryParams.get('test_results')) { - addTestResults(queryParams.get('test_results')); + getAndAddTestResults(queryParams.get('test_results')); } var layerControl = L.control.layers(baseLayers, overlays).addTo(map); @@ -2301,45 +2301,50 @@

Examples:

}); } + // receives test result data through iframe from testing app + window.addEventListener("message", (event) => { + if(event.data.features) + addTestResults(event.data); + }); + function addTestResults(data) { + var testResultsLayer = L.geoJSON(data.features, { + style: getTestStyle, + pane: map.getPane('routePane') + }); + testResultsLayer.bindPopup(function(layer) { + return makeTestResultPopupText(layer.feature.properties); + }); + // add start and end markers, and partition markers + for(var i = 0; i < data.features.length; i++) { + var coords = data.features[i].geometry.coordinates + var startCoord = coords[0]; + var endCoord = coords[coords.length-1]; + if(Array.isArray(startCoord[0])) { + startCoord = startCoord[0]; + endCoord = endCoord[endCoord.length-1]; + } + testResultsLayer.addLayer(L.marker(L.GeoJSON.coordsToLatLng(startCoord), {icon: getRouteIcon(0)})); + testResultsLayer.addLayer(L.marker(L.GeoJSON.coordsToLatLng(endCoord), {icon: getRouteIcon(-1)})); + // add partition markers + var partition_indices = data.features[i].properties.partition_indices; + for(var j = 0; j < partition_indices.length; j++) { + var index = partition_indices[j]; + if(index != '') { + var coord = data.features[i].geometry.coordinates[index]; + testResultsLayer.addLayer(L.circleMarker(L.GeoJSON.coordsToLatLng(coord), {color: "red"})); + } + } + } + testResultsLayer.addTo(map); + centerMap(testResultsLayer.getBounds()); + } - - function addTestResults(url) { + function getAndAddTestResults(url) { $.ajax({ url: url, dataType: "json", - success: function(data) { - var testResultsLayer = L.geoJSON(data.features, { - style: getTestStyle, - pane: map.getPane('routePane') - }); - testResultsLayer.bindPopup(function(layer) { - return makeTestResultPopupText(layer.feature.properties); - }); - // add start and end markers, and partition markers - for(var i = 0; i < data.features.length; i++) { - var coords = data.features[i].geometry.coordinates - var startCoord = coords[0]; - var endCoord = coords[coords.length-1]; - if(Array.isArray(startCoord[0])) { - startCoord = startCoord[0]; - endCoord = endCoord[endCoord.length-1]; - } - testResultsLayer.addLayer(L.marker(L.GeoJSON.coordsToLatLng(startCoord), {icon: getRouteIcon(0)})); - testResultsLayer.addLayer(L.marker(L.GeoJSON.coordsToLatLng(endCoord), {icon: getRouteIcon(-1)})); - // add partition markers - var partition_indices = data.features[i].properties.partition_indices; - for(var j = 0; j < partition_indices.length; j++) { - var index = partition_indices[j]; - if(index != '') { - var coord = data.features[i].geometry.coordinates[index]; - testResultsLayer.addLayer(L.circleMarker(L.GeoJSON.coordsToLatLng(coord), {color: "red"})); - } - } - } - testResultsLayer.addTo(map); - centerMap(testResultsLayer.getBounds()); - } + success: addTestResults }); }