-
Posts
597 -
Joined
-
Last visited
Everything posted by Adamhumbug
-
I have an ajax function function getConsumablePrices($itemId, $qty) { $.ajax({ type: 'post', data: { "ajax": 'getConsumablePriceByQty', 'itemId': $itemId, 'quantity': $qty }, dataType: 'json', success: function(resp) { console.log(resp) } }) } This triggers a php function which after doing a fetch all returns an array that looks like this { "id": 1, "item_id": 19, "min_qty": 1, "max_qty": 499, "GBP": 500, "USD": 750, "CAD": 875 } I am trying to access individual elements in this object. I have tried console.log(resp['CAD'] and resp.CAD but i just see undefined. How would one go about pulling a single element out of this array?
-
(Advice) - Storing price break points in database
Adamhumbug replied to Adamhumbug's topic in PHP Coding Help
That could be a winner - let me have a play with that and i will report back -
I have a system that creates quotes. Most items are simple, order 2 its 2 times the price, order 10, 10 times the price ect. I have some items that break at certain intervals (the intervals are all different.) Item A - price is each appart from under 500 where it is a flat £500. 1 - 499 £500 500 -999 £1.00 1,000 - 1,999 £0.90 2,000 - 2,999 £0.80 3,000 - 5,999 £0.70 6,000 - 9,999 £0.60 10,000 +£0.50 Item B has a similar plan but the breaks are different. I have no idea where to start with this and am struggling to come up with a reasonable database structure that doesnt seem overkill. Also, i have shown the price in GBP but we also have a price for USD, CAD and EUR which follows the same break points.
-
tzone tdiff SYSTEM 02:00:00
-
I have an application that records the time that someone last logs in using CURRENT_TIMESTAMP The time set in the database is 1 hour ahead of the actual time suggesting that the time zones are out. I am in the UK. I have a function that works out the time since their last log on and this is reporting 2 hours ago. Any advice on time zones for the data base and application?
-
I have a log on page that is being handled with ajax and going to a php function. The php function returns some text if the log on is not successful - this is being put into an alert that shows on the page. If the log in is successful there is a header to redirect to the logged in page. The issue is that when logging in successfully, the html that wrapped the error messages is now wrapping the whole logged on page that i am rediurected to. This is the script <script> $('#login').click(function() { $em = $('#email').val(); $pw = $('#password').val(); $.ajax({ type: 'post', data: { 'ajax': 'login', 'email': $em, 'pass': $pw }, success: function(resp) { if(resp != 'success'){ $('.alert-container').append("<div class='row alert alert-warning text-center'><span class='text-center'>"+resp+"</span></div>") } } }) }) </script> and this is the php - i added the return success to try and avoid this but it has been unsuccesful in remedying my issue. function login($email, $pass){ include 'includes/dbconn.php'; $sql = "SELECT pass, id, banned from user where email = :email"; $stmt = $pdo->prepare($sql); $stmt->execute([ ':email' => $email ]); if ($stmt->rowCount() != 1) { return "This is a problem with your account, please email the administrator."; } else { $row = $stmt->fetch(); if (password_verify($pass, $row['pass'])) { $_SESSION['userId'] = $row['id']; header('Location: home.php'); return "success"; } else { return "Your username and password combination do not match."; } } }
-
Calculating "time since" is giving me a negative (CLOSEME)
Adamhumbug replied to Adamhumbug's topic in PHP Coding Help
Hi, Can this please be closed. I dont know what i have done but it is now working - i cannot really give any more info. Could an admin please close this as it is not a helpful post. -
I have a database field that has a datetime in it of 2023-09-04 18:01:50.000000. When i try and work out how long ago that was - get a negative number. I have tried several "borrowed" functions to work this out and none of them are giving me what i expect. This is what i am using now: function get_time_ago($time_stamp) { $time_difference = strtotime('now') - $time_stamp; if ($time_difference >= 60 * 60 * 24 * 365.242199) { /* * 60 seconds/minute * 60 minutes/hour * 24 hours/day * 365.242199 days/year * This means that the time difference is 1 year or more */ return get_time_ago_string($time_stamp, 60 * 60 * 24 * 365.242199, 'year'); } elseif ($time_difference >= 60 * 60 * 24 * 30.4368499) { /* * 60 seconds/minute * 60 minutes/hour * 24 hours/day * 30.4368499 days/month * This means that the time difference is 1 month or more */ return get_time_ago_string($time_stamp, 60 * 60 * 24 * 30.4368499, 'month'); } elseif ($time_difference >= 60 * 60 * 24 * 7) { /* * 60 seconds/minute * 60 minutes/hour * 24 hours/day * 7 days/week * This means that the time difference is 1 week or more */ return get_time_ago_string($time_stamp, 60 * 60 * 24 * 7, 'week'); } elseif ($time_difference >= 60 * 60 * 24) { /* * 60 seconds/minute * 60 minutes/hour * 24 hours/day * This means that the time difference is 1 day or more */ return get_time_ago_string($time_stamp, 60 * 60 * 24, 'day'); } elseif ($time_difference >= 60 * 60) { /* * 60 seconds/minute * 60 minutes/hour * This means that the time difference is 1 hour or more */ return get_time_ago_string($time_stamp, 60 * 60, 'hour'); } else { /* * 60 seconds/minute * This means that the time difference is a matter of minutes */ return get_time_ago_string($time_stamp, 60, 'minute'); } } function get_time_ago_string($time_stamp, $divisor, $time_unit) { $time_difference = strtotime("now") - $time_stamp; $time_units = floor($time_difference / $divisor); settype($time_units, 'string'); if ($time_units === '0') { return 'less than 1 ' . $time_unit . ' ago'; } elseif ($time_units === '1') { return '1 ' . $time_unit . ' ago'; } else { /* * More than "1" $time_unit. This is the "plural" message. */ // TODO: This pluralizes the time unit, which is done by adding "s" at the end; this will not work for i18n! return $time_units . ' ' . $time_unit . 's ago'; } } when i echo what is being fed to this function i see 2023-09-04 18:01:04 and when strtotime i get 1693850464 the function is using now to work out the current time so i dont understand why it thinks my date is in the future.
-
Hi All, I have a user table where people will be creating a password. There is so much out there on what is the best way to do this but i wanted to get your feelings on what is the most up to date way to hash passwords that i am going to store. Is it salt or is that out dated now?
-
Duplicating Mysql Table rows but also updating some content
Adamhumbug replied to Adamhumbug's topic in PHP Coding Help
Love this - thank you so much -
Duplicating Mysql Table rows but also updating some content
Adamhumbug replied to Adamhumbug's topic in PHP Coding Help
-- phpMyAdmin SQL Dump -- version 4.9.11 -- https://www.phpmyadmin.net/ -- -- Host: db5014142045.hosting-data.io -- Generation Time: Sep 03, 2023 at 08:51 PM -- Server version: 10.6.12-MariaDB-1:10.6.12+maria~deb11-log -- PHP Version: 7.0.33-0+deb9u12 SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO"; SET AUTOCOMMIT = 0; START TRANSACTION; SET time_zone = "+00:00"; /*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */; /*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */; /*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */; /*!40101 SET NAMES utf8mb4 */; -- -- Database: `dbs11785372` -- -- -------------------------------------------------------- -- -- Table structure for table `quote_items` -- CREATE TABLE `quote_items` ( `id` int(11) NOT NULL, `quote_id` int(11) NOT NULL, `item_id` int(11) NOT NULL, `quantity` int(11) NOT NULL, `start_date` varchar(30) DEFAULT NULL, `end_date` varchar(30) DEFAULT NULL, `notes` varchar(250) NOT NULL, `amount_charged_each` float(10,2) NOT NULL, `original_price_each` float(10,2) NOT NULL, `chargable_units` float(10,2) NOT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COLLATE=utf8mb3_general_ci; -- -- Dumping data for table `quote_items` -- INSERT INTO `quote_items` (`id`, `quote_id`, `item_id`, `quantity`, `start_date`, `end_date`, `notes`, `amount_charged_each`, `original_price_each`, `chargable_units`) VALUES (168, 64, 1, 1, '', '', '12121212', 10000.00, 0.00, 1.00), (169, 64, 9, 1, '', '', '121212', 1250.00, 0.00, 1.00), (170, 64, 7, 1, '', '', '212', 3000.00, 0.00, 1.00), (171, 65, 1, 1, '', '', '', 10000.00, 0.00, 1.00), (172, 65, 9, 100, '', '', 'notwe', 1250.00, 0.00, 1.00); -- -- Indexes for dumped tables -- -- -- Indexes for table `quote_items` -- ALTER TABLE `quote_items` ADD PRIMARY KEY (`id`); -- -- AUTO_INCREMENT for dumped tables -- -- -- AUTO_INCREMENT for table `quote_items` -- ALTER TABLE `quote_items` MODIFY `id` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=173; COMMIT; /*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */; /*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */; /*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */; -- phpMyAdmin SQL Dump -- version 4.9.11 -- https://www.phpmyadmin.net/ -- -- Host: db5014142045.hosting-data.io -- Generation Time: Sep 03, 2023 at 08:51 PM -- Server version: 10.6.12-MariaDB-1:10.6.12+maria~deb11-log -- PHP Version: 7.0.33-0+deb9u12 SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO"; SET AUTOCOMMIT = 0; START TRANSACTION; SET time_zone = "+00:00"; /*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */; /*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */; /*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */; /*!40101 SET NAMES utf8mb4 */; -- -- Database: `dbs11785372` -- -- -------------------------------------------------------- -- -- Table structure for table `quote` -- CREATE TABLE `quote` ( `id` int(11) NOT NULL, `client_id` int(11) NOT NULL, `total_value` float(10,2) NOT NULL, `date_created` timestamp NOT NULL DEFAULT current_timestamp(), `job_id` int(11) NOT NULL, `version` int(11) NOT NULL, `name` varchar(200) NOT NULL, `currency` varchar(3) NOT NULL, `kit_delivery` varchar(30) NOT NULL, `kit_return` varchar(30) NOT NULL, `quote_status_id` int(11) NOT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3 COLLATE=utf8mb3_general_ci; -- -- Dumping data for table `quote` -- INSERT INTO `quote` (`id`, `client_id`, `total_value`, `date_created`, `job_id`, `version`, `name`, `currency`, `kit_delivery`, `kit_return`, `quote_status_id`) VALUES (65, 15, 135000.00, '2023-09-03 20:17:52', 7, 5, 'first', '1', '2023-09-01', '2023-09-03', 1), (71, 15, 135000.00, '2023-09-03 20:40:42', 7, 6, 'first', '1', '2023-09-01', '2023-09-03', 2); -- -- Indexes for dumped tables -- -- -- Indexes for table `quote` -- ALTER TABLE `quote` ADD PRIMARY KEY (`id`); -- -- AUTO_INCREMENT for dumped tables -- -- -- AUTO_INCREMENT for table `quote` -- ALTER TABLE `quote` MODIFY `id` int(11) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=72; COMMIT; /*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */; /*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */; /*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */; -
I have quotes and quotes have items. When i duplicate a quote i need to also duplicate the items. I have achieved this in one instance with the following. $sql2 = "INSERT INTO quote (client_id, total_value, job_id, version, name, currency, kit_delivery, kit_return, quote_status_id) SELECT client_id, total_value, job_id, (version+1), name, currency, kit_delivery, kit_return, 2 from quote where quote.id = :quoteId"; $stmt2 = $pdo ->prepare($sql2); $stmt2 -> execute([ ":quoteId" => $quoteId ]); $iid = $pdo -> lastInsertId(); This works but the version + 1 that i have in there is not going to work as i first need to check for the highest version that has been used. I may have gone down a rabbit hole here however: function createNewQuoteFromThisVersion($quoteId){ include 'includes/dbconn.php'; $sql ="UPDATE quote SET quote_status_id = 1"; $stmt = $pdo ->query($sql) -> execute(); $sql4 = "SELECT client_id, job_id from quote where id = :quoteId"; $stmt4 = $pdo -> prepare($sql4); $stmt4 -> execute([ ':quoteId' => $quoteId ]); if($row = $stmt4 -> fetch()){ $clientId = $row['client_id']; $jobId = $row['job_id']; } $sql5 = "SELECT max(version) as v from quote where client_id = :clientId and job_id = :jobId"; $stmt5 = $pdo -> prepare($sql5); $stmt5 -> execute([ ':clientId' => $clientId, ':jobId' => $jobId ]); if($row = $stmt5 -> fetch()){ $versionNumber = $row['v']; } $sql2 = "INSERT INTO quote (client_id, total_value, job_id, version, name, currency, kit_delivery, kit_return, quote_status_id) SELECT client_id, total_value, job_id, :version, name, currency, kit_delivery, kit_return, 2 from quote where quote.id = :quoteId"; $stmt2 = $pdo ->prepare($sql2); $stmt2 -> execute([ ":quoteId" => $quoteId, ':version' => $versionNumber ]); $iid = $pdo -> lastInsertId(); $sql3 = "INSERT INTO quote_items (quote_id, item_id, quantity, start_date, end_date, notes, amount_charged_each, original_price, chargable_units) SELECT :iid, item_id, quantity, start_date, end_date, notes, amount_charged_each, original_price, chargable_units from quote_items where quote_id = :quoteId"; $stmt3 = $pdo -> prepare($sql3); $stmt3 -> execute([ ':iid' => $iid, ':quoteId' => $quoteId ]); } This was my effort at doing what i needed to. The sql2 section is where i am going wrong i think. What is the correct way to select what is in the database but also amend the some of the data you are putting in. I can give data here if needed. Please forgive the naming convention here it will be tidied as i go.
-
fixed with ".selectAllItemsBySection()." Thanks Barry for that pointer.
-
<select type="text" class="form-control" id="itemId" name="itemId"> <option value="">Please Select...</option> <!--?= selectAllItemsBySection() ?--> </select>
-
ahh - strangely it is commented out.
-
I had a function that had some html returned in it. As i had to apply some conditions that would have needed me to duplicate the chunk of code, i have moved it into a function of its own that is called where i would have output the html. The function returning the HTML is doing so: function showAddNewItemPanel(){ return <<<HTML <div class='card mb-4' id='addNewQuoteItems'> <div class='card-header'><strong>Add New Item</strong></div> <div class='card-body'> <div class='p-3'> <form method='post' class='row g-3' id='newItemForm'> <div class='col-md-5'> <label for='itemId' class='form-label'>Item Name</label> <select type='text' class='form-control' id='itemId' name='itemId' disabled> <option value=''>Please Select...</option> <?= selectAllItemsBySection() ?> </select> </div> <div class='col-md-1'> <label for='quantity' class='form-label'>Quantity</label> <input type='text' class='form-control text-center' id='quantity' name='quantity' disabled> </div> <div class='col-md-3'> <label for='startDate' class='form-label'>Start Date</label> <input type='date' class='form-control' id='startDate' name='startDate' disabled> </div> <div class='col-md-3'> <label for='endDate' class='form-label'>End Date</label> <input type='date' class='form-control' id='endDate' name='endDate' disabled> </div> <div class='col-md-12'> <label for='notes' class='form-label'>Notes</label> <textarea class='form-control' id='notes' name='notes' rows='3' disabled></textarea> </div> <hr> <div class='col-md-5'> <label for='pricePerItemDisplay' class='form-label'>Price Per Item</label> <input type='text' class='form-control' id='pricePerItemDisplay' disabled> </div> <div class='col-md-4'> <label for='chargableUnitsDisplay' class='form-label' id='chargableUnitsLabel'>Weeks</label> <input type='text' class='form-control' id='chargableUnitsDisplay' name='chargableUnitsDisplay' disabled> </div> <div class='col-md-3'> <label for='itemTotal' class='form-label'>Item Total</label> <input type='text' class='form-control' id='itemTotal' name='itemTotal' disabled> </div> <div class='col-md-12'> <div class='btn btn-primary' id='addNewItem' name='addNewItem' disabled>Save</div> </div> <input type='hidden' name='pricePerItem' id='pricePerItem'> <input type='hidden' name='chargableUnits' id='chargableUnits'> <input type='hidden' name='quoteTotal' id='quoteTotal'> </form> </div> </div> </div> HTML; } The issue that i have is that the php function that is in there is now not showing its results and not creating the options for the select. - <?= selectAllItemsBySection() ?> Is there something that i have ommitted here? I have tried the method shown above and also returning not using heredoc.
-
Ill do my best to provide this going forward.
-
Can i ask how you would prefer me to show the content of my databases. Would it be better for me to give you the create code or is there another way of me showing my data in a way that is more helpful. I use this forum a lot and i try and take all advice onboard but i dont know what would be preferable when it comes to sharing my table structure.
-
Thats the one - thank you
-
Hi All, I have a table that contains jobs and another that contains quotes and another that contains clients. I have a query: I want to select all jobs for a certain client (that part i can do), i also want to know if these jobs have quotes attached to them. I have the following: SELECT distinct job.id, job.name, job.internal_ref, venue, start_date, end_date, quote.quote_status_id, quote.id as quoteId from job left join quote on job.id = quote.job_id where job.client_id = :clientId But this will create a row for each job per quote that is attached to it as well as showing all jobs that dont have quotes - so no good. If i inner join rather than left joining the quote table, i only get rows for jobs with quotes and again another job row per quote. All i want to know is per job, if there is at least 1 quote attached. My table structure is.
-
Passing Variables From Function to Function
Adamhumbug replied to Adamhumbug's topic in Javascript Help
Hold the phone i think i got it. $(function() { $.contextMenu({ selector: '.context-menu-one', build: function($triggerElement, e){ $el = $triggerElement.data('stuff') return { callback: function(){ }, items: { menuItem: {name: $el} } }; } }); }); Thanks you all so much for your feedback here and puttiung up with my rambling. -
Passing Variables From Function to Function
Adamhumbug replied to Adamhumbug's topic in Javascript Help
I got this far: $(function() { $.contextMenu({ selector: '.context-menu-one', build: function($triggerElement, e){ return { callback: function(){}, items: { menuItem: {name: "My on demand menu item"} } }; } }); }); The above works $(function() { $.contextMenu({ selector: '.context-menu-one', build: function($triggerElement, e){ return { callback: function(){ $el = "SOMETHING" }, items: { menuItem: {name: $el} } }; } }); }); The above doesnt. I am assuming that i am making the function wrong. -
Passing Variables From Function to Function
Adamhumbug replied to Adamhumbug's topic in Javascript Help
I am really having a hard time with this and im sorry to ask - i know the idea here is not to get other to write your code. @kicken - i dont suppose you have an example or would have the time to fomulate one - understand if not. Appreciate you all anyway! -
Passing Variables From Function to Function
Adamhumbug replied to Adamhumbug's topic in Javascript Help
Ok. Thanks for that. I’ll give it a go.