I need that first displays the online users lable, and after that to display all the online users, and after that ends the first <optgroup>
the same for Offline and Idle too.
CODE:
foreach($alt_user_result as $cur_user) {
if( $cur_user[user_status]=='online') {
echo "<option class='green_status' value='$cur_user[user_id]'>$cur_user[username] | $cur_user[user_status]
</option>";
}
elseif( $cur_user[user_status]=='idle') {
echo "<option class='yellow_status' value='$cur_user[user_id]'>$cur_user[username] | $cur_user[user_status]
</option>";
}
elseif( $cur_user[user_status]=='offline') {
echo "<option class='gray_status' value='$cur_user[user_id]'>$cur_user[username] | $cur_user[user_status]
</option>";
}
}
i tried to add <optgroup> before <option class='gray_status' for example but then it will be like this
<optgroup><option></option><optgroup>
<optgroup><option></option><optgroup>
<optgroup><option></option><optgroup>
<optgroup><option></option><optgroup>
<optgroup><option></option><optgroup>
and i want like this:
<optgroup lable="online">
<option></option>
<option></option>
<option></option>
<optgroup>
<optgroup lable="offline">
<option></option>
<option></option>
<option></option>
<optgroup>
......
query:
$alt_user_result = execute_pdo_query("SELECT U.username, U.user_id, T.last_activity_time,
case WHEN TIMESTAMPDIFF( MINUTE, T.last_activity_time ,NOW() ) <= 5 THEN 'online'
WHEN ( TIMESTAMPDIFF( MINUTE, T.last_activity_time ,NOW() ) > 5 AND
TIMESTAMPDIFF( MINUTE, T.last_activity_time ,NOW() ) <=30 ) THEN 'idle'
ELSE 'offline' end as user_status
FROM user_skills S, users U
LEFT JOIN user_status T ON U.user_id=T.user_id
WHERE S.user_id=U.user_id and S.task_type_id=? and S.permission='Yes';",
array($tablerow['task_type_id']));
Thanks all for the help in advance!
If the array is sorted by online status, you can do something simple like this:
If the array isn’t sorted by online status, you can use
usort()to sort it prior to running the above code.EDIT: Here is
usortcode that will sort the array in the order you want example: