Commit | Line | Data |
---|---|---|
6a488035 TO |
1 | {* |
2 | +--------------------------------------------------------------------+ | |
1188c7a8 | 3 | | Copyright CiviCRM LLC. All rights reserved. | |
6a488035 | 4 | | | |
1188c7a8 TO |
5 | | This work is published under the GNU AGPLv3 license with some | |
6 | | permitted exceptions and without any warranty. For full license | | |
7 | | and copyright information, see https://civicrm.org/licensing | | |
6a488035 TO |
8 | +--------------------------------------------------------------------+ |
9 | *} | |
10 | {crmRegion name="billing-block"} | |
c78d6d60 | 11 | <div id="payment_information"> |
3cc8d80d | 12 | {if $paymentFields|@count} |
fbfd63ec | 13 | <fieldset class="billing_mode-group {$paymentTypeName}_info-group"> |
dc3560bc | 14 | <legend> |
fbfd63ec | 15 | {$paymentTypeLabel} |
dc3560bc | 16 | </legend> |
aaff4c69 | 17 | {crmRegion name="billing-block-pre"} |
aaff4c69 | 18 | {/crmRegion} |
92ec1d7f EM |
19 | <div class="crm-section billing_mode-section {$paymentTypeName}_info-section"> |
20 | {foreach from=$paymentFields item=paymentField} | |
9d421118 | 21 | {assign var='name' value=$form.$paymentField.name} |
92ec1d7f | 22 | <div class="crm-section {$form.$paymentField.name}-section"> |
9d421118 | 23 | <div class="label">{$form.$paymentField.label} |
24 | {if $requiredPaymentFields.$name}<span class="crm-marker" title="{ts}This field is required.{/ts}">*</span>{/if} | |
25 | </div> | |
8cdd6191 | 26 | <div class="content"> |
27 | {$form.$paymentField.html} | |
4533376a MWMC |
28 | {if $paymentFieldsMetadata.$name.description} |
29 | <div class="description">{$paymentFieldsMetadata.$name.description}</div> | |
30 | {elseif $paymentField == 'cvv2'}{* @todo move to form assignment*} | |
92ec1d7f EM |
31 | <span class="cvv2-icon" title="{ts}Usually the last 3-4 digits in the signature area on the back of the card.{/ts}"> </span> |
32 | {/if} | |
33 | {if $paymentField == 'credit_card_type'} | |
34 | <div class="crm-credit_card_type-icons"></div> | |
35 | {/if} | |
6a488035 | 36 | </div> |
dc3560bc EM |
37 | <div class="clear"></div> |
38 | </div> | |
92ec1d7f | 39 | {/foreach} |
dc3560bc | 40 | </div> |
c78d6d60 | 41 | </fieldset> |
caec10c8 | 42 | {/if} |
b5eab107 | 43 | {if $billingDetailsFields|@count && $paymentProcessor.payment_processor_type neq 'PayPal_Express'} |
37e877b2 | 44 | {if $profileAddressFields && !$ccid} |
c78d6d60 EM |
45 | <input type="checkbox" id="billingcheckbox" value="0"> |
46 | <label for="billingcheckbox">{ts}My billing address is the same as above{/ts}</label> | |
dc3560bc | 47 | {/if} |
c78d6d60 EM |
48 | <fieldset class="billing_name_address-group"> |
49 | <legend>{ts}Billing Name and Address{/ts}</legend> | |
50 | <div class="crm-section billing_name_address-section"> | |
51 | {foreach from=$billingDetailsFields item=billingField} | |
9d421118 | 52 | {assign var='name' value=$form.$billingField.name} |
c78d6d60 | 53 | <div class="crm-section {$form.$billingField.name}-section"> |
9d421118 | 54 | <div class="label">{$form.$billingField.label} |
55 | {if $requiredPaymentFields.$name}<span class="crm-marker" title="{ts}This field is required.{/ts}">*</span>{/if} | |
56 | </div> | |
c78d6d60 EM |
57 | {if $form.$billingField.type == 'text'} |
58 | <div class="content">{$form.$billingField.html}</div> | |
59 | {else} | |
60 | <div class="content">{$form.$billingField.html|crmAddClass:big}</div> | |
61 | {/if} | |
62 | <div class="clear"></div> | |
63 | </div> | |
64 | {/foreach} | |
65 | </div> | |
66 | </fieldset> | |
67 | {/if} | |
68 | </div> | |
dc3560bc EM |
69 | {if $profileAddressFields} |
70 | <script type="text/javascript"> | |
71 | {literal} | |
8ae4d0d3 | 72 | |
dc3560bc EM |
73 | CRM.$(function ($) { |
74 | // build list of ids to track changes on | |
75 | var address_fields = {/literal}{$profileAddressFields|@json_encode}{literal}; | |
76 | var input_ids = {}; | |
77 | var select_ids = {}; | |
78 | var orig_id, field, field_name; | |
6a488035 | 79 | |
dc3560bc EM |
80 | // build input ids |
81 | $('.billing_name_address-section input').each(function (i) { | |
82 | orig_id = $(this).attr('id'); | |
83 | field = orig_id.split('-'); | |
84 | field_name = field[0].replace('billing_', ''); | |
85 | if (field[1]) { | |
86 | if (address_fields[field_name]) { | |
87 | input_ids['#' + field_name + '-' + address_fields[field_name]] = '#' + orig_id; | |
88 | } | |
89 | } | |
90 | }); | |
91 | if ($('#first_name').length) | |
92 | input_ids['#first_name'] = '#billing_first_name'; | |
93 | if ($('#middle_name').length) | |
94 | input_ids['#middle_name'] = '#billing_middle_name'; | |
95 | if ($('#last_name').length) | |
96 | input_ids['#last_name'] = '#billing_last_name'; | |
6a488035 | 97 | |
dc3560bc EM |
98 | // build select ids |
99 | $('.billing_name_address-section select').each(function (i) { | |
100 | orig_id = $(this).attr('id'); | |
101 | field = orig_id.split('-'); | |
102 | field_name = field[0].replace('billing_', '').replace('_id', ''); | |
103 | if (field[1]) { | |
104 | if (address_fields[field_name]) { | |
105 | select_ids['#' + field_name + '-' + address_fields[field_name]] = '#' + orig_id; | |
106 | } | |
107 | } | |
108 | }); | |
6a488035 | 109 | |
dc3560bc EM |
110 | // detect if billing checkbox should default to checked |
111 | var checked = true; | |
112 | for (var id in input_ids) { | |
113 | orig_id = input_ids[id]; | |
114 | if ($(id).val() != $(orig_id).val()) { | |
115 | checked = false; | |
116 | break; | |
117 | } | |
6a488035 | 118 | } |
dc3560bc EM |
119 | for (var id in select_ids) { |
120 | orig_id = select_ids[id]; | |
121 | if ($(id).val() != $(orig_id).val()) { | |
122 | checked = false; | |
123 | break; | |
124 | } | |
125 | } | |
126 | if (checked) { | |
cce5bc84 | 127 | $('#billingcheckbox').prop('checked', true).data('crm-initial-value', true); |
ab2e3179 | 128 | if (!CRM.billing || CRM.billing.billingProfileIsHideable) { |
dc3560bc EM |
129 | $('.billing_name_address-group').hide(); |
130 | } | |
6a488035 | 131 | } |
6a488035 | 132 | |
dc3560bc EM |
133 | // onchange handlers for non-billing fields |
134 | for (var id in input_ids) { | |
135 | orig_id = input_ids[id]; | |
136 | $(id).change(function () { | |
137 | var id = '#' + $(this).attr('id'); | |
138 | var orig_id = input_ids[id]; | |
6a488035 | 139 | |
dc3560bc EM |
140 | // if billing checkbox is active, copy other field into billing field |
141 | if ($('#billingcheckbox').prop('checked')) { | |
142 | $(orig_id).val($(id).val()); | |
143 | } | |
144 | }); | |
ae8f569f | 145 | } |
dc3560bc EM |
146 | for (var id in select_ids) { |
147 | orig_id = select_ids[id]; | |
148 | $(id).change(function () { | |
149 | var id = '#' + $(this).attr('id'); | |
150 | var orig_id = select_ids[id]; | |
6a488035 | 151 | |
dc3560bc EM |
152 | // if billing checkbox is active, copy other field into billing field |
153 | if ($('#billingcheckbox').prop('checked')) { | |
154 | $(orig_id + ' option').prop('selected', false); | |
155 | $(orig_id + ' option[value="' + $(id).val() + '"]').prop('selected', true); | |
dc3560bc EM |
156 | $(orig_id).change(); |
157 | } | |
158 | }); | |
6a488035 | 159 | } |
6a488035 | 160 | |
dc3560bc | 161 | // toggle show/hide |
67ddfab1 MW |
162 | var billingCheckboxElement = $('#billingcheckbox'); |
163 | billingCheckboxElement.click(function() { | |
164 | billingCheckboxChanged(billingCheckboxElement); | |
165 | }); | |
166 | ||
167 | billingCheckboxElement.change(function() { | |
168 | billingCheckboxChanged(billingCheckboxElement); | |
169 | }); | |
170 | ||
171 | function billingCheckboxChanged(billingCheckbox) { | |
172 | if (billingCheckbox.prop('checked')) { | |
ab2e3179 | 173 | if (!CRM.billing || CRM.billing.billingProfileIsHideable) { |
dc3560bc EM |
174 | $('.billing_name_address-group').hide(200); |
175 | } | |
6a488035 | 176 | |
dc3560bc EM |
177 | // copy all values |
178 | for (var id in input_ids) { | |
179 | orig_id = input_ids[id]; | |
180 | $(orig_id).val($(id).val()); | |
181 | } | |
182 | for (var id in select_ids) { | |
183 | orig_id = select_ids[id]; | |
184 | $(orig_id + ' option').prop('selected', false); | |
185 | $(orig_id + ' option[value="' + $(id).val() + '"]').prop('selected', true); | |
84466477 | 186 | $(orig_id).change(); |
dc3560bc EM |
187 | } |
188 | } else { | |
189 | $('.billing_name_address-group').show(200); | |
190 | } | |
67ddfab1 | 191 | } |
6a488035 | 192 | |
dc3560bc EM |
193 | // remove spaces, dashes from credit card number |
194 | $('#credit_card_number').change(function () { | |
195 | var cc = $('#credit_card_number').val() | |
196 | .replace(/ /g, '') | |
197 | .replace(/-/g, ''); | |
198 | $('#credit_card_number').val(cc); | |
199 | }); | |
1ba4a3aa EM |
200 | }); |
201 | ||
dc3560bc | 202 | </script> |
31d31a05 | 203 | {/literal} |
6a488035 | 204 | {/if} |
079e7379 CW |
205 | {if $suppressSubmitButton} |
206 | {literal} | |
207 | <script type="text/javascript"> | |
208 | CRM.$(function($) { | |
209 | $('.crm-submit-buttons', $('#billing-payment-block').closest('form')).hide(); | |
210 | }); | |
211 | </script> | |
212 | {/literal} | |
213 | {/if} | |
6a488035 | 214 | {/crmRegion} |
dbbd55dc EM |
215 | {crmRegion name="billing-block-post"} |
216 | {* Payment processors sometimes need to append something to the end of the billing block. We create a region for | |
217 | clarity - the plan is to move to assigning this through the payment processor to this region *} | |
dbbd55dc | 218 | {/crmRegion} |