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