From 979d7b40f5e9390c916d36c00aa4bc1ab5852980 Mon Sep 17 00:00:00 2001 From: Remco Date: Mon, 6 Nov 2023 14:50:22 +0100 Subject: [PATCH 1/2] feat: optimize api fetches --- src/lib/load-breach.js | 35 ++++++++++++++++++++++------------- src/map.config.js | 12 +++++------- 2 files changed, 27 insertions(+), 20 deletions(-) diff --git a/src/lib/load-breach.js b/src/lib/load-breach.js index d0528b85..3bd3427d 100644 --- a/src/lib/load-breach.js +++ b/src/lib/load-breach.js @@ -146,13 +146,30 @@ export async function getScenarioInfo (scenarioIds, featureInfoByScenarioId) { return data } +let filterVariantsPromise = null; + +async function loadFilterVariants() { + if(!filterVariantsPromise) { + const services = await mapConfig.getServices() + const FILTERS_BASE_URL = services.WEBSERVICE_URL_V2 + const FILTERS_API_URL = `${FILTERS_BASE_URL}/filter_variants` + + filterVariantsPromise = fetch(FILTERS_API_URL, { + method: 'GET', + mode: 'cors', + credentials: 'omit', + headers + }).then(res => res.json()) + } + + return filterVariantsPromise +} + async function loadBreachLayer (breachId, layerName) { // Load the dataset for a breach const services = await mapConfig.getServices() const BREACHES_BASE_URL = services.WEBSERVICE_URL - const FILTERS_BASE_URL = services.WEBSERVICE_URL_V2 const BREACHES_API_URL = `${BREACHES_BASE_URL}/Tools/FloodImage.asmx/GetScenariosPerBreachGeneric` - const FILTERS_API_URL = `${FILTERS_BASE_URL}/filter_variants` const breachFetch = await fetch(BREACHES_API_URL, { method: 'POST', @@ -163,17 +180,9 @@ async function loadBreachLayer (breachId, layerName) { breachid: breachId, layername: layerName }) - }) - - const filterFetch = await fetch(FILTERS_API_URL, { - method: 'GET', - mode: 'cors', - credentials: 'omit', - headers - }) + }).then(res => res.json()) - const [breachData, filtersData] = await Promise.all([breachFetch, filterFetch]) - .then(responses => responses.map(response => response.json())) + const [breachData, filtersData] = await Promise.all([breachFetch, loadFilterVariants()]) const properties = await filtersData @@ -181,7 +190,7 @@ async function loadBreachLayer (breachId, layerName) { store.commit('setVariantFilterProperties', { properties, breachId }) } - const data = await breachData.then(data => JSON.parse(data.d)) + const data = JSON.parse(breachData.d) // get the first layerset if available, otherwise return null let result = null diff --git a/src/map.config.js b/src/map.config.js index a363243d..7dac4da4 100644 --- a/src/map.config.js +++ b/src/map.config.js @@ -85,13 +85,13 @@ const tileLayers = [ }, ]; -var services = null; +var servicePromise = null; async function getServices() { // return the content of webconfig.json // return if we already fetched it (memoize0 - if (services) { - return services; + if (servicePromise) { + return servicePromise; } let url = 'config/webconfig.json' @@ -99,10 +99,8 @@ async function getServices() { url = 'config/webconfig-netlify.json' } - const resp = await fetch(url); - const result = await resp.json(); - services = result; - return result; + servicePromise = fetch(url).then(res => res.json()); + return servicePromise; } export default { From 2c91cb59702963292910e738f170d8f84276d064 Mon Sep 17 00:00:00 2001 From: Remco Date: Mon, 6 Nov 2023 14:52:20 +0100 Subject: [PATCH 2/2] feat: optimize api fetches --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 8fe9d4a1..1130650d 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "liwo-static", - "version": "3.1.0", + "version": "3.2.1", "private": true, "scripts": { "serve": "vite",