<td>[% L.customer_vendor_picker("order.${SELF.cv}" _ '_id', SELF.order.$cv_id, type=SELF.cv, style='width: 300px') %]</td>
</tr>
- <tr id='cp_row' [%- IF !SELF.order.${SELF.cv}.contacts.size %]style='display:none;'[%- END %]>
+ <tr id='cp_row' [%- IF !SELF.order.${SELF.cv}.contacts.size %]style='display:none'[%- END %]>
<th align="right">[% 'Contact Person' | $T8 %]</th>
<td>[% L.select_tag('order.cp_id',
SELF.order.${SELF.cv}.contacts,
style='width: 300px') %]</td>
</tr>
- <tr id='shipto_row' [%- IF !SELF.order.${SELF.cv}.shipto.size %]style='display:none;'[%- END %]>
+ <tr id='shipto_row' [%- IF !SELF.order.${SELF.cv}.shipto.size %]style='display:none'[%- END %]>
<th align="right">[% 'Shipping Address' | $T8 %]</th>
<td>[% L.select_tag('order.shipto_id',
SELF.order.${SELF.cv}.shipto,
<td>[% L.input_tag('order.ordnumber', SELF.order.ordnumber, size = 11) %]</td>
</tr>
+ <tr>
+ <th width="70%" align="right" nowrap>[% 'Quotation Number' | $T8 %]</th>
+ <td>[% L.input_tag('order.quonumber', SELF.order.quonumber, size = 11) %]</td>
+ </tr>
+
<tr>
<th width="70%" align="right" nowrap>[% 'Customer Order Number' | $T8 %]</th>
<td>[% L.input_tag('order.cusordnumber', SELF.order.cusordnumber, size = 11) %]</td>
<td>[% L.date_tag('order.transdate', SELF.order.transdate) %]</td>
</tr>
+ <tr>
+ <th width="70%" align="right" nowrap>[% 'Insert Date' | $T8 %]</th>
+ <td>[% SELF.order.itime_as_date %]</td>
+ </tr>
+
<tr>
<th width="70%" align="right" nowrap>[% 'Project Number' | $T8 %]</th>
<td>[%- L.select_tag('order.globalproject_id', SELF.all_projects, default=SELF.order.globalproject_id, title_key='projectnumber', with_empty = 1) %]</td>
<tr>
<td>
- <div id="row_table_scroll_id" style="overflow-y: auto; height: 45vh;">
+ <div id="row_table_scroll_id" style="overflow-y: auto; height: 45vh">
<table id="row_table_id" width="100%">
<thead>
<tr class="listheading">
</tr>
<tr>
- <td align="right">
- <table>
- [%- IF NOT taxincluded %]
+ <td colspan="100%" width="100%">
+ <table width="100%">
<tr>
- <th align="right">[%- 'Subtotal' | $T8 %]</th>
- <td align="right">
- [%- L.div_tag(SELF.order.netamount_as_number, id='netamount_id') %]
+ <td>
+ <table>
+ <tr>
+ <th align="left">[% 'Notes' | $T8 %]</th>
+ <th align="left">[% 'Internal Notes' | $T8 %]</th>
+ </tr>
+ <tr valign="top">
+ <td>
+ [% L.textarea_tag('order.notes', SELF.order.notes, wrap="soft", style="width: 350px; height: 150px", class="texteditor") %]
+ </td>
+ <td>
+ [% L.textarea_tag('order.intnotes', SELF.order.intnotes, wrap="soft", style="width: 350px; height: 150px") %]
+ </td>
+ </tr>
+ </table>
</td>
- </tr>
- [%- END %]
- [%- FOREACH tax = SELF.taxes %]
- [%- PROCESS order/tabs/_tax_row.html TAX=tax %]
- [%- END %]
- <tr id="amount_row_id">
- <th align="right">[%- 'Total' | $T8 %]</th>
+
+ <td>
+ <table>
+ <tr>
+ <th align="right">[% 'Payment Terms' | $T8 %]</th>
+ <td>[% L.select_tag('order.payment_id',
+ SELF.all_payment_terms,
+ default = SELF.order.payment_id,
+ with_empty = 1,
+ title_key = 'description',
+ style = 'width: 250px') %]</td>
+ </tr>
+ <tr>
+ <th align="right">[% 'Delivery Terms' | $T8 %]</th>
+ <td>[% L.select_tag('order.delivery_term_id',
+ SELF.all_delivery_terms,
+ default = SELF.order.delivery_term_id,
+ with_empty = 1,
+ title_key = 'description',
+ style = 'width: 250px') %]</td>
+ </tr>
+ </table>
+ </td>
+
<td align="right">
- [%- L.div_tag(SELF.order.amount_as_number, id='amount_id') %]
+ <table>
+ [%- IF NOT taxincluded %]
+ <tr>
+ <th align="right">[%- 'Subtotal' | $T8 %]</th>
+ <td align="right">
+ [%- L.div_tag(SELF.order.netamount_as_number, id='netamount_id') %]
+ </td>
+ </tr>
+ [%- END %]
+ [%- FOREACH tax = SELF.taxes %]
+ [%- PROCESS order/tabs/_tax_row.html TAX=tax %]
+ [%- END %]
+ <tr id="amount_row_id">
+ <th align="right">[%- 'Total' | $T8 %]</th>
+ <td align="right">
+ [%- L.div_tag(SELF.order.amount_as_number, id='amount_id') %]
+ </tr>
+ </table>
+ </td>
+
</tr>
</table>
</td>
</tr>
<tr>
- <td><hl></td>
+ <td><hr></td>
</tr>
</table>
}
function delete_order_item_row(clicked) {
- var row = $(clicked).parents("tr").first();
+ var row = $(clicked).parents("tbody").first();
$(row).remove();
- recalc_amounts_and_taxes()
+ recalc_amounts_and_taxes();
}
function recalc_amounts_and_taxes() {
$.post("controller.pl", data, kivi.eval_json_result);
}
+function redisplay_linetotals(data) {
+ $('.row_entry [name="linetotal"]').each(function(idx, elt) {
+ $(elt).html(data[idx]);
+ });
+}
+
function row_table_scroll_down() {
$('#row_table_scroll_id').scrollTop($('#row_table_scroll_id')[0].scrollHeight);
}
+function row_set_keyboard_events_by_id(item_id) {
+ var row = $('#item_' + item_id).parents("tbody").first();
+
+ row_set_keyboard_events(row);
+}
+
+function row_set_keyboard_events(rows) {
+ $(rows).keydown(function(event) {
+ if(event.keyCode == 40 && event.shiftKey == true) {
+ // shift arrow down
+ event.preventDefault();
+ var row = $(event.target).parents(".row_entry").first();
+ $(row).children().not(':first').show();
+ return false;
+ }
+ if(event.keyCode == 38 && event.shiftKey == true) {
+ // shift arrow up
+ event.preventDefault();
+ var row = $(event.target).parents(".row_entry").first();
+ $(row).children().not(':first').hide();
+ return false;
+ }
+ });
+
+ $(rows).dblclick(function(event) {
+ event.preventDefault();
+ var row = $(event.target).parents(".row_entry").first();
+ $(row).children().not(':first').toggle();
+ return false;
+ });
+}
+
$(function(){
$('#order_[%- cv_id %]').change(reload_cv_dependend_selections);
$('#add_item_parts_id').on('set_item:PartPicker', function(e,o) { $('#add_item_sellprice_as_number').val(kivi.format_amount(o.sellprice, -2)) });
return false;
}
});
+ row_set_keyboard_events($('.row_entry'));
+ $('.recalc').change(recalc_amounts_and_taxes);
});
</script>