CRM-20264 support card_type_id and pan_truncation in all backoffice form
[civicrm-core.git] / templates / CRM / Contribute / Form / Contribution.tpl
1 {*
2 +--------------------------------------------------------------------+
3 | CiviCRM version 4.7 |
4 +--------------------------------------------------------------------+
5 | Copyright CiviCRM LLC (c) 2004-2017 |
6 +--------------------------------------------------------------------+
7 | This file is a part of CiviCRM. |
8 | |
9 | CiviCRM is free software; you can copy, modify, and distribute it |
10 | under the terms of the GNU Affero General Public License |
11 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
12 | |
13 | CiviCRM is distributed in the hope that it will be useful, but |
14 | WITHOUT ANY WARRANTY; without even the implied warranty of |
15 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
16 | See the GNU Affero General Public License for more details. |
17 | |
18 | You should have received a copy of the GNU Affero General Public |
19 | License and the CiviCRM Licensing Exception along |
20 | with this program; if not, contact CiviCRM LLC |
21 | at info[AT]civicrm[DOT]org. If you have questions about the |
22 | GNU Affero General Public License or the licensing of CiviCRM, |
23 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
24 +--------------------------------------------------------------------+
25 *}
26 {* this template is used for adding/editing/deleting contributions and pledge payments *}
27
28 {if $priceSetId}
29 {include file="CRM/Price/Form/PriceSet.tpl" context="standalone" extends="Contribution"}
30 {elseif $showAdditionalInfo and $formType }
31 {include file="CRM/Contribute/Form/AdditionalInfo/$formType.tpl"}
32 {else}
33 {include file="CRM/Contribute/Form/AdditionalInfo/Payment.tpl"}
34 <div class="crm-block crm-form-block crm-contribution-form-block">
35
36 {if !$email and $action neq 8 and $context neq 'standalone'}
37 <div class="messages status no-popup">
38 <div class="icon inform-icon"></div>&nbsp;{ts}You will not be able to send an automatic email receipt for this contribution because there is no email address recorded for this contact. If you want a receipt to be sent when this contribution is recorded, click Cancel and then click Edit from the Summary tab to add an email address before recording the contribution.{/ts}
39 </div>
40 {/if}
41 {if $contributionMode}
42 <div class="help">
43 {if $contactId && $payNow}
44 {ts 1=$displayName 2=$contributionMode|upper}Use this form to edit a contribution on behalf of %1. <strong>A
45 %2 transaction will be submitted</strong> using the selected payment processor.{/ts}
46 {elseif $contactId}
47 {ts 1=$displayName 2=$contributionMode|upper}Use this form to submit a new contribution on behalf of %1. <strong>A
48 %2 transaction will be submitted</strong> using the selected payment processor.{/ts}
49 {else}
50 {ts 1=$displayName 2=$contributionMode|upper}Use this form to submit a new contribution. <strong>A %2 transaction will be submitted</strong> using the selected payment processor.{/ts}
51 {/if}
52 </div>
53 {/if}
54 {if $action eq 8}
55 <div class="messages status no-popup">
56 <div class="icon inform-icon"></div>
57 {ts}WARNING: Deleting this contribution will result in the loss of the associated financial transactions (if any).{/ts} {ts}Do you want to continue?{/ts}
58 </div>
59 {else}
60 {if $newCredit AND $action EQ 1 AND $contributionMode EQ null}
61 <div class="action-link css_right crm-link-credit-card-mode">
62 {if $contactId}
63 {capture assign=ccModeLink}{crmURL p='civicrm/contact/view/contribution' q="reset=1&action=add&cid=`$contactId`&context=`$context`&mode=live"}{/capture}
64 {else}
65 {capture assign=ccModeLink}{crmURL p='civicrm/contact/view/contribution' q="reset=1&action=add&context=standalone&mode=live"}{/capture}
66 {/if}
67 <a class="open-inline-noreturn action-item crm-hover-button" href="{$ccModeLink}">&raquo; {ts}submit credit card contribution{/ts}</a>
68 </div>
69 {/if}
70 <div class="crm-submit-buttons">
71 {include file="CRM/common/formButtons.tpl"}
72 </div>
73 {if $isOnline}{assign var=valueStyle value=" class='view-value'"}{else}{assign var=valueStyle value=""}{/if}
74 <table class="form-layout-compressed">
75 {if $context neq 'standalone'}
76 <tr>
77 <td class="font-size12pt label"><strong><strong>{ts}Contributor{/ts}</strong></td><td class="font-size12pt"><strong>{$displayName}</strong></td>
78 </tr>
79 {else}
80 <td class="label">{$form.contact_id.label}</td>
81 <td>{$form.contact_id.html}</td>
82 {/if}
83 {if $contributionMode}
84 <tr class="crm-contribution-form-block-payment_processor_id"><td class="label nowrap">{$form.payment_processor_id.label}<span class="crm-marker"> * </span></td><td>{$form.payment_processor_id.html}</td></tr>
85 {/if}
86 <tr class="crm-contribution-form-block-contribution_type_id crm-contribution-form-block-financial_type_id">
87 <td class="label">{$form.financial_type_id.label}</td><td{$valueStyle}>{$form.financial_type_id.html}&nbsp;
88 {if $is_test}
89 {ts}(test){/ts}
90 {/if} {help id="id-financial_type"}
91 </td>
92 </tr>
93 {if $action eq 2 and $lineItem and !$defaultContribution}
94 <tr>
95 <td class="label">{ts}Contribution Amount{/ts}</td>
96 <td>{include file="CRM/Price/Page/LineItem.tpl" context="Contribution"}</td>
97 </tr>
98 {else}
99 <tr class="crm-contribution-form-block-total_amount">
100 <td class="label">{$form.total_amount.label}</td>
101 <td {$valueStyle}>
102 <span id='totalAmount'>{$form.currency.html|crmAddClass:eight}&nbsp;{$form.total_amount.html|crmAddClass:eight}</span>
103 {if !$payNow}
104 {if $hasPriceSets}
105 <span id='totalAmountORPriceSet'> {ts}OR{/ts}</span>
106 <span id='selectPriceSet'>{$form.price_set_id.html}</span>
107 <div id="priceset" class="hiddenElement"></div>
108 {/if}
109
110 {if $ppID}{ts}<a href='#' onclick='adjustPayment();'>adjust payment amount</a>{/ts}{help id="adjust-payment-amount"}{/if}
111 <div id="totalAmountBlock">
112 {if $hasPriceSets}<span class="description">{ts}Alternatively, you can use a price set.{/ts}</span>{/if}
113 <div id="totalTaxAmount" class="label"></div>
114 </div>
115 {/if}
116 </td>
117 </tr>
118
119 {if $buildRecurBlock && !$payNow}
120 <tr id='recurringPaymentBlock' class='hiddenElement'>
121 <td></td>
122 <td>
123 <strong>{$form.is_recur.html} {ts}every{/ts}
124 &nbsp;{$form.frequency_interval.html}
125 &nbsp;{$form.frequency_unit.html}&nbsp;
126 {ts}for{/ts}
127 &nbsp;{$form.installments.html}
128 &nbsp;{$form.installments.label}
129 </strong>
130 <br />
131 <span class="description">
132 {ts}Your recurring contribution will be processed automatically for the number of installments you specify. You can leave the number of installments blank if you want to make an open-ended commitment. In either case, you can choose to cancel at any time. You will receive an email receipt for each recurring contribution. The receipts will include a link you can use if you decide to modify or cancel your future contributions.{/ts}
133 </span>
134 </td>
135 </tr>
136 {/if}
137
138 <tr id="adjust-option-type" class="crm-contribution-form-block-option_type">
139 <td class="label"></td><td {$valueStyle}>{$form.option_type.html}</td>
140 </tr>
141 {/if}
142 {if $contributionMode && $processorSupportsFutureStartDate}
143 <tr id='start_date' class="crm-contribution-form-block-receive_date">
144 <td class="label">{ts}Start Date{/ts}</td>
145 <td {$valueStyle}>{if $hideCalender neq true}{include file="CRM/common/jcalendar.tpl" elementName=receive_date}{else}{$receive_date|crmDate}{/if}<br />
146 <span class="description">{ts}You can set a start date for recurring contributions and the first payment will be on that date. For a single post-dated contribution you must select recurring and choose one installment{/ts}</span>
147 </td>
148 </tr>
149 {/if}
150
151 <tr class="crm-contribution-form-block-source">
152 <td class="label">{$form.source.label}</td>
153 <td {$valueStyle}>{$form.source.html|crmAddClass:huge} {help id="id-contrib_source"}
154 </td>
155 </tr>
156
157 {* CRM-7362 --add campaign to contributions *}
158 {include file="CRM/Campaign/Form/addCampaignToComponent.tpl" campaignTrClass="crm-contribution-form-block-campaign_id"}
159
160 {if $contributionMode}
161 {if $email and $outBound_option != 2}
162 <tr class="crm-contribution-form-block-is_email_receipt">
163 <td class="label">{$form.is_email_receipt.label}</td>
164 <td>{$form.is_email_receipt.html}&nbsp; <span class="description">{ts 1=$email}Automatically email a receipt for this contribution to %1?{/ts}</span>
165 </td>
166 </tr>
167 {elseif $context eq 'standalone' and $outBound_option != 2 }
168 <tr id="email-receipt" style="display:none;" class="crm-contribution-form-block-is_email_receipt"><td class="label">{$form.is_email_receipt.label}</td><td>{$form.is_email_receipt.html} <span class="description">{ts}Automatically email a receipt for this contribution to {/ts}<span id="email-address"></span>?</span></td></tr>
169 {/if}
170 <tr id="fromEmail" style="display:none;" >
171 <td class="label">{$form.from_email_address.label}</td>
172 <td>{$form.from_email_address.html}</td>
173 </tr>
174 <tr id="receiptDate" class="crm-contribution-form-block-receipt_date">
175 <td class="label">{$form.receipt_date.label}</td>
176 <td>{include file="CRM/common/jcalendar.tpl" elementName=receipt_date}<br />
177 <span class="description">{ts}Date that a receipt was sent to the contributor.{/ts}</span>
178 </td>
179 </tr>
180 {/if}
181 {if !$contributionMode || $payNow}
182 <tr class="crm-contribution-form-block-contribution_status_id">
183 <td class="label">{$form.contribution_status_id.label}</td>
184 <td>{$form.contribution_status_id.html}
185 {if $contribution_status_id eq 2}{if $is_pay_later }: {ts}Pay Later{/ts} {else}: {ts}Incomplete Transaction{/ts}{/if}{/if}
186 </td>
187 <td>
188 {if $contactId && $contribID && $contributionMode EQ null && $contribution_status_id eq 2}
189 {capture assign=payNowLink}{crmURL p='civicrm/contact/view/contribution' q="reset=1&action=update&id=`$contribID`&cid=`$contactId`&context=`$context`&mode=live"}{/capture}
190 <a class="open-inline action-item crm-hover-button" href="{$payNowLink}">&raquo; {ts}Pay with Credit Card{/ts}</a>
191 {/if}
192 </td>
193 </tr>
194 {/if}
195
196 {if !$contributionMode}
197 {* Cancellation / Refunded fields are hidden unless contribution status is set to Cancelled or Refunded*}
198 <tr id="cancelInfo" class="crm-contribution-form-block-cancelInfo">
199 <td>&nbsp;</td>
200 <td><fieldset><legend>{ts}Cancellation or Refund Information{/ts}</legend>
201 <table class="form-layout-compressed">
202 <tr id="cancelDate" class="crm-contribution-form-block-cancel_date">
203 <td class="label">{$form.cancel_date.label}</td>
204 <td>
205 {if $hideCalendar neq true}
206 {include file="CRM/common/jcalendar.tpl" elementName=cancel_date}
207 {else}
208 {$form.cancel_date.value|crmDate}
209 {/if}
210 </td>
211 </tr>
212 <tr id="cancelDescription" class="crm-contribution-form-block-cancel_reason">
213 <td class="label">&nbsp;</td>
214 <td class="description">{ts}Enter the cancellation or refunded date, or you can skip this field and the cancellation date or refunded date will be automatically set to TODAY.{/ts}</td>
215 </tr>
216 <tr id="cancelReason">
217 <td class="label" style="vertical-align: top;">{$form.cancel_reason.label}</td>
218 <td>{$form.cancel_reason.html}</td>
219 </tr>
220 <tr id="refundTrxnID">
221 <td class="label" style="vertical-align: top;">{$form.refund_trxn_id.label}</td>
222 <td>{$form.refund_trxn_id.html}</td>
223 </tr>
224 </table>
225 </fieldset>
226 </td>
227 </tr>
228 {/if}
229 {if $form.revenue_recognition_date && !$payNow}
230 <tr class="crm-contribution-form-block-revenue_recognition_date">
231 <td class="label">{$form.revenue_recognition_date.label}</td>
232 <td>{$form.revenue_recognition_date.html}</td>
233 </tr>
234 {/if}
235 </table>
236
237 {if !$contributionMode}
238 <fieldset class="payment-details_group">
239 <legend>
240 {ts}Payment Details{/ts}
241 </legend>
242 <table class="form-layout-compressed" >
243 <tr class="crm-contribution-form-block-receive_date">
244 <td class="label">{$form.receive_date.label}</td>
245 <td {$valueStyle}>{include file="CRM/common/jcalendar.tpl" elementName=receive_date}<br />
246 <span class="description">{ts}The date this contribution was received.{/ts}</span>
247 </td>
248 </tr>
249 <tr class="crm-contribution-form-block-payment_instrument_id">
250 <td class="label">{$form.payment_instrument_id.label}</td>
251 <td {$valueStyle}>{$form.payment_instrument_id.html} {help id="payment_instrument_id"}</td>
252 </td>
253 </tr>
254 {if $showCheckNumber || !$isOnline}
255 <tr id="checkNumber" class="crm-contribution-form-block-check_number">
256 <td class="label">{$form.check_number.label}</td>
257 <td>{$form.check_number.html}</td>
258 </tr>
259 {/if}
260 <tr class="crm-contribution-form-block-trxn_id">
261 <td class="label">{$form.trxn_id.label}</td>
262 <td {$valueStyle}>{$form.trxn_id.html} {help id="id-trans_id"}</td>
263 </tr>
264 {if $email and $outBound_option != 2}
265 <tr class="crm-contribution-form-block-is_email_receipt">
266 <td class="label">
267 {$form.is_email_receipt.label}</td><td>{$form.is_email_receipt.html}&nbsp;
268 <span class="description">{ts 1=$email}Automatically email a receipt for this payment to %1?{/ts}</span>
269 </td>
270 </tr>
271 {elseif $context eq 'standalone' and $outBound_option != 2 }
272 <tr id="email-receipt" style="display:none;" class="crm-contribution-form-block-is_email_receipt">
273 <td class="label">{$form.is_email_receipt.label}</td>
274 <td>{$form.is_email_receipt.html} <span class="description">{ts}Automatically email a receipt for this payment to {/ts}<span id="email-address"></span>?</span>
275 </td>
276 </tr>
277 {/if}
278 <tr id="receiptDate" class="crm-contribution-form-block-receipt_date">
279 <td class="label">{$form.receipt_date.label}</td>
280 <td>{include file="CRM/common/jcalendar.tpl" elementName=receipt_date}<br />
281 <span class="description">{ts}Date that a receipt was sent to the contributor.{/ts}</span>
282 </td>
283 </tr>
284 <tr id="fromEmail" class="crm-contribution-form-block-receipt_date" style="display:none;">
285 <td class="label">{$form.from_email_address.label}</td>
286 <td>{$form.from_email_address.html}</td>
287 </tr>
288 </table>
289 </fieldset>
290 {/if}
291
292 {include file='CRM/Core/BillingBlockWrapper.tpl'}
293
294 <!-- start of soft credit -->
295 {if !$payNow}
296 <div class="crm-accordion-wrapper crm-accordion_title-accordion crm-accordion-processed {if $noSoftCredit}collapsed{/if}" id="softCredit">
297 <div class="crm-accordion-header">
298 {ts}Soft Credit{/ts}&nbsp;{help id="id-soft_credit"}
299 </div>
300 <div class="crm-accordion-body">
301 <table class="form-layout-compressed">
302 <tr class="crm-contribution-form-block-soft_credit_to">
303 <td colspan="2">
304 {include file="CRM/Contribute/Form/SoftCredit.tpl"}
305 </td>
306 </tr>
307 </table>
308 </div>
309 </div>
310 {/if}
311 <!-- end of soft credit -->
312
313 <!-- start of PCP -->
314 {if $siteHasPCPs && !$payNow}
315 <div class="crm-accordion-wrapper crm-accordion_title-accordion crm-accordion-processed {if $noPCP}collapsed{/if}" id="softCredit">
316 <div class="crm-accordion-header">
317 {ts}Personal Campaign Page{/ts}&nbsp;{help id="id-pcp"}
318 </div>
319 <div class="crm-accordion-body">
320 <table class="form-layout-compressed">
321 <tr class="crm-contribution-pcp-block crm-contribution-form-block-pcp_made_through_id">
322 <td class="label">{$form.pcp_made_through_id.label}</td>
323 <td>
324 {$form.pcp_made_through_id.html} &nbsp;
325 <div class="description">{ts}Search for the Personal Campaign Page by the fund-raiser's last name or email address.{/ts}</div>
326
327 <div class="spacer"></div>
328 <div class="crm-contribution-form-block-pcp_details">
329 <table class="crm-contribution-form-table-credit_to_pcp">
330 <tr id="pcpDisplayRollID" class="crm-contribution-form-block-pcp_display_in_roll">
331 <td class="label">{$form.pcp_display_in_roll.label}</td>
332 <td>{$form.pcp_display_in_roll.html}</td>
333 </tr>
334 <tr id="nickID" class="crm-contribution-form-block-pcp_roll_nickname">
335 <td class="label">{$form.pcp_roll_nickname.label}</td>
336 <td>{$form.pcp_roll_nickname.html|crmAddClass:big}<br/>
337 <div class="description">{ts}Name or nickname contributor wants to be displayed in the Honor Roll. Enter "Anonymous" for anonymous contributions.{/ts}</div>
338 </td>
339 </tr>
340 <tr id="personalNoteID" class="crm-contribution-form-block-pcp_personal_note">
341 <td class="label" style="vertical-align: top">{$form.pcp_personal_note.label}</td>
342 <td>
343 {$form.pcp_personal_note.html}
344 <div
345 class="description">{ts}Personal message submitted by contributor for display in the Honor Roll.{/ts}</div>
346 </td>
347 </tr>
348 </table>
349 </div>
350 </td>
351 </tr>
352 </table>
353 </div>
354 </div>
355 {include file="CRM/Contribute/Form/PCP.js.tpl"}
356 {/if}
357 <!-- end of PCP -->
358
359 {if !$payNow}
360 <div id="customData" class="crm-contribution-form-block-customData"></div>
361 {/if}
362
363 {*include custom data js file*}
364 {include file="CRM/common/customData.tpl"}
365
366 {literal}
367 <script type="text/javascript">
368 CRM.$(function($) {
369 {/literal}
370 CRM.buildCustomData( '{$customDataType}' );
371 {if $customDataSubType}
372 CRM.buildCustomData( '{$customDataType}', {$customDataSubType} );
373 {/if}
374
375 {if $buildPriceSet}{literal}buildAmount( );{/literal}{/if}
376 {literal}
377 });
378
379 // bind first click of accordion header to load crm-accordion-body with snippet
380 // everything else taken care of by cj().crm-accordions()
381 CRM.$(function($) {
382 cj('#adjust-option-type').hide();
383 cj('.crm-ajax-accordion .crm-accordion-header').one('click', function() {
384 loadPanes(cj(this).attr('id'));
385 });
386 cj('.crm-ajax-accordion:not(.collapsed) .crm-accordion-header').each(function(index) {
387 loadPanes(cj(this).attr('id'));
388 });
389 });
390 // load panes function calls for snippet based on id of crm-accordion-header
391 function loadPanes( id ) {
392 var url = "{/literal}{crmURL p='civicrm/contact/view/contribution' q='snippet=4&formType=' h=0}{literal}" + id;
393 {/literal}
394 {if $contributionMode}
395 url = url + "&mode={$contributionMode}";
396 {/if}
397 {if $qfKey}
398 url = url + "&qfKey={$qfKey}";
399 {/if}
400 {literal}
401 if (! cj('div.'+id).html()) {
402 var loading = '<img src="{/literal}{$config->resourceBase}i/loading.gif{literal}" alt="{/literal}{ts escape='js'}loading{/ts}{literal}" />&nbsp;{/literal}{ts escape='js'}Loading{/ts}{literal}...';
403 cj('div.'+id).html(loading);
404 cj.ajax({
405 url : url,
406 success: function(data) { cj('div.'+id).html(data).trigger('crmLoad'); }
407 });
408 }
409 }
410
411 var url = "{/literal}{$dataUrl}{literal}";
412
413 {/literal}
414 {if $context eq 'standalone' and $outBound_option != 2 }
415 {literal}
416 CRM.$(function($) {
417
418 var $form = $("form.{/literal}{$form.formClass}{literal}");
419 $("#contact_id", $form).change(checkEmail);
420 checkEmail( );
421
422 function checkEmail( ) {
423 var data = $("#contact_id", $form).select2('data');
424 if (data && data.extra && data.extra.email && data.extra.email.length) {
425 $("#email-receipt", $form).show();
426 $("#email-address", $form).html(data.extra.email);
427 }
428 else {
429 $("#email-receipt", $form).hide();
430 }
431 }
432
433 showHideByValue( 'is_email_receipt', '', 'receiptDate', 'table-row', 'radio', true);
434 showHideByValue( 'is_email_receipt', '', 'fromEmail', 'table-row', 'radio', false );
435 });
436
437 {/literal}
438 {/if}
439 </script>
440
441 <div class="accordion ui-accordion ui-widget ui-helper-reset">
442 {* Additional Detail / Honoree Information / Premium Information *}
443 {foreach from=$allPanes key=paneName item=paneValue}
444
445 <div class="crm-accordion-wrapper crm-ajax-accordion crm-{$paneValue.id}-accordion {if $paneValue.open neq 'true'}collapsed{/if}">
446 <div class="crm-accordion-header" id="{$paneValue.id}">
447
448 {$paneName}
449 </div><!-- /.crm-accordion-header -->
450 <div class="crm-accordion-body">
451
452 <div class="{$paneValue.id}"></div>
453 </div><!-- /.crm-accordion-body -->
454 </div><!-- /.crm-accordion-wrapper -->
455
456 {/foreach}
457 </div>
458
459 {/if}
460 <br />
461 <div class="crm-submit-buttons">{include file="CRM/common/formButtons.tpl" location="bottom"}</div>
462 </div>
463
464 {literal}
465 <script type="text/javascript">
466 function verify( ) {
467 if (cj('#is_email_receipt').prop('checked' )) {
468 var ok = confirm( '{/literal}{ts escape='js'}Click OK to save this contribution record AND send a receipt to the contributor now{/ts}{literal}.' );
469 if (!ok) {
470 return false;
471 }
472 }
473 }
474 </script>
475 {/literal}
476
477 {if $action neq 8}
478 {literal}
479 <script type="text/javascript">
480 CRM.$(function($) {
481 var $form = $('form.{/literal}{$form.formClass}{literal}');
482 checkEmailDependancies();
483 $('#is_email_receipt', $form).click(function() {
484 checkEmailDependancies();
485 });
486
487 function checkEmailDependancies( ) {
488 if ($('#is_email_receipt', $form).prop('checked')) {
489 $('#fromEmail', $form).show();
490 $('#receiptDate', $form).hide();
491 }
492 else {
493 $('#fromEmail', $form).hide();
494 $('#receiptDate', $form).show();
495 }
496 }
497 {/literal}{if !$contributionMode}{literal}
498 showHideCancelInfo($('#contribution_status_id', $form));
499
500 $('#contribution_status_id', $form).change(function() {
501 showHideCancelInfo($('#contribution_status_id', $form));
502 });
503
504 function showHideCancelInfo(obj) {
505 var cancelInfo_show_ids = [{/literal}{$cancelInfo_show_ids}{literal}];
506 if (cancelInfo_show_ids.indexOf(obj.val()) > -1) {
507 $('#cancelInfo', $form).show();
508 $('#total_amount', $form).attr('readonly', true);
509 }
510 else {
511 $("#cancel_date", $form).val('');
512 $("#cancel_reason", $form).val('');
513 $('#cancelInfo', $form).hide();
514 $("#total_amount", $form).removeAttr('readonly');
515 }
516 }
517 {/literal}{/if}
518 });
519 </script>
520 {if !$contributionMode}
521 {crmAPI var="checkVal" entity="OptionValue" action="getvalue" version="3" option_group_id="payment_instrument" name="Check" return="value"}
522 {include file="CRM/common/showHideByFieldValue.tpl"
523 trigger_field_id ="payment_instrument_id"
524 trigger_value = $checkVal
525 target_element_id ="checkNumber"
526 target_element_type ="table-row"
527 field_type ="select"
528 invert = 0
529 }
530 {/if}
531 {/if} {* not delete mode if*}
532
533 {/if} {* closing of main custom data if *}
534
535 {literal}
536 <script type="text/javascript">
537
538 {/literal}
539
540 // load form during form rule.
541 {if $buildPriceSet}{literal}buildAmount( );{/literal}{/if}
542
543 {literal}
544
545 // CRM-16451: set financial type of 'Price Set' in back office contribution
546 // instead of selecting manually
547 function buildAmount( priceSetId, financialtypeIds ) {
548 if (!priceSetId) priceSetId = cj("#price_set_id").val( );
549 var fname = '#priceset';
550 if (!priceSetId) {
551 // hide price set fields.
552 cj(fname).hide( );
553
554 // show/hide price set amount and total amount.
555 cj("#totalAmountORPriceSet").show( );
556 cj("#totalAmount").show( );
557 var choose = "{/literal}{ts}Choose price set{/ts}{literal}";
558 cj("#price_set_id option[value='']").html( choose );
559
560 cj('label[for="total_amount"]').text('{/literal}{ts}Total Amount{/ts}{literal}');
561 cj(".crm-contribution-form-block-financial_type_id").show();
562 cj("#financial_type_id option[value='']").attr('selected', true);
563
564 //we might want to build recur block.
565 if (cj("#is_recur")) buildRecurBlock( null );
566 return;
567 }
568
569 //don't allow recurring w/ priceset.
570 if ( cj( "#is_recur" ) && cj( 'input:radio[name="is_recur"]:checked').val( ) ) {
571 //reset the values of recur block.
572 cj("#installments").val('');
573 cj("#frequency_interval").val('');
574 cj('input:radio[name="is_recur"]')[0].checked = true;
575 cj("#recurringPaymentBlock").hide( );
576 }
577
578 var dataUrl = {/literal}"{crmURL h=0 q='snippet=4'}"{literal} + '&priceSetId=' + priceSetId;
579
580 var response = cj.ajax({
581 url: dataUrl,
582 async: false
583 }).responseText;
584
585 cj( fname ).show( ).html( response ).trigger('crmLoad');
586 // freeze total amount text field.
587 cj( "#total_amount").val('');
588
589 cj( "#totalAmountORPriceSet" ).hide( );
590 cj( "#totalAmount").hide( );
591 var manual = "{/literal}{ts}Manual contribution amount{/ts}{literal}";
592 cj("#price_set_id option[value='']").html( manual );
593
594 cj('label[for="total_amount"]').text('{/literal}{ts}Price Sets{/ts}{literal}');
595 cj("#financial_type_id option[value="+financialtypeIds[priceSetId]+"]").prop('selected', true);
596 cj(".crm-contribution-form-block-financial_type_id").css("display", "none");
597 }
598
599 function adjustPayment( ) {
600 cj('#adjust-option-type').show();
601 cj("#total_amount").removeAttr("READONLY");
602 cj("#total_amount").css('background-color', '#ffffff');
603 }
604
605 {/literal}{if $processorSupportsFutureStartDate}{literal}
606 cj ('input:radio[name="is_recur"]').click( function( ) {
607 showStartDate( );
608 });
609
610 showStartDate( );
611
612 function showStartDate( ) {
613 if (cj( 'input:radio[name="is_recur"]:checked').val( ) == 0 ) {
614 cj('#start_date').hide( );
615 }
616 else {
617 cj('#start_date').show( );
618 }
619 }
620
621 {/literal}{/if}{literal}
622 var thousandMarker = "{/literal}{$config->monetaryThousandSeparator}{literal}";
623 var separator = "{/literal}{$config->monetaryDecimalPoint}{literal}";
624
625 cj('#fee_amount').change( function() {
626 var totalAmount = cj('#total_amount').val().replace(thousandMarker,'').replace(separator,'.');
627 var feeAmount = cj('#fee_amount').val().replace(thousandMarker,'').replace(separator,'.');
628 var netAmount = totalAmount - feeAmount;
629 if (totalAmount) {
630 cj('#net_amount').val(CRM.formatMoney(netAmount, true));
631 }
632 });
633
634 cj("#financial_type_id").on("change",function(){
635 cj('#total_amount').trigger("change");
636 })
637
638 cj("#currency").on("change",function(){
639 cj('#total_amount').trigger("change");
640 })
641
642 {/literal}{if $taxRates && $invoicing}{literal}
643 CRM.$(function($) {
644 $('#total_amount').on("change",function(event) {
645 if (event.handled !== true) {
646 var freezeFinancialType = '{/literal}{$freezeFinancialType}{literal}';
647 if (!freezeFinancialType) {
648 var financialType = $('#financial_type_id').val();
649 var taxRates = '{/literal}{$taxRates}{literal}';
650 taxRates = JSON.parse(taxRates);
651 var currencies = '{/literal}{$currencies}{literal}';
652 currencies = JSON.parse(currencies);
653 var currencySelect = $('#currency').val();
654 var currencySymbol = currencies[currencySelect];
655 var re= /\((.*?)\)/g;
656 for(m = re.exec(currencySymbol); m; m = re.exec(currencySymbol)){
657 currencySymbol = m[1];
658 }
659 var taxRate = taxRates[financialType];
660 if (!taxRate) {
661 taxRate = 0;
662 cj("#totalTaxAmount").hide( );
663 } else {
664 cj("#totalTaxAmount").show( );
665 }
666 var totalAmount = $('#total_amount').val();
667 // replace all thousandMarker and change the separator to a dot
668 totalAmount = totalAmount.replace(thousandMarker,'').replace(separator,'.');
669
670 var totalTaxAmount = '{/literal}{$totalTaxAmount}{literal}';
671 var taxAmount = (taxRate/100)*totalAmount;
672 taxAmount = isNaN (taxAmount) ? 0:taxAmount;
673 var totalTaxAmount = taxAmount + Number(totalAmount);
674 totalTaxAmount = formatMoney( totalTaxAmount, 2, separator, thousandMarker );
675
676 $("#totalTaxAmount" ).html('Amount with tax : <span id="currencySymbolShow">' + currencySymbol + '</span> '+ totalTaxAmount);
677 }
678 event.handled = true;
679 }
680 return false;
681 });
682
683 $('#total_amount').trigger("change");
684 });
685 {/literal}{/if}{literal}
686
687 CRM.$(function($) {
688 $('#price_set_id').click(function() {
689 if( $('#price_set_id').val() ) {
690 $('#totalAmountBlock').hide();
691 }
692 else {
693 $('#totalAmountBlock').show();
694 }
695 });
696 });
697
698 function formatMoney (amount, c, d, t){
699 var n = amount,
700 c = isNaN(c = Math.abs(c)) ? 2 : c,
701 d = d == undefined ? "," : d,
702 t = t == undefined ? "." : t, s = n < 0 ? "-" : "",
703 i = parseInt(n = Math.abs(+n || 0).toFixed(c)) + "",
704 j = (j = i.length) > 3 ? j % 3 : 0;
705 return s + (j ? i.substr(0, j) + t : "") + i.substr(j).replace(/(\d{3})(?=\d)/g, "$1" + t) + (c ? d + Math.abs(n - i).toFixed(c).slice(2) : "");
706 };
707 </script>
708 {/literal}