Copy link to clipboard
Copied
I need to create a webform in the booking module where the first picket would cost X amount and all following tickets will be priced at Y. I already employ a "Booking multiple seats under one name" method but now I need help with the java script/jquery to be able to price the additional items differently.
Thank you,
Lana
1 Correct answer
Thank you, so far I got an error on line:
$('.total').html("TOTAL:"totalAmount"</span>");
Any idea why?
Thanks,
Lana
// Bookings multiple seats script
//By: Mario Gudelj
// ammended by Janice McConnell to include use of discount codes. Note that an input field for the discount code should be added to the html page.
(function($){
bookings = function() {
var discountAmount = 0;
var bookingAmount = 50; //Booking amount in dollars
$('#seats').change(function() {
$('.webform').fadeIn("slow");
var noOfSeat
...Copy link to clipboard
Copied
Do you have a URL of an example form you've already started on so we could possibly work from that?
Copy link to clipboard
Copied
Here it is, thank you. Lana
<form name="catwebformform24211" method="post" onsubmit="return checkWholeForm24211(this)" enctype="multipart/form-data" action="https://thepaddlesup.worldsecuresystems.com/FormProcessv2.aspx?WebFormID=64457&OID={module_oid}&OTYPE={module_otype}&EID={module_eid}&CID={module_cid}&CC={module_urlcountrycode}&Referrer={module_siteurl,true,true}">
<span class="req">*</span> Required
<table class="webform" cellspacing="0" cellpadding="2" border="0">
<tr>
<td><label for="Title">Title</label>
<br />
<select name="Title" id="Title" class="cat_dropdown_smaller">
<option value="1533683">DR</option>
<option value="1533682">MISS</option>
<option value="1533679" selected="selected">MR</option>
<option value="1533680">MRS</option>
<option value="1533681">MS</option>
</select></td>
</tr>
<tr>
<td><label for="FirstName">First Name <span class="req">*</span></label>
<br />
<input type="text" name="FirstName" id="FirstName" class="cat_textbox" maxlength="255" /></td>
</tr>
<tr>
<td><label for="LastName">Last Name <span class="req">*</span></label>
<br />
<input type="text" name="LastName" id="LastName" class="cat_textbox" maxlength="255" /></td>
</tr>
<tr>
<td><label for="WorkPhone">Phone Number <span class="req">*</span></label>
<br />
<input type="text" name="WorkPhone" id="WorkPhone" class="cat_textbox" maxlength="255" /></td>
</tr>
<tr>
<td><label for="EmailAddress">Email Address <span class="req">*</span></label>
<br />
<input type="text" name="EmailAddress" id="EmailAddress" class="cat_textbox" maxlength="255" /></td>
</tr>
<tr>
<td><label for="CAT_Custom_403255">Please select How many seats would you like to book? <span class="req">*</span></label>
<br />
<select class="cat_dropdown" select name="seats" id="seats">
<option value=" ">-- Please select --</option>
<option selected="selected" value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
<option value="4">4</option>
<option value="5">5</option>
<option value="6">6</option>
<option value="7">7</option>
<option value="8">8</option>
<option value="9">9</option>
<option value="10">10</option>
<option value="11">11</option>
<option value="12">12</option>
<option value="13">13</option>
<option value="14">14</option>
</select></td>
</tr>
<tr>
<td class="person1 hide"><label for="CAT_Custom_403265">Participant1</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403265" id="CAT_Custom_403265" class="cat_textbox" /></td>
</tr>
<tr>
<td class="person2 hide"><label for="CAT_Custom_403266">Participant2</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403266" id="CAT_Custom_403266" class="cat_textbox" /></td>
</tr>
<tr>
<td class="person3 hide"><label for="CAT_Custom_403267">Participant3</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403267" id="CAT_Custom_403267" class="cat_textbox" /></td>
</tr>
<tr>
<td class="person4 hide"><label for="CAT_Custom_403268">Participant4</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403268" id="CAT_Custom_403268" class="cat_textbox" /></td>
</tr>
<tr>
<td class="person5 hide"><label for="CAT_Custom_403269">Participant5</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403269" id="CAT_Custom_403269" class="cat_textbox" /></td>
</tr>
<tr>
<td class="person6 hide"><label for="CAT_Custom_403270">Participant6</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403270" id="CAT_Custom_403270" class="cat_textbox" /></td>
</tr>
<tr>
<td class="person7 hide"><label for="CAT_Custom_403271">Participant7</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403271" id="CAT_Custom_403271" class="cat_textbox" /></td>
</tr>
<tr>
<td class="person8 hide"><label for="CAT_Custom_403272">Participant8</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403272" id="CAT_Custom_403272" class="cat_textbox" /></td>
</tr>
<tr>
<td class="person9 hide"><label for="CAT_Custom_403274">Participant9</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403274" id="CAT_Custom_403274" class="cat_textbox" /></td>
</tr>
<tr>
<td class="person10 hide"><label for="CAT_Custom_403273">Participant10</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403273" id="CAT_Custom_403273" class="cat_textbox" /></td>
</tr>
<tr>
<td class="person11 hide"><label for="CAT_Custom_403275">Participant11</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403275" id="CAT_Custom_403275" class="cat_textbox" /></td>
</tr>
<tr>
<td class="person12 hide"><label for="CAT_Custom_403276">Participant12</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403276" id="CAT_Custom_403276" class="cat_textbox" /></td>
</tr>
<tr>
<td class="person13 hide"><label for="CAT_Custom_403277">Participant13</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403277" id="CAT_Custom_403277" class="cat_textbox" /></td>
</tr>
<tr>
<td class="person14 hide"><label for="CAT_Custom_403278">Participant14</label>
<br />
<input type="text" maxlength="1024" name="CAT_Custom_403278" id="CAT_Custom_403278" class="cat_textbox" /></td>
</tr>
<tr>
<td><label for="CardName">Name on Card <span class="req">*</span></label>
<br />
<input type="text" name="CardName" id="CardName" class="cat_textbox" /></td>
</tr>
<tr>
<td><label for="CardNumber">Card Number <span class="req">*</span></label>
<br />
<input type="text" name="CardNumber" id="CardNumber" class="cat_textbox" /></td>
</tr>
<tr>
<td><label>Card Expiry <span class="req">*</span></label>
<br />
<select name="CardExpiryMonth" id="CardExpiryMonth" class="cat_dropdown_smaller">
<option value="01">01</option>
<option value="02">02</option>
<option value="03">03</option>
<option value="04">04</option>
<option value="05">05</option>
<option value="06">06</option>
<option value="07">07</option>
<option value="08">08</option>
<option value="09">09</option>
<option value="10">10</option>
<option value="11">11</option>
<option value="12">12</option>
</select>
<select name="CardExpiryYear" id="CardExpiryYear" class="cat_dropdown_smaller">
<option value="2012">2012</option>
<option value="2013">2013</option>
<option value="2014">2014</option>
<option value="2015">2015</option>
<option value="2016">2016</option>
<option value="2017">2017</option>
<option value="2018">2018</option>
<option value="2019">2019</option>
<option value="2020">2020</option>
</select></td>
</tr>
<tr>
<td><label for="CardType">Card Type <span class="req">*</span></label>
<br />
<select name="CardType" id="CardType" class="cat_dropdown">
<option value="1">Visa</option>
<option value="2">Master Card</option>
<option value="3">Bank Card</option>
<option value="4">American Express</option>
<option value="5">Diners Club</option>
<option value="6">JCB</option>
</select></td>
</tr>
<tr>
<td><label for="CardCCV">CCV Number <span class="req">*</span></label>
<br />
<input type="text" name="CardCCV" id="CardCCV" class="cat_textbox" /></td>
</tr>
<tr>
<td><label for="Amount">Amount <span class="req">*</span> <span id='constraint-300-label'> (minimum: <span id='constraint-300'>1.00</span>)</span></label>
<br />
<input name="Amount" type="text" class="cat_textbox" id="Amount" value="25.00" readonly /></td>
</tr>
<tr>
<td><label>I agree to Terms of <a href="https://thepaddlesup.worldsecuresystems.com/terms/waver" target="_blank">Waver</a> <span class="req">*</span></label>
<br />
<input checked="checked" type="checkbox" name="CAT_Custom_401053" id="CAT_Custom_401053_0" value="I agree" />
I agree</td>
</tr>
<tr>
<td><input class="cat_button" type="submit" value="Submit" id="catwebformbutton" /></td>
</tr>
</table>
<script type="text/javascript" src="https://thepaddlesup.worldsecuresystems.com/CatalystScripts/ValidationFunctions.js"></script><script type="text/javascript">
//<![CDATA[
var submitcount24211 = 0;function checkWholeForm24211(theForm){var why = "";if (theForm.FirstName) why += isEmpty(theForm.FirstName.value, "First Name");if (theForm.LastName) why += isEmpty(theForm.LastName.value, "Last Name"); if (theForm.WorkPhone) why += isEmpty(theForm.WorkPhone.value, "Phone Number"); if (theForm.EmailAddress) why += checkEmail(theForm.EmailAddress.value); if (!theForm.PaymentMethodType || getRadioSelected(theForm.PaymentMethodType) == 1) { if (theForm.CardName) why += isEmpty(theForm.CardName.value, "Name on Card"); if (theForm.CardNumber) why += isNumeric(theForm.CardNumber.value, "Card Number"); if (theForm.Amount) why += isCurrency(theForm.Amount.value, "Amount"); } if (theForm.CAT_Custom_403255) why += checkDropdown(theForm.CAT_Custom_403255.value, "Please select How many seats would you like to book?");if (theForm.CAT_Custom_401053) why += checkSelected(theForm.CAT_Custom_401053, "I agree to terms of Waver");if(why != ""){alert(why);return false;}if(submitcount24211 == 0){submitcount24211++;theForm.submit();return false;}else{alert("Form submission is in progress.");return false;}}
//]]>
</script>
</form>
<script type="text/javascript">
$(document).ready(function(){
bookings();
});
</script></form>
Copy link to clipboard
Copied
Hi,
I am using the same "Booking multiple seats under one name" method in a project needs a pricing structure as you describe. I edited the bookings.js as follows:
// Bookings multiple seats script
//By: Mario Gudelj
//modified by Janice McConnell to create 2 ticket prices and calculate total.
(function($){
bookings = function() {
var bookingAmount = 50; //Booking amount in dollars
var guestAmount = 100; //Booking abount variable for each guest - added code
$('#seats').change(function() {
$('.webform').fadeIn("slow");
var noOfSeats = $("#seats option:selected").val();//take the selected option from the dropdown
var noOfGuests = parseInt(noOfSeats) - 1; //The number to pay guestAmount for a ticket - added code
$('.hide').fadeOut("slow");
$('#BookingAllocation').val(noOfSeats); //set the number of seats
//totalAmount = bookingAmount * noOfSeats;
var totalAmount = memberAmount + guestAmount * noOfGuests; //New calculation based on number of tickets at each price
$('#Amount').val(totalAmount);
for(var index = noOfSeats; index > 0; index--){
$('.person'+index).fadeIn("slow");
}
$('.total').html("<span>TOTAL:"+totalAmount+"</span>");
});
}
})(jQuery);
I hope this helps.
Now if I can figure out how to create a usable report on bookings . . .
Copy link to clipboard
Copied
Thank you so much for your help.
I know I'm pushing my luck with this Can you please also help with a discount code for the booking using the original js for multiple booking?
The coupon needs to work similar to discount code in e-commerce module but for booking, so when someone types in an input field called
“Discount”, for example, the correct set of numeric/alphabetical string, (example D5OFF) the total amount will change to reflect it. So if the price was $15.00 per session with the valid input of the code the price will become $10.00 for 1 booking. For two people (2x$15.00)-$5.00=$25.00 and so on.
If someone enters an invalid code the alert pop out should state "please enter the valid code" if someone fills out form without entering the code the transaction should continue as normal.
Again, thank you so much.
Lana
Copy link to clipboard
Copied
I may be able to help you with this, but it will be a few days before I can look
at it. You may have it figured out by then.
Janice
Janice McConnell, CEO
MJ WebWizards, Inc.
5057 Strickland Rd
Gainesville, GA 30507
770-967-6742
Copy link to clipboard
Copied
Few days is fine, I can wait. Thank you for your help.
Copy link to clipboard
Copied
Try this:
// Bookings multiple seats script
//By: Mario Gudelj
// ammended by Janice McConnell to include use of discount codes. Note that an
input field for the discount code should be added to the html page.
(function($){
bookings = function() {
var discountAmount = 0;
var bookingAmount = 50; //Booking amount in dollars
$('#seats').change(function() {
$('.webform').fadeIn("slow");
var noOfSeats = $("#seats option:selected").val(); //take the selected option
from the dropdown
$('.hide').fadeOut("slow");
$('#BookingAllocation').val(noOfSeats); //set the number of seats
totalAmount = bookingAmount * noOfSeats - discountAmount;
$('#Amount').val(totalAmount);
for(var index = noOfSeats; index > 0; index--){
$('.person'+index).fadeIn("slow");
}
$('.total').html("TOTAL:"totalAmount"</span>");
});
//When user enters discount code and moves focus, this function fires.
$('#disCode').blur(function() {
var discountCode = $(this).val(); //get the discount code
//Compare discount code to the case values and set discount amount. Note all
codes and values should be added to switch statement
switch (discountCode) {
case 'DIS5':
discountAmount = 5;
break;
case 'DIS10':
discountAmount = 10;
break;
case '':
discountAmount = 0;
break;
default:
alert('Please enter the valid code');
}
var noOfSeats = $("#seats option:selected").val();
var newTotal = bookingAmount * noOfSeats - discountAmount; //Recalculate total
based on number of seats and then subtract discount
$('#Amount').val(newTotal); //set new Amount
});
}})(jQuery);
Janice McConnell, CEO
MJ WebWizards, Inc.
5057 Strickland Rd
Gainesville, GA 30507
770-967-6742
Copy link to clipboard
Copied
Thank you, so far I got an error on line:
$('.total').html("TOTAL:"totalAmount"</span>");
Any idea why?
Thanks,
Lana
// Bookings multiple seats script
//By: Mario Gudelj
// ammended by Janice McConnell to include use of discount codes. Note that an input field for the discount code should be added to the html page.
(function($){
bookings = function() {
var discountAmount = 0;
var bookingAmount = 50; //Booking amount in dollars
$('#seats').change(function() {
$('.webform').fadeIn("slow");
var noOfSeats = $("#seats option:selected").val(); //take the selected option from the dropdown
$('.hide').fadeOut("slow");
$('#BookingAllocation').val(noOfSeats); //set the number of seats
totalAmount = bookingAmount * noOfSeats - discountAmount;
$('#Amount').val(totalAmount);
for(var index = noOfSeats; index > 0; index--){
$('.person'+index).fadeIn("slow");
}
$('.total').html("TOTAL:"totalAmount"</span>");
});
//When user enters discount code and moves focus, this function fires.
$('#disCode').blur(function() {
var discountCode = $(this).val(); //get the discount code
//Compare discount code to the case values and set discount amount. Note all codes and values should be added to switch statement
switch (discountCode) {
case 'DIS5':
discountAmount = 5;
break;
case 'DIS10':
discountAmount = 10;
break;
case '':
discountAmount = 0;
break;
default:
alert('Please enter the valid code');
}
var noOfSeats = $("#seats option:selected").val();
var newTotal = bookingAmount * noOfSeats - discountAmount; //Recalculate total based on number of seats and then subtract discount
$('#Amount').val(newTotal); //set new Amount
});
}})(jQuery);
Copy link to clipboard
Copied
The line in the js file is:
$('.total').html("TOTAL:"totalAmount"</span>");
I notice your line desn't have the opening span tag. Do you have an element with
class="total"?
Janice
Janice McConnell, CEO
MJ WebWizards, Inc.
5057 Strickland Rd
Gainesville, GA 30507
770-967-6742
Copy link to clipboard
Copied
That's what I have in html form:
do I need to add a field?
Thank you,
Lana
Copy link to clipboard
Copied
Best guess is "no". You don't really need another field in your form. Take this
line out of the bookings.js:
$('.total').html("TOTAL:"totalAmount"</span>");
and don't add a field with that class.
Janice
Janice McConnell, CEO
MJ WebWizards, Inc.
5057 Strickland Rd
Gainesville, GA 30507
770-967-6742
Copy link to clipboard
Copied
It works!!
Thank you so much.I just had to delete readonly=readonly for the amount input field (didn't want visitors to change the price) blur function did trigger it
Just curious if there is a way around it, otherwise, beautiful.
Thank you,
Lana
Copy link to clipboard
Copied
Sorry about that. Add the 2 lines around the existing middle line:
$('#Amount').removeAttr('readonly');
$('#Amount').val(newTotal); //set new Amount
$('#Amount').attr('readonly','readonly');
Janice
Janice McConnell, CEO
MJ WebWizards, Inc.
5057 Strickland Rd
Gainesville, GA 30507
770-967-6742
Copy link to clipboard
Copied
Amazing, totally worked Thank you, Lana
Copy link to clipboard
Copied
Just popped in and noticed on your site that when you choose a number of participants in the booking, the form loses the decimal places no it doesn't resemble a dollar amount (at least USD). In order to maintain the decimal, just change line 15 of the bookings35.js file to this:
totalAmount = (bookingAmount * noOfSeats).toFixed(2);
You can see a demo I worked up at http://jsfiddle.net/BzqN5/
In my example, I changed the bookingAmount variable in the javascript to 12.75 to ensure that the decimals were being handled correctly. If you change it back to 35 and save the fiddle again, you can verify it works for round numbers too-- keeping the .00 at the end.
Copy link to clipboard
Copied
Works great, thank you so much Lana
Copy link to clipboard
Copied
Guys, I have followed this thread with interest and am implementing a similiar booking module. My question : is it possible to have a variable amount for multple events that works with the Multiple Seat Bookings under one name concept. I have the booking working with one amount but now have muplitple events with different pricing. Ie: 1st Event $96-00 2nd event $150.00.
When using this script can anyone tell me what the variable price should indicate or where in the form this should be indicated. I am so close but can't quite crack it and would really appreciate some help.
(function($){
bookings = function() {
var bookingAmount = 0.00; //Booking amount in dollars
$('#seats').change(function() {
$('.webform').fadeIn("slow");
var noOfSeats = $("#seats option:selected").val(); //take the selected option from the dropdown
$('.hide').fadeOut("slow");
$('#BookingAllocation').val(noOfSeats); //set the number of seats
totalAmount = (bookingAmount * noOfSeats).toFixed(2);
$('#Amount').val(totalAmount);
for(var index = noOfSeats; index > 0; index--){
$('.person'+index).fadeIn("slow");
}
$('.total').html("<span>TOTAL:"+totalAmount+"</span>");
});
};
})(jQuery);
Thanks in anticipation.
Rossco
Copy link to clipboard
Copied
I set the cost for each event in the content of the event in the event modules
section. Then I added jquery code to get that amount for each event and use it
in the original code rather than hard-coding the amount in the original code.
Janice
Janice McConnell, CEO
MJ WebWizards, Inc.
5057 Strickland Rd
Gainesville, GA 30507
770-967-6742
Copy link to clipboard
Copied
Janice I have applied the above code to my site wide template to act with all bookings with separate booking forms. Is there a way to enable one "booking multiple seats script " i(in template ) ie ; amount change with each No of Seatys allocation.and then have the booking form code display the separate price for each event. I have it working on one event but price is set in the template script. This has got me beaten. If not where are you seating the script wthin the individual event pricing.
Thanks for your help it is most appreciated.
Rossco
Copy link to clipboard
Copied
We have an Events template that has a call to the script file. When you go to
the dashboard, select Modules>Events> and open a specific event, you will see
the Event Content field. This is where we have the details for each event and a
content-holder with the registration form. In the details section, we have an
element for the cost of the event with an id applied. When the event is opened
on the Events page, the code gets the text of the element, changes it to a
decimal number and sets the cost per ticket variable. Something like:
var bookingAmount = parseFloat($('#ticketCost').text(),10);
where "ticketCost" is the id of the element in the event description which
contains the price of the ticket. Make sure that the amount doesn't contain the
dollar sign. In one case,I made a span for the price with the dollar sign
outside the span. In another case, I tested for its presence and stripped it -
probably the better, cleaner way - I should mention that I am not an expert.
You ask " If not where are you seating the script wthin the individual event
pricing." If I understand your question - I'm not. The individual event pricing
is seated in the event content. The script is seated in the Events template.
This may not fit in with your design at all, but perhaps it will give you some
new ideas.
Janice
Janice McConnell, CEO
MJ WebWizards, Inc.
5057 Strickland Rd
Gainesville, GA 30507
770-967-6742
Copy link to clipboard
Copied
Thanks so much Janice. This hasn't quite worked for our situation but have established new templates for each event which is great for now. Have everything working now in content holders which is perfect. Having a problem with trying to get the multiple seat names top display in the workflow. This seems to be a common problem with the BC Platform,, where only the email subscribers name appears in the booking. Do you know of any way that we can make all names subscribed appear to the booking. Thanks again your assistance was invaluable. Cheers from Aus.
Rossco
Copy link to clipboard
Copied
My client was satisfied to have the names appear in a custom report. So we
"extended the CRM database" with a list of text fields for guests for the
registration form. Now we can do a custom report of "Customers and Bookings" and
add the CRM extension to the report. The report then shows the "guest" names
with each registrant's name.
I considered trying submitting multiple forms, but since this was working and
sufficient for the client, I didn't follow up on it.
Hope this helps.
Janice
Janice McConnell, CEO
MJ WebWizards, Inc.
5057 Strickland Rd
Gainesville, GA 30507
770-967-6742
