Projekt

Allgemein

Profil

« Zurück | Weiter » 

Revision 926099a8

Von Sven Schöling vor etwa 8 Jahren hinzugefügt

  • ID 926099a8af011d9bd4d4616797ce5b0fa5e42add
  • Vorgänger 506a2aab
  • Nachfolger 905d9edd

PartPicker: Multipicker als separate popupklasse

Unterschiede anzeigen:

js/kivi.Part.js
$.post("controller.pl", data, kivi.eval_json_result);
};
ns.set_multi_assembly_items = function(data) {
data.push({ name: 'part.id', value: $('#part_id').val() });
data.push({ name: 'part.part_type', value: $('#part_part_type').val() });
$.post("controller.pl?action=Part/add_multi_assembly_items", data, kivi.eval_json_result);
}
ns.set_multi_assortment_items = function(data) {
data.push({ name: 'part.id', value: $('#part_id').val() });
data.push({ name: 'part.part_type', value: $('#part_part_type').val() });
$.post("controller.pl?action=Part/add_multi_assortment_items", data, kivi.eval_json_result);
}
ns.close_picker_dialogs = function() {
$('.part_autocomplete').each(function(_, e) {
var picker = $(e).data('part_picker');
if (picker) picker.close_dialog();
});
}
ns.redisplay_items = function(data) {
var old_rows;
var part_type = $("#part_part_type").val();
......
$("#assembly_rows tr:last").find('input[type=text]').filter(':visible:first').focus();
};
ns.show_multi_items_dialog = function(part_type,part_id) {
$('#row_table_id thead a img').remove();
kivi.popup_dialog({
url: 'controller.pl?action=Part/show_multi_items_dialog',
data: { callback: 'Part/add_multi_' + part_type + '_items',
callback_data_id: 'ic',
'part.part_type': part_type,
'part.id' : part_id,
},
id: 'jq_multi_items_dialog',
dialog: {
title: kivi.t8('Add multiple items'),
width: 800,
height: 800
}
});
return true;
};
ns.close_multi_items_dialog = function() {
$('#jq_multi_items_dialog').dialog('close');
};
// makemodel
ns.makemodel_renumber_positions = function() {
$('.makemodel_row [name="position"]').each(function(idx, elt) {
......
this.state = this.STATES.PICKED;
this.last_dummy = this.$dummy.val();
this.timer = undefined;
this.dialog = undefined;
this.init();
};
......
}
this.annotate_state();
},
set_multi_items: function(data) {
this.run_action(this.o.action.set_multi_items, [ data ]);
},
make_defined_state: function() {
if (this.state == this.STATES.PICKED) {
this.annotate_state();
......
}
},
open_dialog: function() {
new ns.PickerPopup(this);
if (this.o.multiple) {
this.dialog = new ns.PickerMultiPopup(this);
} else {
this.dialog = new ns.PickerPopup(this);
}
},
close_dialog: function() {
this.dialog.close_dialog();
this.dialog = undefined;
},
init: function() {
var self = this;
......
partnumber: $(this).children('input.part_picker_partnumber').val(),
description: $(this).children('input.part_picker_description').val(),
});
self.close_popup();
self.close_dialog();
self.pp.$dummy.focus();
return true;
});
});
$('#part_selection').keydown(function(e){
if (e.which == KEY.ESCAPE) {
self.close_popup();
self.close_dialog();
self.pp.$dummy.focus();
}
});
......
this.timer = window.setTimeout(function() { self.update_results() }, 100);
}
},
close_popup: function() {
close_dialog: function() {
$('#part_selection').dialog('close');
}
};
ns.PickerMultiPopup = function(pp) {
this.pp = pp;
this.callback = 'Part/add_multi_' + this.pp.o.part_type + '_items';
this.open_dialog();
};
ns.PickerMultiPopup.prototype = {
open_dialog: function() {
var self = this;
$('#row_table_id thead a img').remove();
kivi.popup_dialog({
url: 'controller.pl?action=Part/show_multi_items_dialog',
data: $.extend({
real_id: self.pp.real_id,
}, self.pp.ajax_data(this.pp.$dummy.val())),
id: 'jq_multi_items_dialog',
dialog: {
title: kivi.t8('Add multiple items'),
width: 800,
height: 800
},
load: function() {
self.init_search();
}
});
return true;
},
init_search: function() {
var self = this;
$('#multi_items_filter_table input, #multi_items_filter_table select').keydown(function(event) {
if(event.which == KEY.ENTER) {
event.preventDefault();
self.update_results();
return false;
}
});
$('#multi_items_filter_all_substr_multi_ilike').focus();
$('#multi_items_filter_button').click(function(){ self.update_results() });
$('#multi_items_filter_reset').click(function(){ $("#multi_items_form").resetForm() });
$('#continue_button').click(function(){ self.add_multi_items() });
},
update_results: function() {
var self = this;
var data = $('#multi_items_form').serializeArray();
data.push({ name: 'type', value: self.pp.type });
$.ajax({
url: 'controller.pl?action=Part/multi_items_update_result',
data: data,
method: 'post',
success: function(data){
$('#multi_items_result').html(data);
self.init_results();
self.enable_continue();
}
});
},
set_qty_to_one: function(clicked) {
if ($(clicked).val() === '') {
$(clicked).val(kivi.format_amount(1.00, -2));
}
$(clicked).select();
},
init_results: function() {
var self = this;
$('#multi_items_all_qty').change(function(event){
$('.multi_items_qty').val($(event.target).val());
});
$('.multi_items_qty').click(function(){ self.set_qty_to_one(this) });
},
result_timer: function(event) {
},
close_dialog: function() {
$('#jq_multi_items_dialog').dialog('close');
},
disable_continue: function() {
$('#multi_items_result input').off("keydown");
$('#continue_button').prop('disabled', true);
},
enable_continue: function() {
var self = this;
$('#multi_items_result input').keydown(function(event) {
if(event.keyCode == KEY.ENTER) {
event.preventDefault();
self.add_multi_items();
return false;
}
});
$('#continue_button').prop('disabled', false);
},
add_multi_items: function() {
// rows at all
var n_rows = $('.multi_items_qty').length;
if ( n_rows === 0) { return; }
// filled rows
n_rows = $('.multi_items_qty').filter(function() {
return $(this).val().length > 0;
}).length;
if (n_rows === 0) { return; }
this.disable_continue();
var data = $('#multi_items_form').serializeArray();
this.pp.set_multi_items(data);
}
};
ns.reinit_widgets = function() {
kivi.run_once_for('input.part_autocomplete', 'part_picker', function(elt) {
if (!$(elt).data('part_picker'))
......
}
$(function(){
// assortment
// TODO: allow units for assortment items
$('#add_assortment_item_id').on('set_item:PartPicker', function(e,o) { $('#add_item_unit').val(o.unit) });
$('#ic').on('focusout', '.reformat_number', function(event) {
ns.reformat_number(event);
})
$('.add_assortment_item_input').keydown(function(event) {
if(event.keyCode == 13) {
event.preventDefault();
if ($("input[name='add_items[+].parts_id']").val() !== '' ) {
kivi.Part.show_multi_items_dialog("assortment");
// ns.add_assortment_item();
}
return false;
}
});
$('.add_assembly_item_input').keydown(function(event) {
if(event.keyCode == 13) {
event.preventDefault();
if ($("input[name='add_items[+].parts_id']").val() !== '' ) {
kivi.Part.show_multi_items_dialog("assortment");
// ns.add_assembly_item();
}
return false;
}
});
$('.add_makemodel_input').keydown(function(event) {
templates/webpages/part/_multi_items_dialog.html
<form method="post" id="multi_items_form" method="POST">
[% L.hidden_tag('part.part_type', FORM.part.part_type) %]
<table id='multi_items_filter_table'>
<tr>
<th>[%- LxERP.t8("Description") %]/[%- LxERP.t8("Partnumber") %]:</th>
<td>[%- L.input_tag('multi_items.filter.all:substr:multi::ilike', partfilter) %]</td>
<td>[%- L.input_tag('multi_items.filter.all:substr:multi::ilike', SELF.multi_items_models.filtered.laundered.all_substr_multi__ilike) %]</td>
<th>[%- LxERP.t8("Partsgroup") %]</th>
<td>[%- L.select_tag('multi_items.filter.partsgroup_id', all_partsgroups, title_key='partsgroup', value_key='id', with_empty=1) %]</td>
<tr>
</table>
[% L.button_tag('update_result()', LxERP.t8('Filter')) %]
[% L.button_tag('$("#multi_items_form").resetForm()', LxERP.t8('Reset')) %]
[% L.button_tag('', LxERP.t8('Filter'), id='multi_items_filter_button') %]
[% L.button_tag('', LxERP.t8('Reset'), id='multi_items_filter_reset') %]
<hr>
<div id='multi_items_result'></div>
<hr>
[% L.button_tag('add_multi_items()', LxERP.t8('Continue'), id='continue_button') %]
<a href="#" onclick="kivi.Part.close_multi_items_dialog();">[%- LxERP.t8("Cancel") %]</a>
<script type='text/javascript'>
function update_result() {
var data = $('#multi_items_form').serializeArray();
data.push({ name: 'type', value: '[%- FORM.type %]' });
$.ajax({
url: 'controller.pl?action=Part/multi_items_update_result',
data: data,
method: 'post',
success: function(data){
$('#multi_items_result').html(data);
enable_continue();
}
});
}
function disable_continue() {
// disable keydown-event and continue button to prevent
// impatient users to add parts multiple times
$('#multi_items_result input').off("keydown");
$('#continue_button').prop('disabled', true);
}
function enable_continue() {
$('#multi_items_result input').keydown(function(event) {
if(event.keyCode == 13) {
event.preventDefault();
add_multi_items();
return false;
}
});
$('#continue_button').prop('disabled', false);
}
function add_multi_items() {
// rows at all
var n_rows = $('.multi_items_qty').length;
if ( n_rows == 0) { return; }
// filled rows
n_rows = $('.multi_items_qty').filter(function() {
return $(this).val().length > 0;
}).length;
if ( n_rows == 0) { return; }
disable_continue();
// var data = $('#[%- FORM.callback_data_id %]').serializeArray(); /* do i need to serialize this as well? */
// var data = data.concat($('#multi_items_form').serializeArray());
var data = $('#multi_items_form').serializeArray();
data.push({ name: 'action', value: '[%- FORM.callback %]' });
data.push({ name: 'part_type', value: '[%- FORM.part.part_type %]' });
data.push({ name: 'part.id' , value: '[%- FORM.part.id %]' });
$.post("controller.pl", data, kivi.eval_json_result);
}
$('#multi_items_filter_table input, #multi_items_filter_table select').keydown(function(event) {
if(event.keyCode == 13) {
event.preventDefault();
update_result();
return false;
}
});
$('#multi_items_filter_all_substr_multi_ilike').focus();
</script>
[% L.button_tag('', LxERP.t8('Continue'), id='continue_button') %]
</form>
templates/webpages/part/_multi_items_result.html
<td>
[% L.hidden_tag("add_items[+].parts_id", item.id) %]
[% L.input_tag("add_items[].qty_as_number", '', size = 5,
class = 'multi_items_qty numeric', onclick = 'set_qty_to_one(this)') %]
class = 'multi_items_qty numeric') %]
</td>
<td>[% HTML.escape(item.unit) %]</td>
<td>[% P.part(item) %]</td>
......
</tr>
[%- END %]
</table>
<script type='text/javascript'>
function set_qty_to_one(clicked) {
if ($(clicked).val() == '') {
$(clicked).val('[%- LxERP.format_amount(1.00, -2) %]');
}
$(clicked).select();
}
$('#multi_items_all_qty').change(function(event){
$('.multi_items_qty').val($(event.target).val());
});
</script>
templates/webpages/part/test_page.html
Convertible unit 'Std': (only select parts with unit Tag/Std/Min)<br>
[% L.part_picker('part_id7', undef, convertible_unit='Std') %]<br>
With multi select popup<br>
[% L.part_picker('part_id8', undef, multiple=1) %]<br>
<h2>Styling</h2>
In a span:

Auch abrufbar als: Unified diff