76 lines
2.7 KiB
JavaScript
76 lines
2.7 KiB
JavaScript
$(function() {
|
|
|
|
$("#contactForm input,#contactForm textarea").jqBootstrapValidation({
|
|
preventSubmit: true,
|
|
submitError: function($form, event, errors) {
|
|
// additional error messages or events
|
|
},
|
|
submitSuccess: function($form, event) {
|
|
event.preventDefault(); // prevent default submit behaviour
|
|
// get values from FORM
|
|
var name = $("input#name").val();
|
|
var email = $("input#email").val();
|
|
var phone = $("input#phone").val();
|
|
var message = $("textarea#message").val();
|
|
var firstName = name; // For Success/Failure Message
|
|
// Check for white space in name for Success/Fail message
|
|
if (firstName.indexOf(' ') >= 0) {
|
|
firstName = name.split(' ').slice(0, -1).join(' ');
|
|
}
|
|
$this = $("#sendMessageButton");
|
|
$this.prop("disabled", true); // Disable submit button until AJAX call is complete to prevent duplicate messages
|
|
$.ajax({
|
|
url: "contact_me.php",
|
|
type: "POST",
|
|
data: {
|
|
name: name,
|
|
phone: phone,
|
|
email: email,
|
|
message: message
|
|
},
|
|
cache: false,
|
|
success: function() {
|
|
// Success message
|
|
$('#success').html("<div class='alert alert-success'>");
|
|
$('#success > .alert-success').html("<button type='button' class='close' data-dismiss='alert' aria-hidden='true'>×")
|
|
.append("</button>");
|
|
$('#success > .alert-success')
|
|
.append("<strong>Your message has been sent. </strong>");
|
|
$('#success > .alert-success')
|
|
.append('</div>');
|
|
//clear all fields
|
|
$('#contactForm').trigger("reset");
|
|
},
|
|
error: function() {
|
|
// Fail message
|
|
$('#success').html("<div class='alert alert-danger'>");
|
|
$('#success > .alert-danger').html("<button type='button' class='close' data-dismiss='alert' aria-hidden='true'>×")
|
|
.append("</button>");
|
|
$('#success > .alert-danger').append($("<strong>").text("Sorry " + firstName + ", it seems that my mail server is not responding. Please try again later!"));
|
|
$('#success > .alert-danger').append('</div>');
|
|
//clear all fields
|
|
$('#contactForm').trigger("reset");
|
|
},
|
|
complete: function() {
|
|
setTimeout(function() {
|
|
$this.prop("disabled", false); // Re-enable submit button when AJAX call is complete
|
|
}, 1000);
|
|
}
|
|
});
|
|
},
|
|
filter: function() {
|
|
return $(this).is(":visible");
|
|
},
|
|
});
|
|
|
|
$("a[data-toggle=\"tab\"]").click(function(e) {
|
|
e.preventDefault();
|
|
$(this).tab("show");
|
|
});
|
|
});
|
|
|
|
/*When clicking on Full hide fail/success boxes */
|
|
$('#name').focus(function() {
|
|
$('#success').html('');
|
|
});
|