- Add a user_load_by_uid() to load a user by their unique id (users are now cloned for each year);

- Fixup the committees.php page to always show the users from the latest year.
This commit is contained in:
dave 2009-02-03 08:19:15 +00:00
parent 8b430bd63f
commit 94d0e5022a
2 changed files with 49 additions and 46 deletions

View File

@ -22,68 +22,54 @@
*/
?>
<?
require("common.inc.php");
require_once('common.inc.php');
require_once('user.inc.php');
send_header("Committee List", null, "committee_management");
echo "<table>";
$q=mysql_query("SELECT * FROM committees ORDER BY ord,name");
while($r=mysql_fetch_object($q))
{
$q2=mysql_query("SELECT
users.id,
users.firstname,users.lastname,
users.email,
users_committee.emailprivate,
users_committee.displayemail,
committees_link.title,
committees_link.ord
FROM
users, users_committee, committees_link
WHERE
users_committee.users_id=users.id
AND committees_link.users_id=users.id
AND committees_link.committees_id='$r->id'
ORDER BY
ord,firstname");
while($r=mysql_fetch_object($q)) {
$q2=mysql_query("SELECT * FROM committees_link
LEFT JOIN users ON users.id = committees_link.users_id
WHERE committees_id='{$r->id}' ORDER BY ord,users.lastname");
//if there's nobody in this committee, then just skip it and go on to the next one.
if(mysql_num_rows($q2)==0)
continue;
echo "<tr>";
echo "<td colspan=\"3\"><h3>$r->name</h3>";
echo "<td colspan=\"3\"><h3>{$r->name}</h3>";
echo "</td></tr>\n";
echo mysql_error();
while($r2=mysql_fetch_object($q2))
{
while($r2=mysql_fetch_object($q2)) {
$uid = $r2->users_id;
$u = user_load_by_uid($uid);
$output=$config['committee_publiclayout'];
$name=$r2->firstname.' '.$r2->lastname;
$output=str_replace("name",$name,$output);
$output=str_replace("name",$u['name'],$output);
$output=str_replace("title",$r2->title,$output);
//make sure we do emailprivate before email so we dont match the wrong thing
if($r2->emailprivate && $r2->displayemail=='yes')
{
list($b,$a)=split("@",$r2->emailprivate);
if($u['emailprivate'] && $u['displayemail']=='yes') {
list($b,$a)=split("@",$u['emailprivate']);
$output=str_replace("emailprivate","<script language=\"javascript\" type=\"text/javascript\">em('$b','$a')</script>",$output);
}
else
$output=str_replace("emailprivate","",$output);
} else
$output=str_replace("emailprivate","",$output);
if($r2->email && $r2->displayemail=='yes')
{
list($b,$a)=split("@",$r2->email);
if($u['email'] && $u['displayemail']=='yes') {
list($b,$a)=split("@",$u['email']);
$output=str_replace("email","<script language=\"javascript\" type=\"text/javascript\">em('$b','$a')</script>",$output);
}
else
} else
$output=str_replace("email","",$output);
$output=str_replace("phonehome",$r2->phonehome,$output);
$output=str_replace("phonework",$r2->phonework,$output);
$output=str_replace("phonecell",$r2->phonecell,$output);
$output=str_replace("fax",$r2->fax,$output);
$output=str_replace("phonehome",$u['phonehome'],$output);
$output=str_replace("phonework",$u['->phonework'],$output);
$output=str_replace("phonecell",$u['->phonecell'],$output);
$output=str_replace("fax",$u['fax'],$output);
echo $output;

View File

@ -127,10 +127,8 @@ function user_load_sponsor($u)
return true;
}
function user_load($user)
function user_load($user, $uid = false)
{
$id = intval($user);
/* So, it turns out that doing one big load is faster than loading just
* from the users table then loading only the specific types the user
* has.. go figure. */
@ -140,8 +138,14 @@ function user_load($user)
LEFT JOIN `users_volunteer` ON `users_volunteer`.`users_id`=`users`.`id`
LEFT JOIN `users_fair` ON `users_fair`.`users_id`=`users`.`id`
LEFT JOIN `users_sponsor` ON `users_sponsor`.`users_id`=`users`.`id`
WHERE `users`.`id`='$id'
AND `users`.`deleted`='no' ";
WHERE ";
if($uid != false) {
$uid = intval($uid);
$query .= "`users`.`uid`='$uid' ORDER BY `users`.`year` DESC LIMIT 1";
} else {
$id = intval($user);
$query .= " `users`.`id`='$id'";
}
$q=mysql_query($query);
if(mysql_num_rows($q)!=1) {
@ -151,8 +155,17 @@ function user_load($user)
$ret = mysql_fetch_assoc($q);
/* Make sure they're not deleted, we don't want to do this in the query, because loading by $uid would
* simply return the previous year (where deleted=no) */
if($ret['deleted'] != 'no') {
/* User is deleted */
return false;
}
/* Do we need to do number conversions? */
$ret['id'] = intval($ret['id']);
$ret['uid'] = intval($ret['uid']);
$ret['year'] = intval($ret['year']);
/* Turn the type into an array, because there could be more than one */
$ts = explode(',', $ret['types']);
@ -191,10 +204,14 @@ function user_load($user)
print_r($ret);
echo "</pre>";
*/
return $ret;
}
function user_load_by_uid($uid)
{
return user_load(0, $uid);
}
function user_set_password($id, $password = NULL)
{
/* pass $u by reference so we can update it */