I added some hidden fields to the bottom of my HTML form in order to send it to Pardot, but they are creating empty space at the end of the form (right before the submit button). If I delete these empty lines in the visual editor, it deletes the hidden fields in the HTML code that I need in order to send the form to the correct place. How can I keep the hidden fields and get rid of this empty space?
Thank you!
]]> <script type="text/javascript" src="https://code.jquery.com/jquery-3.5.0.js"></script>
<script type="text/javascript">
const url = "https://www.plasticatbay.org/ChartBal/populatebeach2.php";
$.getJSON(url, function(data){
$('#selector').empty();
$('#selector').append('<option selected="true" disabled>Choose a beach</option>')
$('#selector').prop('selectedIndex', 0);
$.each(data, function(key,entry){
$('#selector').append($('<option>').text(entry.Beach).attr('value', entry.Id))});
});
</script>
<script type="text/javascript">
function validateForm(){
/* Validating name field */
var x=document.forms["myForm"]["name"].value;
if (x==null || x=="") {
alert("Name must be filled out");
return false;
}
/* Validating email field */
var x=document.forms["myForm"]["email"].value;
var atpos=x.indexOf("@");
var dotpos=x.lastIndexOf(".");
if (atpos<1 || dotpos<atpos+2 || dotpos+2>=x.length){
alert("Not a valid e-mail address");
return false;
}
var x=document.forms["myForm"]["date"].value;
if (x==null || x=="") {
alert("The date must be filled out");
return false;
}
var x=document.forms["myForm"]["selector"].value;
if (x==null || x=="") {
alert("The beach must be selected");
return false;
}
var x=document.forms["myForm"]["weight"].value;
if (x==null || x=="") {
alert("The weight must be provided");
return false;
}
}
</script>
</head>
<body>
<form action="<?php echo admin_url( 'admin-post.php' ); ?>" method="post" name="myForm">
<input type="hidden" name="action" value="pollution_data">
Name:<br> <input id="name" type="text" name="name" /><p>
Enter your email:<br> <input type = "email" id="email" name="email" /><p>
Date of collection: <input type="date" id="date" name="date" class="datepicker" /><p>
Choose a beach: <select id= "selector" name="Choose_beach"></select><br>
If the beach is not listed please use the contact form<p>
Weight collected in kg: <input id="weight" type="number" name="weight" /><p>
Feedback: <br><textarea name="feedback" rows="10" cols="50" ></textarea><p>
<input type="submit" value="Submit" /></form>
</body>
I have modified the function.php to export my POST data via admin_post but nothing seems to work. Here an exert of the function.
/**
* Manage form
*/
add_action( 'admin_post_nopriv_pollution_data', 'add_pollution_data' );
add_action( 'admin_post_pollution_data','add_pollution_data');
function add_pollution_data(){
$name=$email=$date=$beach=$weight=$unit=$feedback="";
//get the form elements and store them in a variable
if (! is_page("contribute-to-marine-pollution-data-collection")||! isset( $_POST['name'] )) {
return;}
$name=test_input($_POST["name"]);
$email=test_input($_POST["email"]);
$date=test_input($_POST["date"]);
$beach=test_input($_POST["beach"]);
$weight=test_input($_POST["weight"]);
$feedback=test_input($_POST["feedback"]);
function test_input($data) {
$data = trim($data);
$data = stripslashes($data);
$data = htmlspecialchars($data);
return $data;
}
//database
define('DB_HOST', 'host');
define('DB_USERNAME', 'user');
define('DB_PASSWORD', 'pwd');
define('DB_NAME', 'DB');
//get connection
$mysqli = new mysqli(DB_HOST, DB_USERNAME, DB_PASSWORD, DB_NAME);
if(!$mysqli){
die("Connection failed: " . $mysqli->error);
}
//insert data
$query1 ="INSERT INTO <code>TAB1</code> (a,b,c,d) VALUES ($beach, $date,$weight,$email)";
$result1 = $mysqli->query($query1);
//free memory associated with result
$result1->close();
//close connection
$mysqli->close();
// Sanitize E-mail Address
$email =filter_var($email, FILTER_SANITIZE_EMAIL);
// Validate E-mail Address
$email= filter_var($email, FILTER_VALIDATE_EMAIL);
if (!$email){
echo "Invalid Sender's Email";
}
$subject ="Data Submission";
$headers ='From: /*valid email*/';
$message = wordwrap("name:\t$name\nemail:\t$email\ndate:\t$date\nbeach:\t$beach\nWeigth:\t$weight $unit\nmsg:\n",70);
wp_mail("/*valid email*/",$subject,$message,$headers);
echo "Thanks for the submission!";
//Redirects to the success page
header("Location: https://www.plasticatbay.org/contribute-to-marine-pollution-data-collection");
}
I don’t think the function is read and I don’t really find a way of debugging this. Any help is welcome.
]]>Thank you for reading this. I am trying to make a HTML form with a submit button, which I would like to cause the current page to reload.
On pressing the submit button I would like the page to reload itself:
[ redundant link removed ]
However, the following location is where it arrives:
/
I am not sure what to do to fix this. Can you give me some help with this?
here is my form code:
<div class="create-note">
<form action="https://alaskametrology.com/?page_id=167" method="get">
<h3 class="headline headline--medium">customer address</h3>
<label for="customer_name">customer name</label>
<input class="new-note-title" name="customer_name" placeholder="business name ">
<label for="address_1"></label>
<input class="new-note-title" name="address_1" placeholder="street address 1 (default street address)">
<label for="address_2"></label>
<input class="new-note-title" name="address_2" placeholder="street 2 (optional)">
<label for="city"></label>
<input class="new-note-city" name="city" placeholder="city">
<input class="new-note-city" name="workorders_workorder_number" placeholder="state">
<input class="new-note-city" name="workorders_workorder_number" placeholder="zip">
<hr>
<h3 class="headline headline--medium">contact person</h3>
<label for="recieved-date">person name</label>
<input type=input class="new-note-title" name="workorders_estimate_number" placeholder="name">
<label for="city"></label>
<input class="new-note-city" name="city" placeholder="phone number">
<label for="city"></label>
<input class="new-note-city" name="city" placeholder="email">
<hr>
<h3 class="headline headline--medium">special notes</h3>
<textarea class="new-note-title" name="workorder-note" placeholder="specific notes and instructions for this customer"></textarea>
<input type="hidden" name="customers_id" value="<?php echo $my_customers_id; ?>">
<input type="hidden" name="action" value="create_new_thingy">
<input type="submit" class="submit-note" value="create new customer">
<a class="btn btn--orange" href="#" onClick="history.back();return false;">cancel</a>
</form>
</div>
]]>Ordinarily in these kinds of scenarios, if you happen to be using something else other than what the plugin/service you’re using allows you to connect with via API, no problem, you just connect via HTML form. But no, not with this plugin. For some bizarre reason, there is no facility to connect via HTML form. Why on earth does it not have such a basic function? That makes it utterly useless for me.
]]>It seems that I only have the option to add text fields, selects and single checkboxes to the forms but I need multiple checkbox options. I’ve added the checkboxes to the form but the selected information doesn’t pull through.
Is this possible?
]]><form id="registerform" action="https://tahiti-barbecue-contest.com/wp-login.php?action=register" method="post" name="registerform" novalidate="novalidate"><label for="user_login">Identifiant
<input id="user_login" class="input" name="user_login" size="20" type="text" value="" /></label></form><label for="user_email">Adresse de messagerie
<input id="user_email" class="input" name="user_email" size="25" type="email" value="" /></label>
<p id="reg_passmail">La confirmation d’inscription vous sera envoyée par e-mail.</p>
<br class="clear" /> <input name="redirect_to" type="hidden" value="" />
<p class="submit"><input id="wp-submit" class="button button-primary button-large" name="wp-submit" type="submit" value="Inscription" /></p>
I have massive fake inscriptions so I need to add a recaptcha to this form. So i Installed the SI Captcha Anti-Spam Plugin.
How can i add the captcha in this form ? Insert some html new code ? new field ? shortcode ?
Here is my register page :
https://tahiti-barbecue-contest.com/inscription/
Thans for your help
Nicolas
]]>https://www.ads-software.com/plugins/newsletter/
]]>I currently have two radio buttons where the user can select what type of membership they want. Ideally, I would like the data from the form to tie in with a PayPal button so that users don’t have to enter/choose the desired amount a second time on the PayPal page.
Also, if possible, I would like to integrate two (optional) check boxes for if users want to pay an additional fee for extra access at the event. However, I don’t know if that’s possible with PayPal.
Any help would be immensely appreciated.
]]>