From 87694e660c188ff08e85cbe9d1f850780491bc82 Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Fri, 16 Jul 2021 12:03:29 +0200 Subject: [PATCH] seems to be no need to send a synchronous request --- api/js/etemplate/et2_widget_selectbox.ts | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/api/js/etemplate/et2_widget_selectbox.ts b/api/js/etemplate/et2_widget_selectbox.ts index 666d329aaf..d64f5df037 100644 --- a/api/js/etemplate/et2_widget_selectbox.ts +++ b/api/js/etemplate/et2_widget_selectbox.ts @@ -1496,33 +1496,33 @@ export class et2_selectbox extends et2_inputWidget // Fetch with json instead of jsonq because there may be more than // one widget listening for the response by the time it gets back, // and we can't do that when it's queued. - var req = egw.json( + const req = egw.json( 'EGroupware\\Api\\Etemplate\\Widget\\Select::ajax_get_options', [widget._type,options_string,attrs.value] - ).sendRequest(!in_nextmatch); + ).sendRequest(); // was !in_nextmatch to send synchronous request if(typeof cache === 'undefined') { cache_owner[cache_id] = req; } cache = req; } - if(typeof cache.done == 'function') + if (typeof cache.then === 'function') { // pending, wait for it - cache.done(jQuery.proxy(function(response) { + cache.then((response) => { cache = cache_owner[cache_id] = response.response[0].data||undefined; // Set select_options in attributes in case we get a resonse before // the widget is finished loading (otherwise it will re-set to {}) attrs.select_options = cache; - egw.window.setTimeout(jQuery.proxy(function() { + egw.window.setTimeout(() => { // Avoid errors if widget is destroyed before the timeout - if(this.widget && typeof this.widget.id !== 'undefined') + if (widget && typeof widget.id !== 'undefined') { - this.widget.set_select_options(et2_selectbox.find_select_options(this.widget,{}, this.widget.options)); + widget.set_select_options(et2_selectbox.find_select_options(widget,{}, widget.options)); } - },this),1); - },{widget:widget,cache_id:cache_id})); + }, 1); + }); return []; } else