ScoobyDont Posted December 27, 2017 Share Posted December 27, 2017 Hi, Can someone point me in the right direction on how to do this I have a form (I have condensed it down to stop complicating things) <input type="text" name="regid"/> <input type="text" name="controlno"/> <input type="text" name="hoverdate"/> <button>My Submit Button</button> The php function public function Addnew($regid, $controlno, $hoverdate) { try { $query = $db->prepare("INSERT INTO addnew(regid, controlno, hoverdate) VALUES (:regid,:controlno,:hoverdate)"); $query->bindParam("regid", $regid, PDO::PARAM_STR); $query->bindParam("controlno", $chassis, PDO::PARAM_STR); $query->bindParam("hoverdate", $hoverdate, PDO::PARAM_STR); $query->execute(); return $db->lastInsertId(); } catch (PDOException $e) { exit($e->getMessage()); } } And form data if (!empty($_POST['btnAddNew'])) { if ($_POST['regid'] == "") { $add_error_message = 'Registration ID is required!'; } else if ($_POST['controlno'] == "") { $add_error_message = 'A control number is required!'; } else if ($_POST['hoverdate'] == "") { $add_error_message = 'When is the product being handed over'; } else if ($app->isReg($_POST['regid'])) { $add_error_message = 'That Registration ID is already being processed!'; } else { $user_id = $app->Addnew($_POST['regid'], $_POST['controlno'], $_POST['hoverdate']); What I am trying to do is insert a 'pickingdate' into the database when the user submits the form The date has to be 3 days prior to the "hoverdate" I am not sure where to start on this one and been scratching my head for ages trying to think of a solution but cannot for the life of me get my head round it...Any pointers would be much appreciated Thanks in advance for any help Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/ Share on other sites More sharing options...
Barand Posted December 27, 2017 Share Posted December 27, 2017 $hoverdate = '2017-12-27'; // from your post data $hoverdate = new dateTime($hoverdate); $pickingdate = $hoverdate->modify('-3 days')->format('Y-m-d'); // 2017-12-24 Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554932 Share on other sites More sharing options...
ScoobyDont Posted December 27, 2017 Author Share Posted December 27, 2017 Sorry to sound stupid but where in the code does that go Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554934 Share on other sites More sharing options...
Barand Posted December 27, 2017 Share Posted December 27, 2017 A good place would be somewhere before you insert the picking date into your table Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554935 Share on other sites More sharing options...
Barand Posted December 27, 2017 Share Posted December 27, 2017 Are you planning on putting the picking date into that same table with the hoverdate? If so, why? You can just SELECT regid , controlno , hoverdate , hoverdate - INTERVAL 3 DAY as pickingdate FROM addnewYou can calculate the picking date when required - you shouldn't store derived values. Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554936 Share on other sites More sharing options...
ScoobyDont Posted December 28, 2017 Author Share Posted December 28, 2017 Thanks for the advice, I wanted to store the dates in the DB as I have another 5 dates to deal with not just the one, I wanted to get one working first before I progressed onto the next Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554951 Share on other sites More sharing options...
ginerjm Posted December 28, 2017 Share Posted December 28, 2017 I'm curious how you actually get the data from this supposed form? I don't see a submit button nor any form tags. Perhaps a bit too simplified? Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554953 Share on other sites More sharing options...
ScoobyDont Posted December 28, 2017 Author Share Posted December 28, 2017 Hi, Can someone point me in the right direction on how to do this I have a form (I have condensed it down to stop complicating things) <input type="text" name="regid"/> <input type="text" name="controlno"/> <input type="text" name="hoverdate"/> <button>My Submit Button</button> The form is all working and adding to the database, or should I say it was before I tried doing this I just put an example dummy form up ) so there wasn't a mass of unneeded html Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554955 Share on other sites More sharing options...
ScoobyDont Posted December 28, 2017 Author Share Posted December 28, 2017 No I am totally lost now, wherever I put the code Barand showed me either gives me an error or the form data does not populate the DB Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554956 Share on other sites More sharing options...
ginerjm Posted December 28, 2017 Share Posted December 28, 2017 No - we're lost. Show Us the Code You Are Running. Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554957 Share on other sites More sharing options...
Barand Posted December 28, 2017 Share Posted December 28, 2017 Also, what format is your input date and what date format are you storing? (My sample code showed the formats you should be using) Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554958 Share on other sites More sharing options...
ScoobyDont Posted December 28, 2017 Author Share Posted December 28, 2017 Right OK this is the full code with forms etc etc The date format I am using is yyyy-dd-mm I have to use this else Bootstraps Date picker fails and doesnt insert date into DB First the complete form <?php include "includes/header.php"; include "includes/sidebar.php"; $addnew_error_message = ''; $addnew_added_message = ''; if (!empty($_POST['btnAddNew'])) { if ($_POST['reg'] == "") { $addnew_error_message = 'Registration is required!'; } else if ($_POST['chassis'] == "") { $addnew_error_message = 'Chassis No is required!'; } else if ($_POST['handover'] == "") { $addnew_error_message = 'Handover Date is required!'; } else if ($_POST['dbright'] == "") { $addnew_error_message = 'Handover Date is required!'; } else if ($app->isReg($_POST['reg'])) { $addnew_error_message = 'That Reg No is being processed!'; } else { $user_id = $app->Addnew($_POST['reg'], $_POST['chassis'], $_POST['handover'], $_POST['pdi'], $_POST['tlplates'], $_POST['aplates'], $_POST['dbright'], $_POST['lshine'], $_POST['smats'], $_POST['lmats'], $_POST['mflaps'], $_POST['other']); } $addnew_added_message = 'The vehicle has been added.'; } ?> <div class="page-header"> <h1>New Car Prep</h1> </div><!-- /.page-header --> <div class="row"> <div class="col-xs-12"> <div class="col-md-6 col-md-offset-3 well"> <h4><strong>Add New Car Prep</strong></h4> <br> <?php if ($addnew_error_message != "") { echo '<div class="alert alert-danger"><strong>Error: </strong> ' . $addnew_error_message . '</div>'; } else if ($addnew_added_message != "") { echo '<div class="alert alert-success" id ><strong>Thank You: </strong> ' . $addnew_added_message . '</div>'; } ?> <form action="" method="post"> <div class="form-group"> <h4>Reg</h4> <input type="text" name="reg" class="form-control"/> </div> <div class="form-group"> <h4>Chassis (Last Six)</h4> <input type="text" name="chassis" class="form-control"/> </div> <div class="form-group"> <h4>Handover Date</h4> <div class="row"> <div class="col-xs-8 col-sm-11"> <div class="input-group"> <input type="text" class="form-control date-picker" name="handover" id="id-date-picker-1" data-date-format="yyyy-dd-mm" /> <span class="input-group-addon"> <i class="fa fa-calendar bigger-110"></i> </span> </div> </div> </div> </div> <br> <h4><strong>Work Required:-</strong></h4> <br> <div class="row"> <div class="col-md-9"><h4 class="spacedout">Carry put PDI</h4></div> <div class="col-md-3"> <input type="hidden" name="pdi" value="Not Required" checked /> <div class="dlk-radio btn-group"> <label class="btn btn-success"> <input name="pdi" class="form-control" type="radio" value="Yes"> <i class="fa fa-check glyphicon glyphicon-ok"></i> </label> <label class="btn btn-danger"> <input name="pdi" class="form-control" type="radio" value="No"> <i class="fa fa-close glyphicon glyphicon-remove"></i> </label> </div> </div> </div> <br> <div class="row"> <div class="col-md-9"><h4 class="spacedout">T L Plates</h4></div> <div class="col-md-3"> <input type="hidden" name="tlplates" value="Not Required" checked /> <div class="dlk-radio btn-group"> <label class="btn btn-success"> <input name="tlplates" class="form-control" type="radio" value="Yes"> <i class="fa fa-check glyphicon glyphicon-ok"></i> </label> <label class="btn btn-danger"> <input name="tlplates" class="form-control" type="radio" value="No"> <i class="fa fa-close glyphicon glyphicon-remove"></i> </label> </div> </div> </div> <br> <div class="row"> <div class="col-md-9"><h4 class="spacedout">Agency Plates</h4></div> <div class="col-md-3"> <input type="hidden" name="aplates" value="Not Required" checked /> <div class="dlk-radio btn-group"> <label class="btn btn-success"> <input name="aplates" class="form-control" type="radio" value="Yes"> <i class="fa fa-check glyphicon glyphicon-ok"></i> </label> <label class="btn btn-danger"> <input name="aplates" class="form-control" type="radio" value="No"> <i class="fa fa-close glyphicon glyphicon-remove"></i> </label> </div> </div> </div> <br> <div class="row"> <div class="col-md-9"><h4 class="spacedout">Diamond Bright</h4></div> <div class="col-md-3"> <input type="hidden" name="dbright" value="Not Required" checked /> <div class="dlk-radio btn-group"> <label class="btn btn-success"> <input name="dbright" class="form-control" type="radio" value="Yes"> <i class="fa fa-check glyphicon glyphicon-ok"></i> </label> <label class="btn btn-danger"> <input name="dbright" class="form-control" type="radio" value="No"> <i class="fa fa-close glyphicon glyphicon-remove"></i> </label> </div> </div> </div> <br> <div class="row"> <div class="col-md-9"><h4 class="spacedout">Lifeshine</h4></div> <div class="col-md-3"> <input type="hidden" name="lshine" value="Not Required" checked /> <div class="dlk-radio btn-group"> <label class="btn btn-success"> <input name="lshine" class="form-control" type="radio" value="Yes"> <i class="fa fa-check glyphicon glyphicon-ok"></i> </label> <label class="btn btn-danger"> <input name="lshine" class="form-control" type="radio" value="No"> <i class="fa fa-close glyphicon glyphicon-remove"></i> </label> </div> </div> </div> <br> <div class="row"> <div class="col-md-9"><h4 class="spacedout">Standard Floor Mats</h4></div> <div class="col-md-3"> <input type="hidden" name="smats" value="Not Required" checked /> <div class="dlk-radio btn-group"> <label class="btn btn-success"> <input name="smats" class="form-control" type="radio" value="Yes"> <i class="fa fa-check glyphicon glyphicon-ok"></i> </label> <label class="btn btn-danger"> <input name="smats" class="form-control" type="radio" value="No"> <i class="fa fa-close glyphicon glyphicon-remove"></i> </label> </div> </div> </div> <br> <div class="row"> <div class="col-md-9"><h4 class="spacedout">Luxury Floor Mats</h4></div> <div class="col-md-3"> <input type="hidden" name="lmats" value="Not Required" checked /> <div class="dlk-radio btn-group"> <label class="btn btn-success"> <input name="lmats" class="form-control" type="radio" value="Yes"> <i class="fa fa-check glyphicon glyphicon-ok"></i> </label> <label class="btn btn-danger"> <input name="lmats" class="form-control" type="radio" value="No"> <i class="fa fa-close glyphicon glyphicon-remove"></i> </label> </div> </div> </div> <br> <div class="row"> <div class="col-md-9"><h4 class="spacedout">Mudflaps</h4></div> <div class="col-md-3"> <input type="hidden" name="mflaps" value="Not Required" checked /> <div class="dlk-radio btn-group"> <label class="btn btn-success"> <input name="mflaps" class="form-control" type="radio" value="Yes"> <i class="fa fa-check glyphicon glyphicon-ok"></i> </label> <label class="btn btn-danger"> <input name="mflaps" class="form-control" type="radio" value="No"> <i class="fa fa-close glyphicon glyphicon-remove"></i> </label> </div> </div> </div> <br> <div class="form-group"> <h4>Other:</h4> <textarea class="form-control" rows="5" name="other"></textarea> </div> <div class="form-group"> <input type="submit" name="btnAddNew" class="btn btn-primary btn-lg btn-block" value="Add New Vehicle"/> </div> </form> </div> </div><!-- /.col --> </div><!-- /.row --> Here is the complete function public function Addnew($reg, $chassis, $handover, $pdi, $tlplates, $aplates, $dbright, $lshine, $smats, $lmats, $mflaps, $other) { try { $query = $db->prepare("INSERT INTO addnewvehicle(reg, chassis, handover, pdi, tlplates, aplates, dbright, lshine, smats, lmats, mflaps, other) VALUES (:reg,:chassis,:handover, :pdi, :tlplates, :aplates, :dbright, :lshine, :smats, :lmats, :mflaps, :other)"); $query->bindParam("reg", $reg, PDO::PARAM_STR); $query->bindParam("chassis", $chassis, PDO::PARAM_STR); $query->bindParam("handover", $handover, PDO::PARAM_STR); $query->bindParam("pdi", $pdi, PDO::PARAM_STR); $query->bindParam("tlplates", $tlplates, PDO::PARAM_STR); $query->bindParam("aplates", $aplates, PDO::PARAM_STR); $query->bindParam("dbright", $dbright, PDO::PARAM_STR); $query->bindParam("lshine", $lshine, PDO::PARAM_STR); $query->bindParam("smats", $smats, PDO::PARAM_STR); $query->bindParam("lmats", $lmats, PDO::PARAM_STR); $query->bindParam("mflaps", $mflaps, PDO::PARAM_STR); $query->bindParam("other", $other, PDO::PARAM_STR); $query->execute(); return $db->lastInsertId(); } catch (PDOException $e) { exit($e->getMessage()); } } Currently with the above everything is working fine Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554959 Share on other sites More sharing options...
ginerjm Posted December 28, 2017 Share Posted December 28, 2017 OK - now you have given us the supposed code. My, my, my - you do like divs! Anyway - Where is this 'hoverdate'? I did a search of both blocks of code and don't find it anywhere? Plus - I don't see where you are doing any of the suggestions that you were given to do this task. Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554960 Share on other sites More sharing options...
ScoobyDont Posted December 28, 2017 Author Share Posted December 28, 2017 Sorry I have stripped everything back out, so I can get the DB to accept the form data again as I kept getting errors hoverdate = handover now sorry should of been clearer And yes I do suffer from divititus Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554961 Share on other sites More sharing options...
Barand Posted December 28, 2017 Share Posted December 28, 2017 The date format I am using is yyyy-dd-mm That is a really weird format. And where do the picking date and the other five dates get inserted? Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554962 Share on other sites More sharing options...
ginerjm Posted December 28, 2017 Share Posted December 28, 2017 Good luck. You're too difficult to work with.... Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554963 Share on other sites More sharing options...
mac_gyver Posted December 28, 2017 Share Posted December 28, 2017 i have some recommendations about the way you are implementing this, that will reduce and simplify the code, making it easier to write, test, and debug what you are doing. 1) use type='date' for the hoverdate form field. this will make use of the html5 datepicker. 2) use meaningful names for form fields, php variables, database columns, function names, ... and use the same name through out for each item. this will allow anyone, now and when looking at the code at some point in the future, to more easily deduce what it is doing. if a name is made up of multiple words, separate them with underscores _ 3) the form processing code should go above the start of the html document. 4) your validation logic is only detecting and reporting the first validation error. if there are multiple errors, the user will have to keep resubmitting the form to see each one. if you use an array to hold the validation error messages, you can easily validate all the input data at once and report all the errors at once. the error array is also an error flag. if the array is empty(), there are no errors. after the end of the validation, you can just test if the array is empty() to decide if you are going to use the submitted data. 5) you need to repopulate the form fields with any submitted data, so that the user doesn't need to keep filling in the same information when there are validation errors. 6) make your Addnew() and any other functions, general purpose, by passing an array of input data to them, so that you don't need to keep changing the list of call-time parameters in the function definition and in the main code that's calling the function. 7) for most database errors, there's no good reason to catch them yourself. you also shouldn't output the raw database errors onto a web site. if you remove the try/catch logic from your code, php will catch the exception and use its error_reporting, display_errors, and log_errors settings to control what happens with the actual error information. when learning, developing, and debugging code, you should display all errors. when on a live/public server, you should log all errors. in most cases, there's no good reason to explicitly bind input parameters/values for a prepared query. just supply an array of data to the execute() method call. 9) the repeated sections in the form, that just differ in the title/label and field names, should be dynamically produced using php code, so that you don't have to sit banging on a keyboard doing work that you can get the computer to do for you. if you were already doing this, it would make it easier to change the form so that it repopulates the fields with the previously submitted data, because you would only need to add code for each different type of field in the dynamic code, not for each and every field in the form. lastly, i'll call your attention to reply #5 in this thread. there is no good reason to store derived data. if these dates are all calculated from the hand over or other submitted date, don't store them in the database table. you can query at any point using any date/time offset relative to the submitted date, to find matching data. Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554965 Share on other sites More sharing options...
ScoobyDont Posted December 28, 2017 Author Share Posted December 28, 2017 Sorry, I am not the worlds best at explaining something I am a novice at but I will try and explain it a little better "The Format is yyyy-mm-dd" I used the same format on the datepicker that Barand gave me of Y-m-d to try and help me and I changed it here(in red) jQuery(function($) { $('.date-picker').datepicker({ startDate: '+10d', format: 'yyyy-mm-dd', autoclose: true, }) //show datepicker when clicking on the icon .next().on(ace.click_event, function(){ $(this).prev().focus(); }); But it gave me a bad output so changed it to yyyy-mm-dd so I could get the date into the database without throwing up an error. When the user posts the form I want the other dates calculated and stored in said DB, the user has no control over these dates the only date they can select is the "handover" which as you can see the first date they can select is 10days after todays date So what I need is date1 = 7days before "handover" date date2 = 5days before "handover" date and so on down to 1day before "handover" date Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554966 Share on other sites More sharing options...
ScoobyDont Posted December 28, 2017 Author Share Posted December 28, 2017 lastly, i'll call your attention to reply #5 in this thread. there is no good reason to store derived data. if these dates are all calculated from the hand over or other submitted date, don't store them in the database table. you can query at any point using any date/time offset relative to the submitted date, to find matching data. Right Ok, Thank you so much for that I will look into validating the form later and the other parts left me scratching my head, going back to the quote above and #5 The end result is that I have a calendar and in the calendar I want to put events using the "handover" date as the Primary Date 5 days Prior to handover date I would like to put an event in the calendar for "Vehicle Booked for PDI" 2 Days Prior to handover date I would like to put an event in the calendar for "Vehicle Booked for Valet" So you are saying this would be better using queries and not storing the dates in the DB Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554967 Share on other sites More sharing options...
Barand Posted December 28, 2017 Share Posted December 28, 2017 The dates are all derived from the one handover date. Whether you derive them in the query on in the php code will depend on circumstance. The point is that only the one date needs to be stored. Quote Link to comment https://forums.phpfreaks.com/topic/306006-taking-3-days-off-the-input-date-of-the-user/#findComment-1554968 Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.