X-Git-Url: https://git.openstreetmap.org./nominatim-ui.git/blobdiff_plain/c9687b102bb6f544a034dc4d508bf0ae4a5fc221..f9d0561c8e1bc5a8dad423545e32737c4e24ef9c:/src/lib/api_utils.js diff --git a/src/lib/api_utils.js b/src/lib/api_utils.js index 9939b61..0317e13 100644 --- a/src/lib/api_utils.js +++ b/src/lib/api_utils.js @@ -1,37 +1,34 @@ import { get_config_value } from './config_reader.js'; -import { last_updated_store } from './stores.js'; +import { last_api_request_url_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'; +} export async function fetch_from_api(endpoint_name, params, callback) { var api_url = generate_nominatim_api_url(endpoint_name, params); - document.getElementById('loading').style.display = 'block'; + api_request_progress('start'); + await fetch(api_url) .then(response => response.json()) .then(data => { callback(data); - document.getElementById('loading').style.display = 'none'; + api_request_progress('finish'); }); - - fetch(generate_nominatim_api_url('status', {format: 'json'})) - .then(response => response.json()) - .then(data => { - let last_updated = { - api_request_url: api_url, - api_request_url_debug: api_url + '&debug=1', - date: data.data_updated - }; - last_updated_store.set(last_updated) - }); + if (endpoint_name !== 'status') last_api_request_url_store.set(api_url); } function generate_nominatim_api_url(endpoint_name, params) { return get_config_value('Nominatim_API_Endpoint') + endpoint_name + '.php?' - + Object.keys(clean_up_parameters(params)).map( (k) => { - return encodeURIComponent(k) + '=' + encodeURIComponent(params[k]) + + Object.keys(clean_up_parameters(params)).map((k) => { + return encodeURIComponent(k) + '=' + encodeURIComponent(params[k]); }).join('&'); } @@ -44,7 +41,7 @@ function generate_nominatim_api_url(endpoint_name, params) { export function serialize_form(form) { var arr = []; Array.prototype.slice.call(form.elements).forEach(function (field) { - if (!field.name || field.disabled || ['file', 'reset', 'submit', 'button'].indexOf(field.type) > -1) return; + if (!field.name || field.disabled || ['submit', 'button'].indexOf(field.type) > -1) return; // if (field.type === 'select-multiple') { // Array.prototype.slice.call(field.options).forEach(function (option) { // if (!option.selected) return; @@ -52,12 +49,12 @@ export function serialize_form(form) { // }); // return; // } - if (['checkbox', 'radio'].indexOf(field.type) >-1 && !field.checked) return; - if (typeof(field.value) === 'undefined') return; + if (['checkbox', 'radio'].indexOf(field.type) > -1 && !field.checked) return; + if (typeof field.value === 'undefined') return; arr.push(encodeURIComponent(field.name) + '=' + encodeURIComponent(field.value)); }); return arr.join('&'); -}; +} // remove any URL paramters with empty values @@ -88,7 +85,7 @@ function clean_up_parameters(params) { export function update_html_title(title) { document.title = [title, 'OpenStreetMap Nominatim'] - .filter( (val) => val && val.length > 1 ) - .join(' | '); + .filter((val) => val && val.length > 1) + .join(' | '); }