d66c9105e43fbbe729c4d2bb44ef519a4051bd11
[kivitendo-erp.git] / templates / webpages / order / tabs / basic_data.html
1 [%- USE T8 %]
2 [%- USE HTML %]
3 [%- USE LxERP %]
4 [%- USE L %]
5
6 <div id="ui-tabs-basic-data">
7   <table width="100%">
8     <tr valign="top">
9       <td>
10         <table width="100%">
11           <tr>
12             <th align="right">[% SELF.cv | $T8 %]</th>
13             [% SET cv_id = SELF.cv _ '_id' %]
14             <td>[% L.customer_vendor_picker("order.${SELF.cv}" _ '_id', SELF.order.$cv_id, type=SELF.cv, style='width: 300px') %]</td>
15           </tr>
16
17           <tr id='cp_row' [%- IF !SELF.order.${SELF.cv}.contacts.size %]style='display:none'[%- END %]>
18             <th align="right">[% 'Contact Person' | $T8 %]</th>
19             <td>[% L.select_tag('order.cp_id',
20                                 SELF.order.${SELF.cv}.contacts,
21                                 default=SELF.order.cp_id,
22                                 title_key='full_name_dep',
23                                 value_key='cp_id',
24                                 with_empty=1,
25                                 style='width: 300px') %]</td>
26           </tr>
27
28           <tr id='shipto_row' [%- IF !SELF.order.${SELF.cv}.shipto.size %]style='display:none'[%- END %]>
29             <th align="right">[% 'Shipping Address' | $T8 %]</th>
30             <td>[% L.select_tag('order.shipto_id',
31                                 SELF.order.${SELF.cv}.shipto,
32                                 default=SELF.order.shipto_id,
33                                 title_key='displayable_id',
34                                 value_key='shipto_id',
35                                 with_empty=1,
36                                 style='width: 300px') %]</td>
37           </tr>
38
39           <tr>
40             <th align="right">[% 'Steuersatz' | $T8 %]</th>
41             <td>[% L.select_tag('order.taxzone_id', SELF.all_taxzones, default=SELF.order.taxzone_id, title_key='description', style='width: 300px', class='recalc') %]</td>
42           </tr>
43
44 [%- IF SELF.all_departments.size %]
45           <tr>
46             <th align="right">[% 'Department' | $T8 %]</th>
47             <td>
48               [% L.select_tag('order.department_id', SELF.all_departments, default=SELF.order.department_id, title_key='description', with_empty=1, style='width:300px') %]
49             </td>
50           </tr>
51 [%- END %]
52
53           <tr>
54             <th align="right">[% 'Shipping Point' | $T8 %]</th>
55             <td>[% L.input_tag('order.shippingpoint', SELF.order.shippingpoint, style='width: 300px') %]</td>
56           </tr>
57
58           <tr>
59             <th align="right">[% 'Ship via' | $T8 %]</th>
60             <td>[% L.input_tag('order.shipvia', SELF.order.shipvia, style='width: 300px') %]</td>
61           </tr>
62
63           <tr>
64             <th align="right">[% 'Transaction description' | $T8 %]</th>
65             <td>[% L.input_tag('order.transaction_description', SELF.order.transaction_description, style='width: 300px') %]</td>
66           </tr>
67
68           <tr>
69             <th align="right">[% 'Project Number' | $T8 %]</th>
70             <td>[% L.project_picker('order.globalproject_id', SELF.order.globalproject_id, style='width: 300px') %]</td>
71           </tr>
72
73         </table>
74       </td>
75
76       <td align="right">
77         <table>
78
79           <tr>
80             <td colspan="2" align="center">
81               [%- IF SELF.order.closed %] [% 'Closed' | $T8 %] [%- ELSE %] [% 'Open' | $T8 %] [%- END %]
82             </td>
83           </tr>
84
85           <tr>
86             <th align="right">[% 'Employee' | $T8 %]</th>
87             <td>[% L.select_tag('order.employee_id',
88               SELF.all_employees,
89               default=(SELF.order.employee_id ? SELF.order.employee_id : SELF.current_employee_id),
90               title_key='safe_name') %]</td>
91           </tr>
92
93           [% IF SELF.cv == 'customer' %]
94           <tr>
95             <th align="right">[% 'Salesman' | $T8 %]</th>
96             <td>[% L.select_tag('order.salesman_id',
97               SELF.all_salesmen,
98               default=(SELF.order.salesman_id ? SELF.order.salesman_id : SELF.current_employee_id),
99               title_key='safe_name') %]</td>
100           </tr>
101           [% END %]
102
103           <tr>
104             <th width="70%" align="right" nowrap>[% 'Order Number' | $T8 %]</th>
105             <td>[% L.input_tag('order.ordnumber', SELF.order.ordnumber, size = 11) %]</td>
106           </tr>
107
108           <tr>
109             <th width="70%" align="right" nowrap>[% 'Quotation Number' | $T8 %]</th>
110             <td>[% L.input_tag('order.quonumber', SELF.order.quonumber, size = 11) %]</td>
111           </tr>
112
113           <tr>
114             <th width="70%" align="right" nowrap>[% 'Customer Order Number' | $T8 %]</th>
115             <td>[% L.input_tag('order.cusordnumber', SELF.order.cusordnumber, size = 11) %]</td>
116           </tr>
117
118           <tr>
119             <th width="70%" align="right" nowrap>[% 'Order Date' | $T8 %]</th>
120             <td>[% L.date_tag('order.transdate', SELF.order.transdate) %]</td>
121           </tr>
122
123           <tr>
124             <th width="70%" align="right" nowrap>[% 'Reqdate' | $T8 %]</th>
125             <td>[% L.date_tag('order.reqdate', SELF.order.reqdate) %]</td>
126           </tr>
127
128           <tr>
129             <th width="70%" align="right" nowrap>[% 'Insert Date' | $T8 %]</th>
130             <td>[% SELF.order.itime_as_date %]</td>
131           </tr>
132
133         </table>
134
135       </td>
136     </tr>
137   </table>
138
139   [%- PROCESS order/tabs/_item_input.html %]
140
141   [% L.button_tag('setup_multi_items_dialog()', LxERP.t8('Add multiple parts')) %]</td>
142
143   <table width="100%">
144     <tr>
145       <td>
146
147         <div id="row_table_scroll_id" style="overflow-y: auto; height: 25vh">
148           <table id="row_table_id" width="100%">
149             <thead>
150               <tr class="listheading">
151                 <th class="listheading" style='display:none'></th>
152                 <th class="listheading" style='text-align:center' nowrap width="1"><img src="image/updown.png" alt="[%- LxERP.t8('reorder item') %]"></th>
153                 <th class="listheading" style='text-align:center' nowrap width="1"><img src="image/close.png" alt="[%- LxERP.t8('delete item') %]"></th>
154                 <th class="listheading" nowrap width="15">[%- 'Partnumber'  | $T8 %] </th>
155                 <th class="listheading" nowrap           >[%- 'Description'  | $T8 %] </th>
156                 <th class="listheading" nowrap width="5" >[%- 'Qty'          | $T8 %] </th>
157                 <th class="listheading" nowrap width="5" >[%- 'Price Factor' | $T8 %] </th>
158                 <th class="listheading" nowrap width="5" >[%- 'Unit'         | $T8 %] </th>
159                 <th class="listheading" nowrap width="5" >[%- 'Price Source' | $T8 %] </th>
160                 <th class="listheading" nowrap width="15">[%- 'Price'        | $T8 %] </th>
161                 <th class="listheading" nowrap width="5" >[%- 'Discount'     | $T8 %] </th>
162                 <th class="listheading" nowrap width="10">[%- 'Extended'     | $T8 %] </th>
163               </tr>
164             </thead>
165
166             [%- FOREACH item = SELF.order.items_sorted %]
167               [%- PROCESS order/tabs/_row.html ITEM=item ID=item.id %]
168             [%- END %]
169
170           </table>
171         </div>
172
173       </td>
174     </tr>
175
176     <tr>
177     </tr>
178
179     <tr>
180       <td colspan="100%" width="100%">
181         <table width="100%">
182           <tr>
183             <td>
184               <table>
185                 <tr>
186                   <th align="left">[% 'Notes' | $T8 %]</th>
187                   <th align="left">[% 'Internal Notes' | $T8 %]</th>
188                 </tr>
189                 <tr valign="top">
190                   <td>
191                     [% L.textarea_tag('order.notes', SELF.order.notes, wrap="soft", style="width: 350px; height: 150px", class="texteditor") %]
192                   </td>
193                   <td>
194                     [% L.textarea_tag('order.intnotes', SELF.order.intnotes, wrap="soft", style="width: 350px; height: 150px") %]
195                   </td>
196                 </tr>
197               </table>
198             </td>
199
200             <td>
201               <table>
202                 <tr>
203                   <th align="right">[% 'Payment Terms' | $T8 %]</th>
204                   <td>[% L.select_tag('order.payment_id',
205                                       SELF.all_payment_terms,
206                                       default = SELF.order.payment_id,
207                                       with_empty = 1,
208                                       title_key = 'description',
209                                       style = 'width: 250px') %]</td>
210                 </tr>
211                 <tr>
212                   <th align="right">[% 'Delivery Terms' | $T8 %]</th>
213                   <td>[% L.select_tag('order.delivery_term_id',
214                                       SELF.all_delivery_terms,
215                                       default = SELF.order.delivery_term_id,
216                                       with_empty = 1,
217                                       title_key = 'description',
218                                       style = 'width: 250px') %]</td>
219                 </tr>
220               </table>
221             </td>
222
223             <td align="right">
224               <table>
225                 <tr id="taxincluded_row_id" [%- IF !SELF.taxes.size %]style="display:none"[%- END %]>
226                   <td align=right colspan="2">
227                     <label for="order.taxincluded"><b>[% 'Tax Included' | $T8 %]</b></label>
228                     [% L.yes_no_tag('order.taxincluded', SELF.order.taxincluded, class='recalc') %]
229                   </td>
230                 </tr>
231
232                 <tr id="subtotal_row_id" [%- IF SELF.order.taxincluded %]style="display:none"[%- END %]>
233                   <th align="right">[%- 'Subtotal' | $T8 %]</th>
234                   <td align="right">
235                     [%- L.div_tag(SELF.order.netamount_as_number, id='netamount_id') %]
236                   </td>
237                 </tr>
238                 [%- FOREACH tax = SELF.taxes %]
239                   [%- PROCESS order/tabs/_tax_row.html TAX=tax TAXINCLUDED=SELF.order.taxincluded %]
240                 [%- END %]
241                 <tr id="amount_row_id">
242                   <th align="right">[%- 'Total' | $T8 %]</th>
243                   <td align="right">
244                     [%- L.div_tag(SELF.order.amount_as_number, id='amount_id') %]
245                   </td>
246                 </tr>
247               </table>
248             </td>
249
250           </tr>
251         </table>
252       </td>
253     </tr>
254
255   </table>
256
257 </div>
258
259
260 [% L.sortable_element('#row_table_id') %]
261
262 <script type='text/javascript'>
263 function reload_cv_dependend_selections() {
264   var data = $('#order_form').serialize();
265   data += '&action=Order/customer_vendor_changed';
266
267   $.post("controller.pl", data, kivi.eval_json_result);
268 }
269
270 function add_item() {
271   if ($('#add_item_parts_id').val() == '') return;
272   if (!check_cv()) return;
273
274   var data = $('#order_form').serialize();
275   data += '&action=Order/add_item';
276   data += '&type=' + $('#type').val();
277
278   $.post("controller.pl", data, kivi.eval_json_result);
279 }
280
281 function setup_multi_items_dialog() {
282   if (!check_cv()) return;
283   var data = $('#order_form').serialize();
284   data += '&action=Order/show_multi_items_dialog';
285
286   $.post("controller.pl", data, kivi.eval_json_result);
287 }
288
289 var multi_items_dialog;
290
291 function show_multi_items_dialog(html, title) {
292   var id            = 'jq_multi_items_dialog';
293   var dialog_params = {
294     id:     id,
295     width:  800,
296     height: 500,
297     modal:  true,
298     close:  function(event, ui) {
299       multi_items_dialog.remove();
300     },
301   };
302
303   $('#' + id).remove();
304
305   multi_items_dialog = $('<div style="display:none" id="' + id + '"></div>').appendTo('body');
306   multi_items_dialog.attr('title', title);
307   multi_items_dialog.html(html);
308   multi_items_dialog.dialog(dialog_params);
309
310   $('.cancel').click(close_multi_items_dialog);
311
312   return true;
313 }
314
315 var close_multi_items_dialog = function() {
316   multi_items_dialog.dialog('close');
317 }
318
319 function delete_order_item_row(clicked) {
320   var row = $(clicked).parents("tbody").first();
321   $(row).remove();
322
323   recalc_amounts_and_taxes();
324 }
325
326 function price_chooser_item_row(clicked) {
327   var row = $(clicked).parents("tbody").first();
328   var item_id_dom = $(row).find('[name="orderitem_ids[+]"]');
329
330   var data = $('#order_form').serialize();
331   data += '&action=Order/price_popup';
332   data += '&item_id=' + item_id_dom.val();
333
334   $.post("controller.pl", data, kivi.eval_json_result);
335 }
336
337 function update_price_source(item_id, source, descr, price_str) {
338   var row = $('#item_' + item_id).parents("tbody").first();
339   var source_elt = $(row).find('[name="order.orderitems[].active_price_source"]');
340   var button_elt = $(row).find('[name="price_chooser_button"]');
341
342   button_elt.val(button_elt.val().replace(/.*\|/, descr + " |"));
343   source_elt.val(source);
344
345   var editable_div_elt = $(row).find('[name="editable_price"]');
346   var not_editable_div_elt = $(row).find('[name="not_editable_price"]');
347   if ([%- AUTH.assert('edit_prices', 1) %] == 1 && source == '') {
348     // editable
349     $(editable_div_elt).show();
350     $(not_editable_div_elt).hide();
351     $(editable_div_elt).find(':input').prop("disabled", false);
352     $(not_editable_div_elt).find(':input').prop("disabled", true);
353   } else {
354     // not editable
355     $(editable_div_elt).hide();
356     $(not_editable_div_elt).show();
357     $(editable_div_elt).find(':input').prop("disabled", true);
358     $(not_editable_div_elt).find(':input').prop("disabled", false);
359   }
360
361   if (price_str) {
362     var price_elt = $(row).find('[name="order.orderitems[].sellprice_as_number"]');
363     var html_elt  = $(row).find('[name="sellprice_text"]');
364     price_elt.val(price_str);
365     html_elt.html(price_str);
366     recalc_amounts_and_taxes();
367   }
368
369   kivi.io.close_dialog();
370 }
371
372 function update_discount_source(item_id, source, descr, discount_str) {
373   var row = $('#item_' + item_id).parents("tbody").first();
374   var source_elt = $(row).find('[name="order.orderitems[].active_discount_source"]');
375   var button_elt = $(row).find('[name="price_chooser_button"]');
376
377   button_elt.val(button_elt.val().replace(/\|.*/, "| " + descr));
378   source_elt.val(source);
379
380   var editable_div_elt = $(row).find('[name="editable_discount"]');
381   var not_editable_div_elt = $(row).find('[name="not_editable_discount"]');
382   if ([%- AUTH.assert('edit_prices', 1) %] == 1 && source == '') {
383     // editable
384     $(editable_div_elt).show();
385     $(not_editable_div_elt).hide();
386     $(editable_div_elt).find(':input').prop("disabled", false);
387     $(not_editable_div_elt).find(':input').prop("disabled", true);
388   } else {
389     // not editable
390     $(editable_div_elt).hide();
391     $(not_editable_div_elt).show();
392     $(editable_div_elt).find(':input').prop("disabled", true);
393     $(not_editable_div_elt).find(':input').prop("disabled", false);
394   }
395
396   if (discount_str) {
397     var discount_elt = $(row).find('[name="order.orderitems[].discount_as_percent"]');
398     var html_elt     = $(row).find('[name="discount_text"]');
399     discount_elt.val(discount_str);
400     html_elt.html(discount_str);
401     recalc_amounts_and_taxes();
402   }
403
404   kivi.io.close_dialog();
405 }
406
407 function reformat_number(event) {
408   $(event.target).val(kivi.format_amount(kivi.parse_amount($(event.target).val()), -2));
409 }
410
411 function recalc_amounts_and_taxes() {
412   var data = $('#order_form').serialize();
413   data += '&action=Order/recalc_amounts_and_taxes';
414   data += '&type=' + $('#type').val();
415
416   $.post("controller.pl", data, kivi.eval_json_result);
417 }
418
419 function redisplay_linetotals(data) {
420   $('.row_entry [name="linetotal"]').each(function(idx, elt) {
421     $(elt).html(data[idx]);
422   });
423 }
424
425 function row_table_scroll_down() {
426   $('#row_table_scroll_id').scrollTop($('#row_table_scroll_id')[0].scrollHeight);
427 }
428
429 function row_set_keyboard_events_by_id(item_id) {
430   var row = $('#item_' + item_id).parents("tbody").first();
431
432   row_set_keyboard_events(row);
433 }
434
435 function row_set_keyboard_events(rows) {
436   $(rows).keydown(function(event) {
437     if(event.keyCode == 40 && event.shiftKey == true) {
438       // shift arrow down
439       event.preventDefault();
440       var row = $(event.target).parents(".row_entry").first();
441       $(row).children().not(':first').show();
442       return false;
443     }
444     if(event.keyCode == 38 && event.shiftKey == true) {
445       // shift arrow up
446       event.preventDefault();
447       var row = $(event.target).parents(".row_entry").first();
448       $(row).children().not(':first').hide();
449       return false;
450     }
451   });
452
453   $(rows).dblclick(function(event) {
454       event.preventDefault();
455       var row = $(event.target).parents(".row_entry").first();
456       $(row).children().not(':first').toggle();
457       return false;
458   });
459 }
460
461 var email_dialog;
462
463 function show_email_dialog(html) {
464   var id            = 'jqueryui_popup_dialog';
465   var dialog_params = {
466     id:     id,
467     width:  800,
468     height: 500,
469     modal:  true,
470     close: function(event, ui) {
471       email_dialog.remove();
472     },
473   };
474
475   $('#' + id).remove();
476
477   email_dialog = $('<div style="display:none" id="' + id + '"></div>').appendTo('body');
478   email_dialog.html(html);
479   email_dialog.dialog(dialog_params);
480
481   $('.cancel').click(close_email_dialog);
482
483   return true;
484 }
485
486 close_email_dialog = function() {
487   email_dialog.dialog("close");
488 }
489
490
491 $(function(){
492   $('#order_[%- cv_id %]').change(reload_cv_dependend_selections);
493   [%- IF SELF.cv == 'customer' %]
494     $('#add_item_parts_id').on('set_item:PartPicker', function(e,o) { $('#add_item_sellprice_as_number').val(kivi.format_amount(o.sellprice, -2)) });
495   [%- ELSE %]
496     $('#add_item_parts_id').on('set_item:PartPicker', function(e,o) { $('#add_item_sellprice_as_number').val(kivi.format_amount(o.lastcost, -2)) });
497   [%- END %]
498   $('#add_item_parts_id').on('set_item:PartPicker', function(e,o) { $('#add_item_description').val(o.description) });
499   $('#add_item_parts_id').on('set_item:PartPicker', function(e,o) { $('#add_item_unit').val(o.unit) });
500   $('.add_item_input').keydown(function(event) {
501     if(event.keyCode == 13) {
502       event.preventDefault();
503       add_item();
504       return false;
505     }
506   });
507   row_set_keyboard_events($('.row_entry'));
508   $('.recalc').change(recalc_amounts_and_taxes);
509   $('.reformat_number').change(reformat_number);
510 });
511
512 </script>