Bug 31254: Add additional fields for accountlines
[srvgit] / koha-tmpl / intranet-tmpl / prog / en / modules / members / paycollect.tt
1 [% USE raw %]
2 [% USE Asset %]
3 [% USE Koha %]
4 [% USE Branches %]
5 [% USE Registers %]
6 [% USE Price %]
7 [% SET footerjs = 1 %]
8 [% PROCESS 'accounts.inc' %]
9 [% INCLUDE 'doc-head-open.inc' %]
10 [% BLOCK cash_register_required %]
11     <div id="error_message" class="dialog message">
12         <p>
13             You must have at least one cash register associated with the library before you can record payments.
14         </p>
15         [% IF ( CAN_user_parameters_manage_cash_registers ) %]
16             <form action="/cgi-bin/koha/admin/cash_registers.pl" method="get">
17                 <input type="hidden" name="op" value="add_form" />
18                 <button class="new" type="submit"><i class="fa fa-plus"></i> Create a new cash register</button>
19             </form>
20         [% END %]
21     </div>
22 [% END %]
23 [% SET registers = Registers.all( filters => { current_branch => 1 } ) %]
24 <title>
25     [% IF type == 'WRITEOFF' %]
26         Write off an amount for [% INCLUDE 'patron-title.inc' no_html = 1 %]
27     [% ELSE %]
28         Collect fine payment for [% INCLUDE 'patron-title.inc' no_html = 1 %]
29     [% END %] &rsaquo; Patrons &rsaquo; Koha
30 </title>
31 [% INCLUDE 'doc-head-close.inc' %]
32 </head>
33
34 <body id="pat_paycollect" class="pat">
35 [% INCLUDE 'header.inc' %]
36 [% INCLUDE 'patron-search-header.inc' %]
37
38 <nav id="breadcrumbs" aria-label="Breadcrumb" class="breadcrumb">
39     <ol>
40         <li>
41             <a href="/cgi-bin/koha/mainpage.pl">Home</a>
42         </li>
43         <li>
44             <a href="/cgi-bin/koha/members/members-home.pl">Patrons</a>
45         </li>
46         <li>
47             <a href="/cgi-bin/koha/members/pay.pl?borrowernumber=[% patron.borrowernumber | uri %]">Pay charges for [% INCLUDE 'patron-title.inc' %]</a>
48         </li>
49         <li>
50             <a href="#" aria-current="page">
51                 [% IF ( pay_individual ) %]
52                     <span>Pay an individual fine</span>
53                 [% ELSIF ( writeoff_individual ) %]
54                     <span>Write off an individual fine</span>
55                 [% ELSE %]
56                     [% IF ( selected_accts ) %]
57                         [% IF type == 'WRITEOFF' %]
58                             <span>Write off an amount toward selected fines</span>
59                         [% ELSE %]
60                             <span>Pay an amount toward selected fines</span>
61                         [% END %]
62                     [% ELSE %]
63                         <span>Pay an amount toward all fines</span>
64                     [% END %]
65                 [% END %]
66             </a>
67         </li>
68     </ol>
69 </nav>
70
71 <div class="main container-fluid">
72     <div class="row">
73         <div class="col-sm-10 col-sm-push-2">
74             <main>
75
76             <h1>
77                 [% IF ( pay_individual ) %]
78                     <span>Pay an individual fine</span>
79                 [% ELSIF ( writeoff_individual ) %]
80                     <span>Write off an individual fine</span>
81                 [% ELSE %]
82                     [% IF ( selected_accts ) %]
83                         [% IF type == 'WRITEOFF' %]
84                             <span>Write off an amount toward selected fines</span>
85                         [% ELSE %]
86                             <span>Pay an amount toward selected fines</span>
87                         [% END %]
88                     [% ELSE %]
89                         <span>Pay an amount toward all fines</span>
90                     [% END %]
91                 [% END %]
92             </h1>
93
94 [% INCLUDE 'members-toolbar.inc' borrowernumber=patron.borrowernumber %]
95
96 <!-- The manual invoice and credit buttons -->
97 <div class="statictabs">
98 <ul>
99     <li>
100     <a href="/cgi-bin/koha/members/boraccount.pl?borrowernumber=[% patron.borrowernumber | uri %]">Transactions</a>
101     </li>
102     <li class="active">
103     <a href="/cgi-bin/koha/members/pay.pl?borrowernumber=[% patron.borrowernumber | uri %]" >Make a payment</a>
104     </li>
105     <li>
106     <a href="/cgi-bin/koha/members/maninvoice.pl?borrowernumber=[% patron.borrowernumber | uri %]" >Create manual invoice</a>
107     </li>
108     <li>
109     <a href="/cgi-bin/koha/members/mancredit.pl?borrowernumber=[% patron.borrowernumber | uri %]" >Create manual credit</a>
110     </li>
111 </ul>
112 <div class="tabs-container">
113 [% IF ( error_over ) %]
114     <div id="error_message" class="dialog alert">
115     You must pay a value less than or equal to [% total_due | $Price %].
116     </div>
117 [% END %]
118 [% IF ( error_under ) %]
119     <div id="error_message" class="dialog alert">
120     You must collect a value greater than or equal to [% total_paid | $Price %].
121     </div>
122 [% END %]
123
124 [% IF ( pay_individual ) %]
125     [% IF Koha.Preference('UseCashRegisters') && ( registers.size == 0 ) %]
126         [% PROCESS 'cash_register_required' %]
127     [% ELSE %]
128
129     <ul class="nav nav-pills">
130         <li role="presentation" class="active"><a>Pay</a></li>
131         <li role="presentation"><a href="/cgi-bin/koha/members/paycollect.pl?writeoff_individual=1&borrowernumber=[% patron.borrowernumber | uri %]&debit_type_code=[% debit_type_code | uri %]&amount=[% amount | uri %]&amountoutstanding=[% amountoutstanding | uri %]&description=[% individual_description | uri %]&itemnumber=[% itemnumber | uri %]&accountlines_id=[% accountlines_id | uri %]&payment_note=[% payment_note | uri %]">Write off</a></li>
132     </ul>
133
134     <form name="payindivfine" id="payindivfine" method="post" action="/cgi-bin/koha/members/paycollect.pl">
135     <input type="hidden" name="csrf_token" value="[% csrf_token | html %]" />
136     <input type="hidden" name="borrowernumber" id="borrowernumber" value="[% patron.borrowernumber | html %]" />
137     <input type="hidden" name="pay_individual" id="pay_individual" value="[% pay_individual | html %]" />
138     <input type="hidden" name="itemnumber" id="itemnumber" value="[% itemnumber | html %]" />
139     <input type="hidden" name="description" id="description" value="[% individual_description | html %]" />
140     <input type="hidden" name="debit_type_code" id="debit_type_code" value="[% debit_type_code | html %]" />
141     <input type="hidden" name="amount" id="amount" value="[% amount | html %]" />
142     <input type="hidden" name="amountoutstanding" id="amountoutstanding" value="[% amountoutstanding | html %]" />
143     <input type="hidden" name="accountlines_id" id="accountlines_id" value="[% accountlines_id | html %]" />
144     <input type="hidden" name="change_given" id="change_given" />
145
146 <fieldset class="rows">
147     <legend>Pay an individual fine</legend>
148     <input type="hidden" name="payment_note" id="payment_note" value="[% payment_note | html %]" />
149     <table>
150     <thead><tr>
151             <th>Description</th>
152             <th>Account type</th>
153             <th>Amount</th>
154             <th>Amount outstanding</th>
155         </tr></thead>
156     <tfoot>
157         <tr><td colspan="3">Total amount payable:</td><td>[% amountoutstanding | $Price %]</td></tr>
158     </tfoot>
159     <tbody><tr>
160             <td>
161                 [% individual_description | html %]
162             </td>
163             [% line.debit_type_code = debit_type_code %]
164             <td>[% PROCESS account_type_description account=line %]</td>
165             <td class="debit">[% amount | $Price %]</td>
166             <td class="debit">[% amountoutstanding | $Price %]</td>
167         </tr></tbody>
168 </table>
169
170 <ol>
171
172     <li>
173         <label for="paid">Amount being paid: </label>
174         <input name="paid" id="paid" type="text" step="0.01" min="0" value="[% amountoutstanding | $Price on_editing => 1 %]"/>
175     </li>
176     <li>
177         <label for="collected">Amount tendered: </label>
178         <input name="collected" id="collected" type="text" step="0.01" min="0" value="[% amountoutstanding | $Price on_editing => 1 %]"/>
179     </li>
180     <li>
181         <label>Change to give: </label>
182         <span id="change">0.00</span>
183     </li>
184
185     [% INCLUDE 'transaction_types.inc' type="payment" %]
186
187     [% IF Koha.Preference('UseCashRegisters') %]
188     <li>
189         [% IF Koha.Preference('RequireCashRegister') %]
190             <label for="cash_register" class="required">
191         [% ELSE %]
192             <label for="cash_register">
193         [% END %]
194             Cash register:
195         </label>
196
197         [% IF Koha.Preference('RequireCashRegister') %]
198             <select name="cash_register" id="cash_register" required>
199         [% ELSE %]
200             <select name="cash_register" id="cash_register">
201         [% END %]
202             <option id="noregister" disabled selected="selected" value="">-- Select an option--</option>
203             [% PROCESS options_for_registers %]
204         </select>
205
206         [% IF Koha.Preference('RequireCashRegister') %]
207             <span class="required">Required</span>
208         [% END %]
209     </li>
210     [% END %]
211 </ol>
212 </fieldset>
213
214 [% IF available_additional_fields %]
215     [% INCLUDE 'additional-fields-entry.inc' available=available_additional_fields values=additional_field_values %]
216 [% END %]
217
218         <div class="action">
219             <input type="submit" name="submitbutton" value="Confirm" />
220             <a class="cancel" href="/cgi-bin/koha/members/pay.pl?borrowernumber=[% patron.borrowernumber | html %]">Cancel</a>
221         </div>
222     </form>
223     [% END %]
224 [% ELSIF ( writeoff_individual ) %]
225     <ul class="nav nav-pills">
226         <li role="presentation"><a href="/cgi-bin/koha/members/paycollect.pl?pay_individual=1&borrowernumber=[% patron.borrowernumber | uri %]&debit_type_code=[% debit_type_code | uri %]&amount=[% amount | uri %]&amountoutstanding=[% amountoutstanding | uri %]&description=[% individual_description | uri %]&itemnumber=[% itemnumber | uri %]&accountlines_id=[% accountlines_id | uri %]&payment_note=[% payment_note | uri %]">Pay</a></li>
227         <li role="presentation" class="active"><a>Write off</a></li>
228     </ul>
229
230     <form name="woindivfine" id="woindivfine" action="/cgi-bin/koha/members/pay.pl" method="post" >
231     <input type="hidden" name="csrf_token" value="[% csrf_token | html %]" />
232     <fieldset class="rows">
233     <legend>Write off an individual fine</legend>
234     <input type="hidden" name="borrowernumber" id="borrowernumber" value="[% patron.borrowernumber | html %]" />
235     <input type="hidden" name="pay_individual" id="pay_individual" value="[% pay_individual | html %]" />
236     <input type="hidden" name="itemnumber" id="itemnumber" value="[% itemnumber | html %]" />
237     <input type="hidden" name="description" id="description" value="[% individual_description | html %]" />
238     <input type="hidden" name="debit_type_code" id="debit_type_code" value="[% debit_type_code | html %]" />
239     <input type="hidden" name="amount" id="amount" value="[% amount | html %]" />
240     <input type="hidden" name="accountlines_id" id="accountlines_id" value="[% accountlines_id | html %]" />
241     <input type="hidden" name="payment_note" id="payment_note" value="[% payment_note | html %]" />
242     <input type="hidden" name="amountoutstanding" id="amountoutstanding" value="[% amountoutstanding | html %]" />
243     <input type="hidden" name="confirm_writeoff" id="confirm_writeoff" value="1" />
244     <input type="hidden" name="change_given" id="change_given" />
245     <table>
246     <thead><tr>
247             <th>Description</th>
248             <th>Account type</th>
249             <th>Amount</th>
250             <th>Amount outstanding</th>
251         </tr></thead>
252     <tfoot><tr><td colspan="3">Total amount outstanding:</td><td>[% amountoutstanding | $Price %]</td></tr></tfoot>
253     <tbody><tr>
254             <td>[% individual_description | html %]</td>
255             [% line.debit_type_code = debit_type_code %]
256             <td>[% PROCESS account_type_description account=line %]</td>
257             <td class="debit">[% amount | $Price %]</td>
258             <td class="debit">[% amountoutstanding | $Price %]</td>
259         </tr></tbody>
260     </table>
261
262             <ol>
263                 <li>
264                     <label for="amountwrittenoff">Writeoff amount: </label>
265                     <!-- default to writing off all -->
266                     <input name="amountwrittenoff" id="amountwrittenoff" value="[% amountoutstanding | $Price on_editing => 1 %]" type="text" />
267                 </li>
268             </ol>
269         </fieldset>
270
271         [% IF available_additional_fields %]
272             [% INCLUDE 'additional-fields-entry.inc' available=available_additional_fields values=additional_field_values %]
273         [% END %]
274
275         <div class="action">
276             <input type="submit" value="Write off this charge" />
277             <a class="cancel" href="/cgi-bin/koha/members/pay.pl?borrowernumber=[% patron.borrowernumber | html %]">Cancel</a>
278         </div>
279     </form>
280 [% ELSE %]
281     [% IF Koha.Preference('UseCashRegisters') && ( registers.size == 0 ) && ( type != 'WRITEOFF' ) %]
282         [% PROCESS 'cash_register_required' %]
283     [% ELSE %]
284
285     [% IF selected_accts %]
286         <ul class="nav nav-pills">
287             [% IF type == 'WRITEOFF' %]
288                 <li role="presentation"><a href="/cgi-bin/koha/members/paycollect.pl?borrowernumber=[% patron.borrowernumber | uri %]&type=PAYMENT&amt=[% amt | uri %]&selected=[% selected_accts | uri %]&notes=[% selected_accts_notes | uri %]">Pay</a></li>
289                 <li role="presentation" class="active"><a>Write off</a></li>
290             [% ELSE %]
291                 <li role="presentation" class="active"><a>Pay</a></li>
292                 <li role="presentation"><a href="/cgi-bin/koha/members/paycollect.pl?borrowernumber=[% patron.borrowernumber | uri %]&type=WRITEOFF&amt=[% amt | uri %]&selected=[% selected_accts | uri %]&notes=[% selected_accts_notes | uri %]">Write off</a></li>
293             [% END %]
294         </ul>
295     [% END %]
296
297     <form name="payfine" id="payfine" method="post" action="/cgi-bin/koha/members/paycollect.pl">
298     <input type="hidden" name="csrf_token" value="[% csrf_token | html %]" />
299     <input type="hidden" name="borrowernumber" id="borrowernumber" value="[% patron.borrowernumber | html %]" />
300     <input type="hidden" name="selected_accts" id="selected_accts" value="[% selected_accts | html %]" />
301     <input type="hidden" name="total" id="total" value="[% total | html %]" />
302     <input type="hidden" name="type" value="[% type | html %]" />
303     <input type="hidden" name="change_given" id="change_given" />
304
305     <fieldset class="rows">
306     [% IF ( selected_accts ) %]
307         [% IF type == 'WRITEOFF' %]
308             <legend>Write off an amount toward selected fines</legend>
309         [% ELSE %]
310             <legend>Pay an amount toward selected fines</legend>
311         [% END %]
312     [% ELSE %]
313         <legend>Pay an amount toward all fines</legend>
314     [% END %]
315
316     <ol>
317         <li>
318             <span class="label">Total amount outstanding: </span>
319             <span class="debit">[% total | $Price %]</span>
320         </li>
321     <li>
322         [% IF type == 'WRITEOFF' %]
323             <label for="paid">Writeoff amount: </label>
324         [% ELSE %]
325             <label for="paid">Amount being paid: </label>
326         [% END %]
327         <input name="paid" id="paid" type="text" step="0.01" min="0" value="[% total | $Price on_editing => 1 %]"/>
328     </li>
329     [% IF type != 'WRITEOFF' %]
330         <li>
331             <label for="collected">Amount tendered: </label>
332             <input name="collected" id="collected" type="text" step="0.01" min="0" value="[% total | $Price on_editing => 1 %]"/>
333         </li>
334         <li>
335             <label>Change to give: </label>
336             <span id="change">0.00</span>
337         </li>
338
339     [% INCLUDE 'transaction_types.inc' type="payment" %]
340
341     [% IF Koha.Preference('UseCashRegisters') %]
342     <li>
343         <label for="cash_register">Cash register: </label>
344         <select name="cash_register" id="cash_register">
345             <option id="noregister" disabled selected="selected" value="">-- Select an option--</option>
346             [% PROCESS options_for_registers %]
347         </select>
348     </li>
349     [% END %]
350     [% END %]
351
352     <li>
353         <label for="selected_accts_notes">Note: </label>
354         <textarea name="selected_accts_notes" id="selected_accts_notes">[% selected_accts_notes | html %]</textarea>
355     </li>
356     </ol>
357     </fieldset>
358
359     [% IF available_additional_fields %]
360         [% INCLUDE 'additional-fields-entry.inc' available=available_additional_fields values=additional_field_values %]
361     [% END %]
362
363     <div class="action">
364         <input type="submit" name="submitbutton" value="Confirm" />
365         <a class="cancel" href="/cgi-bin/koha/members/pay.pl?borrowernumber=[% patron.borrowernumber | html %]">Cancel</a>
366     </div>
367     </form>
368     [% END %]
369 [% END %]
370 </div></div>
371
372             </main>
373         </div> <!-- /.col-sm-10.col-sm-push-2 -->
374
375         <div class="col-sm-2 col-sm-pull-10">
376             <aside>
377                 [% INCLUDE 'circ-menu.inc' %]
378             </aside>
379         </div> <!-- /.col-sm-2.col-sm-pull-10 -->
380      </div> <!-- /.row -->
381
382 <!-- Modal -->
383 <div id="confirm_change_form" class="modal" tabindex="-1" role="dialog" aria-hidden="true">
384     <div class="modal-dialog">
385         <div class="modal-content">
386             <div class="modal-header">
387                 <h3>The amount collected is more than the outstanding charge</h3>
388             </div>
389             <div class="modal-body">
390                 <p>The amount collected from the patron is higher than the amount to be paid.</p>
391                 <p>The change to give is <strong><span id="modal_change">0.00</span></strong>.</p>
392                 <p>Confirm this payment?</p>
393             </div>
394             <div class="modal-footer">
395                 <button class="btn btn-default approve" id="modal_submit" type="button"><i class="fa fa-check"></i> Yes</button>
396                 <button class="btn btn-default deny cancel" href="#" data-dismiss="modal" aria-hidden="true"><i class="fa fa-times"></i> No</button>
397             </div>
398         </div>
399     </div>
400 </div>
401
402 [% MACRO jsinclude BLOCK %]
403     [% INCLUDE 'str/members-menu.inc' %]
404     [% Asset.js("js/members-menu.js") | $raw %]
405     <script>
406         $(document).ready(function() {
407             [% IF payment_id && Koha.Preference('FinePaymentAutoPopup') %]
408                 window.open('/cgi-bin/koha/members/printfeercpt.pl?action=print&accountlines_id=[% payment_id | html %]&change_given=[% change_given | html %]&borrowernumber=[% patron.borrowernumber | html %]', '_blank');
409             [% END %]
410
411             var forms = $('#payindivfine, #payfine');
412             var change = $('#change')[0];
413
414             $('#payindivfine, #payfine').preventDoubleFormSubmit();
415             $("#paid, #collected").on("change",function() {
416                 moneyFormat( this );
417                 if (change != undefined) {
418                     updateChangeValues();
419                 }
420             });
421
422             if (change != undefined) {
423                 forms.on("submit", function(e) {
424                     if (change.innerHTML > 0.00) {
425                         e.preventDefault();
426                         $("#confirm_change_form").modal("show");
427                     } else {
428                         return true;
429                     }
430                 });
431             }
432
433             $("#confirm_change_form").on("hidden.bs.modal", function(){
434                 // remove class added by preventDoubleFormSubmit if necessary
435                 $("body, form input[type='submit'], form button[type='submit'], form a").removeClass('waiting');
436             });
437
438             $('#modal_submit').click(function() {
439                 forms[0].submit();
440             });
441
442             $( "#payindivfine, #payfine" ).validate({
443                 rules: {
444                     paid: { required: true },
445                     collected: {
446                         required: true
447                     },
448                     [% IF Koha.Preference('UseCashRegisters') %]
449                     cash_register: {
450                         [% IF Koha.Preference('RequireCashRegister') %]
451                             required: true
452                         [% ELSE %]
453                             required: function() {
454                                 return $('#payment_type').val() == 'CASH'
455                             }
456                         [% END %]
457                     }
458                     [% END %]
459                 },
460                 invalidHandler: function(event, validator) {
461                     // reset beenSubmitted for prevenDoubleFormSubmit
462                     event.target.beenSubmitted = false;
463                     // remove class added by preventDoubleFormSubmit
464                     $("body, form input[type='submit'], form button[type='submit'], form a").removeClass('waiting');
465                 }
466             });
467         });
468
469         prevent_default = 1;
470         $('#woindivfine').on('submit', function(e){
471             if ( prevent_default ) {
472                 e.preventDefault();
473
474                 let amount_outstanding = parseFloat( $('#amountoutstanding').attr('value') );
475                 let amount_writeoff = parseFloat( $('#amountwrittenoff').attr('value') );
476                 if ( amount_writeoff > amount_outstanding ) {
477                     alert(_("You are attemping to writeoff more than the value of the fee."));
478                     $('#woindivfine').beenSubmitted = false;
479                 } else {
480                     prevent_default = 0;
481                     $('#woindivfine').preventDoubleFormSubmit();
482                     $('#woindivfine').submit();
483                 }
484             }
485         });
486
487         function moneyFormat(textObj) {
488             var newValue = textObj.value;
489             var decAmount = "";
490             var dolAmount = "";
491             var dolFlag   = false;
492             var aChar     = "";
493
494             for(var i = newValue.length; 0 < i; i--) {
495                 aChar = newValue.substring(i-1, i);
496                 if ("0" <= aChar && aChar <= "9") {
497                     if(dolFlag) {
498                         dolAmount = "" + aChar + dolAmount;
499                     }
500                     else {
501                         decAmount = "" + aChar + decAmount;
502                     }
503                 }
504                 if (aChar == "." || aChar == ",") {
505                     dolFlag = true;
506                 }
507             }
508
509             if (!dolFlag) {
510                 dolAmount = decAmount;
511                 decAmount = "";
512             }
513
514             if (dolAmount == "") {
515                 dolAmount = "0";
516             }
517         // Strip leading 0s
518             if (dolAmount.length > 1) {
519                 while(dolAmount.length > 1 && dolAmount.substring(0,1) == "0") {
520                     dolAmount = dolAmount.substring(1,dolAmount.length);
521                 }
522             }
523             if (decAmount.length > 2) {
524                 decAmount = decAmount.substring(0,2);
525             }
526         // Pad right side
527             if (decAmount.length == 1) {
528                decAmount = decAmount + "0";
529             }
530             if (decAmount.length == 0) {
531                decAmount = decAmount + "00";
532             }
533
534             textObj.value = dolAmount + "." + decAmount;
535         }
536
537         function updateChangeValues() {
538             var change = $('#change')[0];
539             change.innerHTML = Math.round(($('#collected')[0].value - $('#paid')[0].value) * 100) / 100;
540             if (change.innerHTML <= 0) {
541                 var paid = $('#paid')[0];
542                 moneyFormat(paid);
543                 $('#collected').rules( "add", { min: Number(paid.value) });
544                 $( "#payindivfine, #payfine" ).valid();
545                 change.innerHTML = "0.00";
546                 $('input[name="change_given"]').val('0.00');
547             } else {
548                 change.value = change.innerHTML;
549                 moneyFormat(change);
550                 change.innerHTML = change.value;
551                 $('input[name="change_given"]').val(change.value);
552             }
553
554             $('#modal_change').html(change.innerHTML);
555         }
556     </script>
557 [% END %]
558
559 [% INCLUDE 'intranet-bottom.inc' %]