X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=js%2Fkivi.Part.js;h=4f813bbf4713183b1267db65283b22970576eee7;hb=6ceacc682f9c760e654f5aacde9b8480760d8b36;hp=ff3ce981a1c6b1acc6d8b4ffcd028244d901ea1d;hpb=2096db3951150a55ebc4db00b20d8f606cdfaf34;p=kivitendo-erp.git diff --git a/js/kivi.Part.js b/js/kivi.Part.js index ff3ce981a..4f813bbf4 100644 --- a/js/kivi.Part.js +++ b/js/kivi.Part.js @@ -154,7 +154,7 @@ namespace('kivi.Part', function(ns) { }; ns.add_assortment_item = function() { - if ($('#add_assortment_item_id').val() === '') return; + if ($('#assortment_picker').val() === '') return; $('#row_table_id thead a img').remove(); @@ -162,17 +162,19 @@ namespace('kivi.Part', function(ns) { data.push({ name: 'action', value: 'Part/add_assortment_item' }, { name: 'part.id', value: $('#part_id').val() }, { name: 'part.part_type', value: 'assortment' }); + $('#assortment_picker').data('part_picker').clear(); $.post("controller.pl", data, kivi.eval_json_result); }; ns.add_assembly_item = function() { - if ($('#add_assembly_item_id').val() === '') return; + if ($('#assembly_picker').val() === '') return; var data = $('#assembly :input').serializeArray(); data.push({ name: 'action', value: 'Part/add_assembly_item' }, { name: 'part.id', value: $("#part_id").val() }, - { name: 'part.part_type', value: 'assortment' }); + { name: 'part.part_type', value: 'assembly' }); + $('#assembly_picker').data('part_picker').clear(); $.post("controller.pl", data, kivi.eval_json_result); }; @@ -192,7 +194,7 @@ namespace('kivi.Part', function(ns) { ns.close_picker_dialogs = function() { $('.part_autocomplete').each(function(_, e) { var picker = $(e).data('part_picker'); - if (picker) picker.close_dialog(); + if (picker && picker.dialog) picker.close_dialog(); }); } @@ -239,10 +241,11 @@ namespace('kivi.Part', function(ns) { }; ns.add_makemodel_row = function() { - if ($('#add_makemodelid').val() === '') return; + if ($('#add_makemodel').val() === '') return; var data = $('#makemodel_table :input').serializeArray(); data.push({ name: 'action', value: 'Part/add_makemodel_row' }); + $('#add_makemodel').data('customer_vendor_picker').clear(); $.post("controller.pl", data, kivi.eval_json_result); }; @@ -251,6 +254,36 @@ namespace('kivi.Part', function(ns) { $("#makemodel_rows tr:last").find('input[type=text]').filter(':visible:first').focus(); }; + + // customerprice + ns.customerprice_renumber_positions = function() { + $('.customerprice_row [name="position"]').each(function(idx, elt) { + $(elt).html(idx+1); + }); + }; + + ns.delete_customerprice_row = function(clicked) { + var row = $(clicked).closest('tr'); + $(row).remove(); + + ns.customerprice_renumber_positions(); + }; + + ns.add_customerprice_row = function() { + if ($('#add_customerprice').val() === '') return; + + var data = $('#customerprice_table :input').serializeArray(); + data.push({ name: 'action', value: 'Part/add_customerprice_row' }); + $('#add_customerprice').data('customer_vendor_picker').clear(); + + $.post("controller.pl", data, kivi.eval_json_result); + }; + + ns.focus_last_customerprice_input = function () { + $("#customerprice_rows tr:last").find('input[type=text]').filter(':visible:first').focus(); + }; + + ns.reload_bin_selection = function() { $.post("controller.pl", { action: 'Part/warehouse_changed', warehouse_id: function(){ return $('#part_warehouse_id').val() } }, kivi.eval_json_result); } @@ -272,13 +305,13 @@ namespace('kivi.Part', function(ns) { ns.Picker = function($real, options) { var self = this; - this.o = $.extend({ + this.o = $.extend(true, { limit: 20, delay: 50, action: { - on_enter_match_none: function(){ }, - on_enter_match_one: function(){ $('#update_button').click(); }, - on_enter_match_many: function(){ self.open_dialog(); } + commit_none: function(){ }, + commit_one: function(){ $('#update_button').click(); }, + commit_many: function(){ self.open_dialog(); } } }, $real.data('part-picker-data'), options); this.$real = $real; @@ -301,14 +334,18 @@ namespace('kivi.Part', function(ns) { }, ajax_data: function(term) { var data = { - 'filter.all:substr:multi::ilike': term, - 'filter.obsolete': 0, current: this.$real.val(), }; if (this.o.part_type) data['filter.part_type'] = this.o.part_type.split(','); + if (this.o.status) { + if (this.o.status == 'active') data['filter.obsolete'] = 0; + if (this.o.status == 'obsolete') data['filter.obsolete'] = 1; + } else + data['filter.obsolete'] = 0; + if (this.o.classification_id) data['filter.classification_id'] = this.o.classification_id.split(','); @@ -318,6 +355,15 @@ namespace('kivi.Part', function(ns) { if (this.o.convertible_unit) data['filter.unit_obj.convertible_to'] = this.o.convertible_unit; + var filter_name = 'all'; + if (this.o.with_makemodel) { + filter_name = 'all_with_makemodel'; + } + if (this.o.with_customer_partnumber) { + filter_name = 'all_with_customer_partnumber'; + } + data['filter.' + filter_name + ':substr:multi::ilike'] = term; + return data; }, set_item: function(item) { @@ -386,7 +432,7 @@ namespace('kivi.Part', function(ns) { if (callbacks && callbacks.match_many) self.run_action(callbacks.match_many, [ data ]); } else { self.state = self.STATES.UNDEFINED; - if (callbacks && callbacks.match_none) self.run_action(callbacks.match_none); + if (callbacks && callbacks.match_none) self.run_action(callbacks.match_none, [ self, self.$dummy.val() ]); } self.annotate_state(); } @@ -412,8 +458,8 @@ namespace('kivi.Part', function(ns) { self.set_item({}); return true; } else if (self.state == self.STATES.PICKED) { - if (self.o.action.on_enter_match_one) { - self.run_action(self.o.action.on_enter_match_one); + if (self.o.action.commit_one) { + self.run_action(self.o.action.commit_one); } return true; } @@ -422,9 +468,11 @@ namespace('kivi.Part', function(ns) { self.handle_changed_text(); } if (event.which == KEY.ENTER) { + event.preventDefault(); self.handle_changed_text({ - match_one: self.o.action.on_enter_match_one, - match_many: self.o.action.on_enter_match_many + match_none: self.o.action.commit_none, + match_one: self.o.action.commit_one, + match_many: self.o.action.commit_many }); return false; } @@ -461,6 +509,9 @@ namespace('kivi.Part', function(ns) { }, select: function(event, ui) { self.set_item(ui.item); + if (self.o.action.commit_one) { + self.run_action(self.o.action.commit_one); + } }, search: function(event, ui) { if ((event.which == KEY.SHIFT) || (event.which == KEY.CTRL) || (event.which == KEY.ALT)) @@ -556,6 +607,7 @@ namespace('kivi.Part', function(ns) { id: $(this).children('input.part_picker_id').val(), name: $(this).children('input.part_picker_description').val(), classification_id: $(this).children('input.part_picker_classification_id').val(), + ean: $(this).children('input.part_picker_ean').val(), unit: $(this).children('input.part_picker_unit').val(), partnumber: $(this).children('input.part_picker_partnumber').val(), description: $(this).children('input.part_picker_description').val(), @@ -643,6 +695,11 @@ namespace('kivi.Part', function(ns) { var self = this; var data = $('#multi_items_form').serializeArray(); data.push({ name: 'type', value: self.pp.type }); + var ppdata = self.pp.ajax_data(function(){ + var val = $('#multi_items_filter').val(); + return val === undefined ? '' : val + }); + $.each(Object.keys(ppdata), function() {data.push({ name: 'multi_items.' + this, value: ppdata[this]});}); $.ajax({ url: 'controller.pl?action=Part/multi_items_update_result', data: data, @@ -710,6 +767,14 @@ namespace('kivi.Part', function(ns) { if (!$(elt).data('part_picker')) $(elt).data('part_picker', new kivi.Part.Picker($(elt))); }); + + kivi.run_once_for('#customerprice_rows', 'customerprice_row_sort_renumber', function(elt) { + $(elt).on('sortstop', kivi.Part.customerprice_renumber_positions); + }); + + kivi.run_once_for('#makemodel_rows', 'makemodel_row_sort_renumber', function(elt) { + $(elt).on('sortstop', kivi.Part.makemodel_renumber_positions); + }); } ns.init = function() { @@ -721,14 +786,6 @@ namespace('kivi.Part', function(ns) { ns.reformat_number(event); }); - $('.add_makemodel_input').keydown(function(event) { - if(event.keyCode == 13) { - event.preventDefault(); - ns.add_makemodel_row(); - return false; - } - }); - $('#part_warehouse_id').change(kivi.Part.reload_bin_selection); ns.init();