X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=js%2Fautocomplete_chart.js;h=557b94557edf72848a7f450e215ffb7a09db0df6;hb=561d4521aa9148dc3523f297afdfea53b263b48d;hp=d5763a4e5e0195cde76e3f32a01d6252137842db;hpb=4f152ed21fb137de6d6f4d48ec28d67055bcf965;p=kivitendo-erp.git diff --git a/js/autocomplete_chart.js b/js/autocomplete_chart.js index d5763a4e5..557b94557 100644 --- a/js/autocomplete_chart.js +++ b/js/autocomplete_chart.js @@ -164,6 +164,27 @@ namespace('kivi', function(k){ $('#chart_selection').dialog('close'); }; + function handle_changed_text(callbacks) { + $.ajax({ + url: 'controller.pl?action=Chart/ajax_autocomplete', + dataType: "json", + data: $.extend( ajax_data($dummy.val()), { prefer_exact: 1 } ), + success: function (data) { + if (data.length == 1) { + set_item(data[0]); + if (callbacks && callbacks.match_one) callbacks.match_one(data[0]); + } else if (data.length > 1) { + state = STATES.UNDEFINED; + if (callbacks && callbacks.match_many) callbacks.match_many(data); + } else { + state = STATES.UNDEFINED; + if (callbacks &&callbacks.match_none) callbacks.match_none(); + } + annotate_state(); + } + }); + }; + $dummy.autocomplete({ source: function(req, rsp) { $.ajax($.extend(o, { @@ -199,31 +220,28 @@ namespace('kivi', function(k){ } else if (state == STATES.PICKED) { return true; } - if (event.which == KEY.TAB) event.preventDefault(); - $.ajax({ - url: 'controller.pl?action=Chart/ajax_autocomplete', - dataType: "json", - data: $.extend( ajax_data($dummy.val()), { prefer_exact: 1 } ), - success: function (data) { - if (data.length == 1) { - set_item(data[0]); - if (event.which == KEY.ENTER) - $('#update_button').click(); - } else if (data.length > 1) { - if (event.which == KEY.ENTER) - open_dialog(); - } else { - } - annotate_state(); - } - }); - if (event.which == KEY.ENTER) + if (event.which == KEY.TAB) { + event.preventDefault(); + handle_changed_text(); + } + if (event.which == KEY.ENTER) { + handle_changed_text({ + match_one: function(){$('#update_button').click();}, + match_many: function(){open_dialog();} + }); return false; + } } else { state = STATES.UNDEFINED; } }); + $dummy.on('paste', function(){ + setTimeout(function() { + handle_changed_text(); + }, 1); + }); + $dummy.blur(function(){ window.clearTimeout(timer); timer = window.setTimeout(annotate_state, 100); @@ -234,7 +252,7 @@ namespace('kivi', function(k){ var picker = $('
'); $dummy.after(pcont); pcont.append(picker); - picker.addClass('icon16 crm--search').click(open_dialog); + picker.addClass('icon16 search').click(open_dialog); var cp = { real: function() { return $real },