Damit wird bei eindeutigem eingefügtem Text der entsprechende Artikel
ausgewählt. Ansonsten wird der Text rot (undefined) dargestellt.
Vorher war es möglich, z.B. eine eindeutige Artikelnummer einzufügen, aber
intern war dennoch kein Artikel ausgewählt. In der Anzeige sah es aber so aus,
als sei alles in Ordnung.
$('#part_selection').dialog('close');
};
$('#part_selection').dialog('close');
};
+ function handle_changed_text(callbacks) {
+ $.ajax({
+ url: 'controller.pl?action=Part/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, {
$dummy.autocomplete({
source: function(req, rsp) {
$.ajax($.extend(o, {
} else if (state == STATES.PICKED) {
return true;
}
} else if (state == STATES.PICKED) {
return true;
}
- if (event.which == KEY.TAB) event.preventDefault();
- $.ajax({
- url: 'controller.pl?action=Part/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();}
+ });
} else {
state = STATES.UNDEFINED;
}
});
} 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);
$dummy.blur(function(){
window.clearTimeout(timer);
timer = window.setTimeout(annotate_state, 100);