X-Git-Url: https://git.openstreetmap.org./nominatim-ui.git/blobdiff_plain/9e8d3367fe08a708b1019ff39ac752e0105be20a..8f12a2a62ec13d3df912d7ec8538fa19d5b4e067:/src/lib/api_utils.js diff --git a/src/lib/api_utils.js b/src/lib/api_utils.js index 70acda6..a44a30e 100644 --- a/src/lib/api_utils.js +++ b/src/lib/api_utils.js @@ -1,32 +1,53 @@ - -import { get_config_value } from './config_reader.js'; -import { last_api_request_url_store } from './stores.js'; - +import { last_api_request_url_store, error_store } from './stores.js'; function api_request_progress(status) { var loading_el = document.getElementById('loading'); if (!loading_el) return; // might not be on page yet - loading_el.style.display = (status === 'start') ? 'block' : 'none'; + loading_el.style.display = (status === 'start') ? 'block' : null; } export async function fetch_from_api(endpoint_name, params, callback) { var api_url = generate_nominatim_api_url(endpoint_name, params); api_request_progress('start'); + if (endpoint_name !== 'status') last_api_request_url_store.set(null); - await fetch(api_url) - .then(response => response.json()) - .then(data => { - callback(data); - api_request_progress('finish'); - }); + try { + await fetch(api_url) + .then(response => response.json()) + .then(data => { + if (data.error) { + error_store.set(data.error.message); + } + callback(data); + api_request_progress('finish'); + }); + } catch (error) { + error_store.set(`Error fetching data from ${api_url} (${error})`); + api_request_progress('finish'); + } if (endpoint_name !== 'status') last_api_request_url_store.set(api_url); } +var fetch_content_cache = {}; +export async function fetch_content_into_element(url, dom_element) { + if (fetch_content_cache[url]) { + dom_element.innerHTML = fetch_content_cache[url]; + return; + } + await fetch(url) + .then(response => response.text()) + .then(html => { + html = html.replace('Nominatim_API_Endpoint', Nominatim_Config.Nominatim_API_Endpoint); + dom_element.innerHTML = html; + fetch_content_cache[url] = html; + }); +} + function generate_nominatim_api_url(endpoint_name, params) { - return get_config_value('Nominatim_API_Endpoint') + endpoint_name + '.php?' + return Nominatim_Config.Nominatim_API_Endpoint + endpoint_name + '.php?' + Object.keys(clean_up_parameters(params)).map((k) => { return encodeURIComponent(k) + '=' + encodeURIComponent(params[k]); }).join('&'); @@ -46,7 +67,7 @@ function clean_up_parameters(params) { } export function update_html_title(title) { - document.title = [title, 'OpenStreetMap Nominatim'] + document.title = [title, Nominatim_Config.Page_Title] .filter((val) => val && val.length > 1) .join(' | '); }