Reputation: 49
Can someone help me with creating functions for the following processes? I want to have many datepickers, each with different forms, on a page. Then onChange, submit the correct form. I am currently repeating the code over and over to get this behavior to work. Here is all of my code for that page.
<html>
<head>
<link rel='stylesheet' type='text/css' media='all' href='style.css' />
<link rel='stylesheet' type='text/css' media='all' href='jqueryui.css' />
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.8.18/jquery-ui.min.js"></script>
<script type="text/javascript">
$(document).ready(function () {
var $datepickers = $(".datepick");
var $setallow = $(".showdate");
var $removeallow = $(".hidedate");
$removeallow.click(function() {
var $remove = $(this).closest("form");
$remove.children(".datepick").hide("normal");
var formData = $remove.serialize();
submitForm(formData);
});
$setallow.click(function() {
var $allow = $(this).closest("form");
$allow.children(".datepick").show("normal");
var formData = $allow.serialize();
submitForm(formData);
});
$datepickers.datepicker({ dateFormat: 'yy-mm-dd' });
$datepickers.change(function() {
var $form = $(this).closest("form");
var formData = $form.serialize();
alert($form.serialize());
submitForm(formData);
});
});
</script>
</head>
<body>
<div>
<h1 align="center">Testing Datepicker</h1>
<div class="entry">
<table id="striping" cellspacing="0" cellpadding="2" width="100%"><tr class="textbold">
<td class="Label" nowrap="nowrap" width="500">
Title Name
</td>
<td class="Label" align="center" nowrap="nowrap" width="70">
Show</td>
<td class="Label" align="center" nowrap="nowrap" width="100">
Don't Show
</td>
<td class="Label" align="left" nowrap="nowrap" width="100">
Date (Year-Month-Day)
</td></tr>
<tr id="highlight">
<td nowrap="nowrap" height="33">Title 19</td>
<form id="form19">
<input name="id" type="hidden" value="19" />
<td align="center" nowrap="nowrap">
<input name="allow" class="showdate" type="radio" value="yes" id="show19" />
</td>
<td align="center" nowrap="nowrap">
<input name="allow" class="hidedate" type="radio" value="no" id="hide19" checked="checked" />
</td>
<td align="center" nowrap="nowrap">
<table width="100%">
<tr><td>
<input name="allowdate" class="datepick" id="datepicker19" type="text" size="12" maxlength="10" value="2012-06-25">
</td>
<td width="121"><div id="feedback"></div></td></tr>
</table>
</td>
<input type="hidden" name="token" value="69601e04ff3580695fa4aa1dc91d35b6" />
</form>
</tr>
<tr id="highlight">
<td nowrap="nowrap" height="33">Title 2</td>
<form id="form2">
<input name="id" type="hidden" value="2" />
<td align="center" nowrap="nowrap">
<input name="allow" class="showdate" type="radio" value="yes" id="show2" />
</td>
<td align="center" nowrap="nowrap">
<input name="allow" class="hidedate" type="radio" value="no" id="hide2" checked="checked" />
</td>
<td align="center" nowrap="nowrap">
<table width="100%">
<tr><td>
<input name="allowdate" class="datepick" id="datepicker2" type="text" size="12" maxlength="10" value="2012-06-25">
</td>
<td width="121"><div id="feedback"></div></td></tr>
</table>
</td>
<input type="hidden" name="token" value="69601e04ff3580695fa4aa1dc91d35b6" />
</form>
</tr>
</table>
</div>
<script>
function submitForm(formData) {
$.ajax({
type: "POST",
url: "update.php",
data: formData,
dataType: "json",
cache: false,
timeout: 8000,
success: function(data) {
$("#feedback").html('<img src="icon_updated.png" border="0" />').fadeIn("fast");
setTimeout("$('#feedback').fadeOut('slow')", 1000);
},
error: function(data) {
$("#feedback").html('<img src="icon_not_updated.png" border="0" />').fadeIn("fast");
setTimeout("$('#feedback').fadeOut('slow')", 1000);
}
});
};
</script>
</body>
</html>
I am also trying to use the radio buttons to toggle showing and not showing the datepicker elements with no success. There is a lot more than 2 datepickers per page too. I would like to have one datepicker and one ajax function. I have tried the above links with no luck. Thanks for helping.
Upvotes: 2
Views: 1417
Reputation: 28645
Something along these lines should work for you:
$(function() {
//var $datepickers = $("#datepicker1, #datepicker2, #datepicker3");
var $datepickers = $(".datepick");
$datepickers.datepicker({ dateFormat: 'yy-mm-dd' });
$datepickers.change(function() {
var $form = $(this).closest('form');
var formData = $form.serialize();
submitForm(formData);
});
});
To simplify the selector set to $datepicker you could add a class of datepicker to the textboxes.
Upvotes: 2