soil-report-pdf.php 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431
  1. <!doctype html>
  2. <html lang="en">
  3. <head>
  4. <title>[[*longtitle]] | [[++site_name]]</title>
  5. <base href="[[!++site_url]]" >
  6. <meta charset="[[++modx_charset]]" >
  7. <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no" >
  8. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" >
  9. <meta name="keywords" content="[[*introtext]]" >
  10. <meta name="description" content="[[*description]]" >
  11. [[!Profile]]
  12. <link rel="icon" href="client-assets/images/favicon.ico?v=2" type="image/x-icon" >
  13. <script src="https://code.jquery.com/jquery-3.3.1.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script>
  14. <link href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous" rel="stylesheet" type="text/css" />
  15. <link href="https://ajax.googleapis.com/ajax/libs/jqueryui/1.12.1/themes/smoothness/jquery-ui.css" rel="stylesheet" type="text/css" />
  16. <link href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.9.0/css/all.css" integrity="sha256-PF6MatZtiJ8/c9O9HQ8uSUXr++R9KBYu4gbNG5511WE=" crossorigin="anonymous" rel="stylesheet" type="text/css" />
  17. <link type="text/css" href="/client-assets/weather-icons/css/weather-icons.min.css?version=1.16" rel="stylesheet" type="text/css" />
  18. <link href="https://cdnjs.cloudflare.com/ajax/libs/magnific-popup.js/1.1.0/magnific-popup.css" rel="stylesheet" type="text/css" />
  19. <script type="text/javascript" src="https://use.fontawesome.com/1e2844bb90.js"></script>
  20. <link href="/client-assets/css/dashboard.css" rel="stylesheet" type="text/css" />
  21. <script src="https://unpkg.com/gijgo@1.9.11/js/gijgo.min.js" type="text/javascript"></script>
  22. <link href="https://unpkg.com/gijgo@1.9.11/css/gijgo.min.css" rel="stylesheet" type="text/css" />
  23. <script src="client-assets/js/skycons.js" type="text/javascript"></script>
  24. <link href="client-assets/home/css/graphing.css" rel="stylesheet" type="text/css" media="screen" />
  25. <link href="client-assets/home/css/alux.min.css" rel="stylesheet" type="text/css" media="screen" />
  26. <script src="https://cdnjs.cloudflare.com/ajax/libs/html2pdf.js/0.9.3/html2pdf.bundle.min.js" integrity="sha512-YcsIPGdhPK4P/uRW6/sruonlYj+Q7UHWeKfTAkBW+g83NKM+jMJFJ4iAPfSnVp7BKD4dKMHmVSvICUbE/V1sSw==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
  27. <style>
  28. @media print {
  29. @page {
  30. size: A4 portrait;
  31. }
  32. @page :left {
  33. margin-left: 0.5cm;
  34. }
  35. @page :right {
  36. margin-right: 0.5cm;
  37. }
  38. @page :top {
  39. margin-top: 0cm;
  40. }
  41. @page :bottom {
  42. margin-bottom: 0cm;
  43. }
  44. }
  45. </style>
  46. </head>
  47. <body>
  48. <div class="container">
  49. <div class="row">
  50. <?php
  51. // Replace Logo with Customer Logo if supplied.
  52. $client = '';
  53. echo "<div class='col-md-3'>";
  54. if ($client === "") {
  55. echo "<img class='img-fluid' src='client-assets/images/crop-monitor.png' alt='Crop Monitor' >";
  56. } else {
  57. echo "<img class='img-fluid' src='client-assets/images/crop-monitor.png' alt='Crop Monitor' >";
  58. }
  59. //echo "<span class='col'></span>";
  60. //Client Test Description
  61. if ($client === "") {
  62. echo "";
  63. } else {
  64. echo "<img class='img-fluid' src='client-assets/images/crop-monitor.png' alt='Crop Monitor' >";
  65. }
  66. echo "</div>";
  67. echo "<div class='col-md-9'></div>";
  68. ?>
  69. </div>
  70. <?php
  71. $result = null;
  72. $client_id = (int) (isset($_GET["cid"])) ? $_GET["cid"] : ""; // client number
  73. $record_id = (float) (isset($_GET["rid"])) ? $_GET["rid"] : ""; // record number
  74. $rand_id = (float) (isset($_GET["rand"])) ? $_GET["rand"] : "";
  75. $today = date('jS F Y');
  76. //Database connection
  77. //$con = mysqli_connect("localhost", "root", "R3M0T31", "cropmonitor");
  78. $con = mysqli_connect("localhost", "cropmonitor", "brvnCcaEYxlPCS3", "cropmonitor");
  79. // Check connection
  80. if (mysqli_connect_errno()) {
  81. echo "Failed to connect to MySQL: " . mysqli_connect_error();
  82. }
  83. // Get results from database
  84. $result = mysqli_query($con, "SELECT * FROM `soil_records` WHERE `id` = '" . $record_id . "' AND `rand` = '" . $rand_id . "' ");
  85. if ($result === FALSE) {
  86. die(mysqli_error($con)); // TODO: better error handling
  87. echo "User Profile incorrect";
  88. } else {
  89. while ($row = mysqli_fetch_array($result)) {
  90. //TEST
  91. $client = $row['client_name'];
  92. $address = $row['site_address'];
  93. $state = $row['state_postcode'];
  94. $email = $row['email'];
  95. $labNo = $row['lab_no'];
  96. $sampleDate = $row['date_sampled'];
  97. $sample = $row['site_id'];
  98. $crop = $row['sample_id'];
  99. if ($rand_id === NULL) { //if element not tested hide row
  100. } else {
  101. ?>
  102. <table class='title'>
  103. <tbody>
  104. <tr>
  105. <th class='col-20'></th>
  106. <th class='col-20'></th>
  107. <th class='col-20'></th>
  108. <th class='col-20'></th>
  109. <th class='col-20'></th>
  110. </tr>
  111. <tr>
  112. <td class='right'><b>DATE:</b></td>
  113. <td class='left'><?php echo $today; ?></td>
  114. <td></td>
  115. <td class='right'><b>SAMPLE ID:</b></td>
  116. <td class='left'><?php echo $sample; ?></td>
  117. </tr>
  118. <tr>
  119. <td class='right'><b>CLIENT:</b></td>
  120. <td class='left'><?php echo $client; ?></td>
  121. <td></td>
  122. <td class='right'><b>DATE SAMPLED:</b></td>
  123. <td class='left'><?php echo $sampleDate; ?></td>
  124. </tr>
  125. <tr>
  126. <td class='right'><b>ADDRESS:</b></td>
  127. <td class='left'><?php echo $address; ?></td>
  128. <td></td>
  129. <td class='right'><b>LAB NUMBER:</b></td>
  130. <td class='left'><?php echo $labNo; ?></td>
  131. </tr>
  132. <tr>
  133. <td class='right'><b> </b></td>
  134. <td class='left'><?php echo $state; ?></td>
  135. <td></td>
  136. <td class='right'><b>CROP:</b></td>
  137. <td class='left'><?php echo $crop; ?></td>
  138. </tr>
  139. <tr>
  140. <td class='right'><b> </b></td>
  141. <td class='left'><?php echo $email; ?></td>
  142. <td></td>
  143. <td class='right'></td>
  144. <td class='left'></td>
  145. </tr>
  146. </tbody>
  147. </table>
  148. <?php
  149. }
  150. }
  151. }
  152. mysqli_close($con);
  153. /*
  154. <div class="row pt-3">
  155. <div class="col-md-2 text-right"><b>DATE:</b></div>
  156. <div class="col-md-3 text-left"><?php echo $today; ?></div>
  157. <div class="col-md-1"></div>
  158. <div class="col-md-3 text-right"><b>SAMPLE ID:</b></div>
  159. <div class="col-md-3 text-left"><?php echo $sample; ?></div>
  160. </div>
  161. <div class="row pt-1">
  162. <div class="col-md-2 text-right"><b>CLIENT:</b></div>
  163. <div class="col-md-3 text-left"><?php echo $client; ?></div>
  164. <div class="col-md-1"></div>
  165. <div class="col-md-3 text-right"><b>DATE SAMPLED:</b></div>
  166. <div class="col-md-3 text-left"><?php echo $sampleDate; ?></div>
  167. </div>
  168. <div class="row pt-1">
  169. <div class="col-md-2 text-right"><b>Address:</b></div>
  170. <div class="col-md-3 text-left"><?php echo $address; ?></div>
  171. <div class="col-md-1"></div>
  172. <div class="col-md-3 text-right"><b>Lab Number:</b></div>
  173. <div class="col-md-3 text-left"><?php echo $labNo; ?></div>
  174. </div>
  175. <div class="row pt-1">
  176. <div class="col-md-2 text-right"><b></b></div>
  177. <div class="col-md-3 text-left"><?php echo $state; ?></div>
  178. <div class="col-md-1"></div>
  179. <div class="col-md-3 text-right"><b>CROP:</b></div>
  180. <div class="col-md-3 text-left"><?php echo $crop; ?></div>
  181. </div>
  182. <div class="row pt-1">
  183. <div class="col-md-2 text-right"><b></b></div>
  184. <div class="col-md-3 text-left"><?php echo $email; ?></div>
  185. <div class="col-md-1"></div>
  186. <div class="col-md-3 text-right"><b></b></div>
  187. <div class="col-md-3 text-left"></div>
  188. </div>
  189. */
  190. ?>
  191. <!-- Graph Button -->
  192. <div class="d-print-none">
  193. <div class="row p-2">
  194. <div class="col">
  195. [[!soilAnalysisGraphButton]]
  196. </div>
  197. <div class="col">
  198. <div class="form-status-holder"></div>
  199. </div>
  200. </div>
  201. </div>
  202. <!-- GRAPH BANNER -->
  203. <div class="row">
  204. <div class="col-md-12 text-center font-weight-bold h4">Soil Analysis Summary</div>
  205. </div>
  206. <!-- CHART HEADER -->
  207. <div class="row bg-dark text-white p-2 mt-3">
  208. <div class="text-center col-md-12 h5">Total kilograms per hectare of each element needed to balance soil in this test</div>
  209. </div>
  210. <div class="row">
  211. <div class="">
  212. [[!soilAnalysisReportCalcs? &symbol=`Ca` &element=`BS_ca_ppm` &min=`ca_ppm_min` &max=`ca_ppm_max` &nutrient=`Calcium` &type=`kg` &class=`col`]]
  213. [[!soilAnalysisReportCalcs? &symbol=`Mg` &element=`BS_mg_ppm` &min=`mg_ppm_min` &max=`mg_ppm_max` &nutrient=`Magnesium` &type=`kg` &class=`col`]]
  214. [[!soilAnalysisReportCalcs? &symbol=`K` &element=`BS_k_ppm` &min=`k_ppm_min` &max=`k_ppm_max` &nutrient=`Potasium` &type=`kg` &class=`col`]]
  215. [[!soilAnalysisReportCalcs? &symbol=`Na` &element=`BS_na_ppm` &min=`na_ppm_min` &max=`na_ppm_max` &nutrient=`Sodium` &type=`kg` &class=`col`]]
  216. [[!soilAnalysisReportCalcs? &symbol=`P` &element=`p_colwell` &min=`` &max=`` &nutrient=`Phosphate` &type=`kg` &class=`col`]]
  217. [[!soilAnalysisReportCalcs? &symbol=`S` &element=`s_morgan` &min=`` &max=`` &nutrient=`Sulfur` &type=`kg &class=`col`]]
  218. [[!soilAnalysisReportCalcs? &symbol=`Mn` &element=`mn_dtpa` &min=`` &max=`` &nutrient=`Manganese` &type=`kg` &class=`col`]]
  219. [[!soilAnalysisReportCalcs? &symbol=`Fe` &element=`fe_dtpa` &min=`` &max=`` &nutrient=`Iron` &type=`kg` &class=`col`]]
  220. [[!soilAnalysisReportCalcs? &symbol=`Zn` &element=`zn_dtpa` &min=`` &max=`` &nutrient=`Zinc` &type=`kg` &class=`col`]]
  221. [[!soilAnalysisReportCalcs? &symbol=`Cu` &element=`cu_dtpa` &min=`` &max=`` &nutrient=`Copper` &type=`kg` &class=`col`]]
  222. [[!soilAnalysisReportCalcs? &symbol=`AmN` &element=`NH3_N` &min=`` &max=`` &nutrient=`AmNitrogen` &type=`kg` &class=`col`]]
  223. [[!soilAnalysisReportCalcs? &symbol=`B` &element=`b_cacl2` &min=`` &max=`` &nutrient=`Boron` &type=`kg` &class=`col`]]
  224. [[!soilAnalysisReportCalcs? &symbol=`NN` &element=`NO3_N` &min=`` &max=`` &nutrient=`NNitrogen` &type=`kg` &class=`col`]]
  225. </div>
  226. </div>
  227. <hr>
  228. <!-- **************** START OF FORM DATA **************** -->
  229. <form class="report-form" method="post">
  230. <input class="" hidden type="text" name="id" id="id" value="[[+modx.user.id]]" >
  231. <!-- **************** OVERVIEW SECTION **************** -->
  232. <div class="row bg-dark text-white p-2 mt-3">
  233. <div class="text-center col-md-12 h5 ">Overview</div>
  234. </div>
  235. <div class="row">
  236. <div class="col-md-12 p-0" >
  237. <textarea class="form-control rounded-0" rows="5" id="overview" name="overview" ></textarea>
  238. </div>
  239. </div>
  240. <hr>
  241. <div class="row bg-dark text-white p-2 mt-3">
  242. <div class="text-center col-md-12 h5 ">Ideal Soil Balancing Program for One Season of a FIVE YEAR Plan</div>
  243. </div>
  244. <div class="">
  245. [[!soilProgramCalcs? &symbol=`Ca` &element=`BS_ca_ppm` &min=`ca_ppm_min` &max=`ca_ppm_max` &nutrient=`Calcium` &type=`kg`]]
  246. [[!soilProgramCalcs? &symbol=`Ca` &element=`BS_ca_ppm` &min=`ca_ppm_min` &max=`ca_ppm_max` &nutrient=`Calcium` &type=`kg`]]
  247. [[!soilProgramCalcs? &symbol=`Ca` &element=`BS_ca_ppm` &min=`ca_ppm_min` &max=`ca_ppm_max` &nutrient=`Calcium` &type=`kg`]]
  248. [[!soilProgramCalcs? &symbol=`Ca` &element=`BS_ca_ppm` &min=`ca_ppm_min` &max=`ca_ppm_max` &nutrient=`Calcium` &type=`kg`]]
  249. [[!soilProgramCalcs? &symbol=`Ca` &element=`BS_ca_ppm` &min=`ca_ppm_min` &max=`ca_ppm_max` &nutrient=`Calcium` &type=`kg`]]
  250. </div>
  251. <hr>
  252. <!-- **************** FOLIAR PROGRAM SECTION **************** -->
  253. <div class="row bg-dark text-white p-2 mt-3">
  254. <div class="text-center col-md-12 h5" ><input type="text" class="text-center form-control-plaintext text-white border-dark bg-dark" name="header1" id="header1" value="Foliar Program"></div>
  255. </div>
  256. <div class="row">
  257. <div class="col-md-12 p-0" >
  258. <textarea class="form-control rounded-0" rows="5" id="foliar_Details" name="foliar_Details"></textarea>
  259. </div>
  260. </div>
  261. <!-- **************** MICROBE PROGRAM SECTION **************** -->
  262. <div class="row bg-dark text-white p-2 mt-3">
  263. <div class="text-center col-md-12 h5">Microbe Program</div>
  264. </div>
  265. <div class="row">
  266. <div class="col-md-12 p-0" >
  267. <textarea class="form-control rounded-0" rows="5" id="microbe_Program" name="microbe_Program" ></textarea>
  268. </div>
  269. </div>
  270. <div class="row">
  271. <p style="font-style: italic; font-size: 9px;">Any recommendations provided by Cropmonitor are advice only, We are not paid consultants and we are not covered to accept responsibiliy for any of our suggestions. As no control can be exercised over storage, handling, mixing application or use, or weather, plant or soil conditions before, during or after application (all of which may affect the preformance of our program), no responsibility for, or liability for any failure in performance, losses, damage or injuries consequential or otherwise, arisiing form such storage mixng application or use will be accepted under any circumstances whatsoever. The buyer assumes all responsibility for the use of any of our products.</p>
  272. </div>
  273. </form>
  274. </div>
  275. <script type="text/javascript">
  276. $(document).ready(function(){
  277. var timeoutId;
  278. $('form textarea, form input').on('input propertychange change', function() {
  279. console.log('Textarea Change');
  280. clearTimeout(timeoutId);
  281. timeoutId = setTimeout(function() {
  282. // Runs 1 second (1000 ms) after the last change
  283. saveToDB();
  284. }, 1000);
  285. });
  286. function saveToDB() {
  287. console.log('Saving to the db');
  288. form = $('.report-form');
  289. $.ajax({
  290. url: "[[~58]]",
  291. type: "POST",
  292. data: form.serialize(), // serializes the form's elements.
  293. beforeSend: function(xhr) {
  294. // Let them know we are saving
  295. $('.form-status-holder').html('Saving...');
  296. },
  297. success: function(data) {
  298. var jqObj = jQuery(data); // You can get data returned from your ajax call here. ex. jqObj.find('.returned-data').html()
  299. // Now show them we saved and when we did
  300. var d = new Date();
  301. $('.form-status-holder').html('Saved! Last: ' + d.toLocaleTimeString());
  302. },
  303. });
  304. }
  305. // This is just so we don't go anywhere
  306. // and still save if you submit the form
  307. $('.report-form').submit(function(e) {
  308. saveToDB();
  309. e.preventDefault();
  310. });
  311. });
  312. </script>
  313. </div>
  314. <!--
  315. <script src="https://cloud.tinymce.com/stable/tinymce.min.js?apiKey=xcotawi18mg1imp8im144buq68h9g3ndd3c9c8215w8qu3ld"></script>
  316. <script>
  317. tinymce.init({
  318. selector: 'textarea',
  319. menubar: false,
  320. toolbar: 'bold italic | alignleft aligncenter alignright alignjustify | bullist numlist | removeformat',
  321. plugins: 'autosave',
  322. autosave_interval: '20s'
  323. });
  324. </script>
  325. -->
  326. <!-- jQuery first, then Popper.js, then Bootstrap JS -->
  327. <script type="text/javascript" src="https://code.jquery.com/ui/1.12.1/jquery-ui.min.js" integrity="sha256-VazP97ZCwtekAsvgPBSUwPFKdrwD3unUfSGVYrahUqU=" crossorigin="anonymous"></script>
  328. <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script>
  329. <script type="text/javascript" src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js" integrity="sha384-ChfqqxuZUCnJSK3+MXmPNIyE6ZbWh2IMqE241rYiqJxyMiZ6OW/JmZQ5stwEULTy" crossorigin="anonymous"></script>
  330. <script type="text/javascript">
  331. addEventListener("load", function() {
  332. setTimeout(hideURLbar, 0);
  333. }, false);
  334. function hideURLbar(){
  335. window.scrollTo(0,1);
  336. }
  337. </script>
  338. <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.bundle.min.js" integrity="sha384-xrRywqdh3PHs8keKZN+8zzc5TX0GRTLCcmivcbNJWm2rs5C8PRhcEn3czEjhAO9o" crossorigin="anonymous"></script>
  339. <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery-easing/1.4.1/jquery.easing.js"></script>
  340. <script src="https://cdnjs.cloudflare.com/ajax/libs/magnific-popup.js/1.1.0/jquery.magnific-popup.js"></script>
  341. <script>
  342. //https://github.com/eKoopmans/html2pdf.js
  343. $('.downloadPDF').click(function () {
  344. var element = document.getElementById('content'); //document.createElement("body");
  345. element.classList.remove('screen');
  346. element.classList.add('print');
  347. var opt = {
  348. margin: 3,
  349. filename: 'soil-analysis.pdf',
  350. image: { type: 'jpeg', quality: 1.0 },
  351. html2canvas: { scale: 2, letterRendering: true, windowWidth: 1024 }, //, windowWidth: 1024
  352. jsPDF: { orientation: 'portrait', unit: 'mm', format: 'a4', putOnlyUsedFonts: true, floatPrecision: 'smart', }
  353. };
  354. html2pdf()
  355. .from(element)
  356. .toPdf()
  357. .set(opt)
  358. .save()
  359. .then(function(){
  360. element.classList.remove('print');
  361. element.classList.add('screen');
  362. });
  363. });
  364. </script>
  365. </body>
  366. </html>