user themed

git-svn-id: file:///home/shish/svn/shimmie2/trunk@333 7f39781d-f577-437e-ae19-be835c7a54ca
This commit is contained in:
shish 2007-07-19 14:32:25 +00:00
parent 1008c36180
commit ef7044ce48
2 changed files with 131 additions and 139 deletions

View file

@ -72,7 +72,9 @@ class UserPage extends Extension {
} }
if(is_a($event, 'UserPageBuildingEvent')) { if(is_a($event, 'UserPageBuildingEvent')) {
$this->build_user_page($event->user); global $user;
$this->theme->display_user_page($event->page, $event->user, $user);
$this->theme->display_ip_list($event->page, $this->count_upload_ips($event->user), $this->count_comment_ips($event->user));
} }
// user info is shown on all pages // user info is shown on all pages
@ -84,7 +86,10 @@ class UserPage extends Extension {
$this->theme->display_login_block($event->page); $this->theme->display_login_block($event->page);
} }
else { else {
$page->add_block(new Block("User Links", $this->build_links_block(), "left", 90)); $ubbe = new UserBlockBuildingEvent($user);
send_event($ubbe);
ksort($ubbe->parts);
$this->theme->display_user_block($page, $user, $ubbe->parts);
} }
} }
@ -130,10 +135,7 @@ class UserPage extends Extension {
$page->set_redirect(make_link("user")); $page->set_redirect(make_link("user"));
} }
else { else {
$page->set_title("Permission Denied"); $this->theme->display_error($event->page, "Error", "No user with those details was found");
$page->set_heading("Permission Denied");
$page->add_block(new NavBlock());
$page->add_block(new Block("Error", "No user with those details was found"));
} }
} }
@ -275,149 +277,27 @@ class UserPage extends Extension {
} }
} }
// }}} // }}}
// HTML building {{{ // ips {{{
private function build_user_page($duser) { private function count_upload_ips($duser) {
global $page;
global $user;
if(!is_null($duser)) {
$page->set_title("{$duser->name}'s Page");
$page->set_heading("{$duser->name}'s Page");
$page->add_block(new NavBlock());
$page->add_block(new Block("Stats", $this->build_stats($duser)));
if(!$user->is_anonymous()) {
if($user->id == $duser->id || $user->is_admin()) {
$page->add_block(new Block("Options", $this->build_options($duser), "main", 0));
}
if($user->is_admin()) {
$page->add_block(new Block("More Options", $this->build_more_options($duser)));
$page->add_block(new Block("IP List", $this->build_ip_list($duser)));
}
}
}
else {
$page->set_title("No Such User");
$page->set_heading("No Such User");
$page->add_block(new NavBlock());
$page->add_block(new Block("No User By That ID",
"If you typed the ID by hand, try again; if you came from a link on this ".
"site, it might be bug report time..."));
}
}
private function build_stats($duser) {
global $database; global $database;
global $config; $rows = $database->db->GetAssoc("
$i_days_old = int_escape($duser->get_days_old());
$h_join_date = html_escape($duser->join_date);
$i_image_count = int_escape($duser->get_image_count());
$i_comment_count = int_escape($duser->get_comment_count());
$i_days_old2 = ($i_days_old == 0) ? 1 : $i_days_old;
$h_image_rate = sprintf("%3.1f", ($i_image_count / $i_days_old2));
$h_comment_rate = sprintf("%3.1f", ($i_comment_count / $i_days_old2));
$u_name = url_escape($duser->name);
$images_link = make_link("index", "search=poster%3D$u_name");
return "
Join date: $h_join_date ($i_days_old days old)
<br><a href='$images_link'>Images uploaded</a>: $i_image_count ($h_image_rate / day)
<br>Comments made: $i_comment_count ($h_comment_rate / day)
";
}
private function build_options($duser) {
global $database;
global $config;
$html = "";
$html .= "
<form action='".make_link("user/changepass")."' method='POST'>
<input type='hidden' name='name' value='{$duser->name}'>
<input type='hidden' name='id' value='{$duser->id}'>
<table style='width: 300px;' border='1'>
<tr><td colspan='2'>Change Password</td></tr>
<tr><td>Password</td><td><input type='password' name='pass1'></td></tr>
<tr><td>Repeat Password</td><td><input type='password' name='pass2'></td></tr>
<tr><td colspan='2'><input type='Submit' value='Change Password'></td></tr>
</table>
</form>
";
return $html;
}
private function build_more_options($duser) {
global $database;
global $config;
$i_user_id = int_escape($duser->id);
$h_is_admin = $duser->is_admin() ? " checked" : "";
$h_is_enabled = $duser->is_enabled() ? " checked" : "";
$html = "
<form action='".make_link("user/set_more")."' method='POST'>
<input type='hidden' name='id' value='$i_user_id'>
Admin: <input name='admin' type='checkbox'$h_is_admin>
<br>Enabled: <input name='enabled' type='checkbox'$h_is_enabled>
<p><input type='submit' value='Set'>
</form>
";
return $html;
}
private function build_ip_list($duser) {
global $database;
global $config;
$html = "<table id='ip-history'>";
$html .= "<tr><td>Uploaded from: ";
$rows = $database->db->GetAll("
SELECT owner_ip, COUNT(images.id) AS count SELECT owner_ip, COUNT(images.id) AS count
FROM images FROM images
WHERE owner_id=? WHERE owner_id=?
GROUP BY owner_ip GROUP BY owner_ip
ORDER BY posted DESC", array($duser->id), true); ORDER BY posted DESC", array($duser->id));
foreach($rows as $row) { return $rows;
$ip = $row['owner_ip']; }
$count = $row['count']; private function count_comment_ips($duser) {
$html .= "<br>$ip ($count)"; global $database;
} $rows = $database->db->GetAssoc("
$html .= "</td><td>Commented from:";
$rows = $database->db->GetAll("
SELECT owner_ip, COUNT(comments.id) AS count SELECT owner_ip, COUNT(comments.id) AS count
FROM comments FROM comments
WHERE owner_id=? WHERE owner_id=?
GROUP BY owner_ip GROUP BY owner_ip
ORDER BY posted DESC", array($duser->id), true); ORDER BY posted DESC", array($duser->id));
foreach($rows as $row) { return $rows;
$ip = $row['owner_ip'];
$count = $row['count'];
$html .= "<br>$ip ($count)";
}
$html .= "</td></tr>";
$html .= "<tr><td colspan='2'>(Most recent at top)</td></tr></table>";
return $html;
} }
private function build_links_block() {
global $user;
$ubbe = new UserBlockBuildingEvent($user);
send_event($ubbe);
$h_name = html_escape($user->name);
$html = "Logged in as $h_name<br>";
ksort($ubbe->parts);
$html .= join("\n<br/>", $ubbe->parts);
return $html;
}
// }}} // }}}
} }
add_event_listener(new UserPage()); add_event_listener(new UserPage());

