View Single Post
  #3  
Old 05-30-2017, 03:50 PM
aquapyrofan aquapyrofan is offline
Member
 
Join Date: Apr 2017
Posts: 48
Gender: Unknown/Other
Credits: 11,649
aquapyrofan is on a distinguished road
Default

Quote:
Originally Posted by Dinocanid View Post
To filter which pets show up in the dropdown, you use this for the conditions:
PHP Code:
$stmt $mysidia->db->select("owned_adoptables", array("name""aid"), "owner = '{$mysidia->user->username}' AND column = value"); 
So you would replace 'column' and 'value' with whatever you want. (you can use AND as much as you want too if you wanted to narrow it down further) Here is an example if it being used to only select pets that are level 3 or higher:
PHP Code:
$stmt $mysidia->db->select("owned_adoptables", array("name""aid"), "owner = '{$mysidia->user->username}' AND currentlevel >= 3"); 
And here is an example found in breeding.php, which narrows down the list to pets of a certain gender, level, and last time bred:
PHP Code:
$stmt $mysidia->db->select("owned_adoptables", array("name""aid"), "owner = '{$mysidia->user->username}' AND gender = 'f' AND currentlevel >= {$settings->level} AND lastbred <= '{$lasttime}'"); 
For getting the id of the pet, you have to use 'fetchmap', like this:
PHP Code:
$stmt $mysidia->db->select("owned_adoptables", array("name""aid"), "owner = '{$mysidia->user->username}' AND currentlevel >= 3");
        
$adopts $mysidia->db->fetchMap($stmt);
//code...
$petlist = new DropdownList("petlist");
          
$petlist->add(new Option("None Selected""none"FALSE));            
          
$petlist->fill($adopts);
$yourForm->add($petlist); 
That way the pet id is inserted into the database instead of the name, unlike it would've done if you used 'fetchlist', which would get the name but nothing else.
Is there a way to add the ID without the database call (say, another form element) so it can then be used elsewhere? I'm planning to try to do something with JavaScript and will need a way for it to know which pet the user is selecting.
Reply With Quote