View file

@ -9,6 +9,13 @@ class UserPageTheme extends Themelet {
"There should be a login box to the left")); "There should be a login box to the left"));
} }
public function display_user_block($page, $user, $parts) {
$h_name = html_escape($user->name);
$html = "Logged in as $h_name<br>";
$html .= join("\n<br/>", $parts);
$page->add_block(new Block("User Links", $html, "left", 90));
}
public function display_signup_page($page) { public function display_signup_page($page) {
global $config; global $config;
$tac = $config->get_string("login_tac"); $tac = $config->get_string("login_tac");
@ -50,5 +57,110 @@ class UserPageTheme extends Themelet {
} }
$page->add_block(new Block("Login", $html, "left", 90)); $page->add_block(new Block("Login", $html, "left", 90));
} }
public function display_ip_list($page, $uploads, $comments) {
$html = "<table id='ip-history'>";
$html .= "<tr><td>Uploaded from: ";
foreach($uploads as $ip => $count) {
$html .= "<br>$ip ($count)";
}
$html .= "</td><td>Commented from:";
foreach($comments as $ip => $count) {
$html .= "<br>$ip ($count)";
}
$html .= "</td></tr>";
$html .= "<tr><td colspan='2'>(Most recent at top)</td></tr></table>";
$page->add_block(new Block("IPs", $html));
}
public function display_user_page($page, $duser, $user) {
if(!is_null($duser)) {
$page->set_title("{$duser->name}'s Page");
$page->set_heading("{$duser->name}'s Page");
$page->add_block(new NavBlock());
$page->add_block(new Block("Stats", $this->build_stats($duser)));
if(!$user->is_anonymous()) {
if($user->id == $duser->id || $user->is_admin()) {
$page->add_block(new Block("Options", $this->build_options($duser), "main", 0));
}
if($user->is_admin()) {
$page->add_block(new Block("More Options", $this->build_more_options($duser)));
}
}
}
else {
$this->display_error($page, "No Such User",
"If you typed the ID by hand, try again; if you came from a link on this ".
"site, it might be bug report time...");
}
}
private function build_stats($duser) {
global $database;
global $config;
$i_days_old = int_escape($duser->get_days_old());
$h_join_date = html_escape($duser->join_date);
$i_image_count = int_escape($duser->get_image_count());
$i_comment_count = int_escape($duser->get_comment_count());
$i_days_old2 = ($i_days_old == 0) ? 1 : $i_days_old;
$h_image_rate = sprintf("%3.1f", ($i_image_count / $i_days_old2));
$h_comment_rate = sprintf("%3.1f", ($i_comment_count / $i_days_old2));
$u_name = url_escape($duser->name);
$images_link = make_link("index", "search=poster%3D$u_name");
return "
Join date: $h_join_date ($i_days_old days old)
<br><a href='$images_link'>Images uploaded</a>: $i_image_count ($h_image_rate / day)
<br>Comments made: $i_comment_count ($h_comment_rate / day)
";
}
private function build_options($duser) {
global $database;
global $config;
$html = "";
$html .= "
<form action='".make_link("user/changepass")."' method='POST'>
<input type='hidden' name='name' value='{$duser->name}'>
<input type='hidden' name='id' value='{$duser->id}'>
<table style='width: 300px;' border='1'>
<tr><td colspan='2'>Change Password</td></tr>
<tr><td>Password</td><td><input type='password' name='pass1'></td></tr>
<tr><td>Repeat Password</td><td><input type='password' name='pass2'></td></tr>
<tr><td colspan='2'><input type='Submit' value='Change Password'></td></tr>
</table>
</form>
";
return $html;
}
private function build_more_options($duser) {
global $database;
global $config;
$i_user_id = int_escape($duser->id);
$h_is_admin = $duser->is_admin() ? " checked" : "";
$h_is_enabled = $duser->is_enabled() ? " checked" : "";
$html = "
<form action='".make_link("user/set_more")."' method='POST'>
<input type='hidden' name='id' value='$i_user_id'>
Admin: <input name='admin' type='checkbox'$h_is_admin>
<br>Enabled: <input name='enabled' type='checkbox'$h_is_enabled>
<p><input type='submit' value='Set'>
</form>
";
return $html;
}
// }}}
} }
?> ?>