optional user links on user page
git-svn-id: file:///home/shish/svn/shimmie2/trunk@413 7f39781d-f577-437e-ae19-be835c7a54ca
This commit is contained in:
parent
f36c783868
commit
ff5f41c91e
@ -83,6 +83,12 @@ class UserPage extends Extension {
|
||||
global $user;
|
||||
global $config;
|
||||
$this->theme->display_user_page($event->page, $event->user, $user);
|
||||
if($user->id == $event->user->id) {
|
||||
$ubbe = new UserBlockBuildingEvent($event->user);
|
||||
send_event($ubbe);
|
||||
ksort($ubbe->parts);
|
||||
$this->theme->display_user_links($event->page, $event->user, $ubbe->parts);
|
||||
}
|
||||
if(($user->is_admin() || $user->id == $event->user->id) && ($user->id != $config->get_int('anon_id'))) {
|
||||
$this->theme->display_ip_list($event->page, $this->count_upload_ips($event->user), $this->count_comment_ips($event->user));
|
||||
}
|
||||
|
@ -9,6 +9,10 @@ class UserPageTheme extends Themelet {
|
||||
"There should be a login box to the left"));
|
||||
}
|
||||
|
||||
public function display_user_links($page, $user, $parts) {
|
||||
# $page->add_block(new Block("User Links", join(", ", $parts), "main", 10));
|
||||
}
|
||||
|
||||
public function display_user_block($page, $user, $parts) {
|
||||
$h_name = html_escape($user->name);
|
||||
$html = "Logged in as $h_name<br>";
|
||||
@ -94,7 +98,7 @@ class UserPageTheme extends Themelet {
|
||||
|
||||
if(!$user->is_anonymous()) {
|
||||
if($user->id == $duser->id || $user->is_admin()) {
|
||||
$page->add_block(new Block("Options", $this->build_options($duser), "main", 0));
|
||||
$page->add_block(new Block("Options", $this->build_options($duser), "main", 20));
|
||||
}
|
||||
if($user->is_admin()) {
|
||||
$page->add_block(new Block("More Options", $this->build_more_options($duser)));
|
||||
|
174
themes/danbooru/user.theme.php
Normal file
174
themes/danbooru/user.theme.php
Normal file
@ -0,0 +1,174 @@
|
||||
<?php
|
||||
|
||||
class UserPageTheme extends Themelet {
|
||||
public function display_login_page($page) {
|
||||
$page->set_title("Login");
|
||||
$page->set_heading("Login");
|
||||
$page->add_block(new NavBlock());
|
||||
$page->add_block(new Block("Login There",
|
||||
"There should be a login box to the left"));
|
||||
}
|
||||
|
||||
public function display_user_links($page, $user, $parts) {
|
||||
$page->add_block(new Block("User Links", join(", ", $parts), "main", 10));
|
||||
}
|
||||
|
||||
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) {
|
||||
global $config;
|
||||
$tac = $config->get_string("login_tac", "");
|
||||
|
||||
$tfe = new TextFormattingEvent($tac);
|
||||
send_event($tfe);
|
||||
$tac = $tfe->formatted;
|
||||
|
||||
if(empty($tac)) {$html = "";}
|
||||
else {$html = "<p>$tac</p>";}
|
||||
|
||||
$html .= "
|
||||
<form action='".make_link("user_admin/create")."' method='POST'>
|
||||
<table style='width: 300px;' border='1'>
|
||||
<tr><td>Name</td><td><input type='text' name='name'></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>Email (Optional)</td><td><input type='text' name='email'></td></tr>
|
||||
<tr><td colspan='2'><input type='Submit' value='Create Account'></td></tr>
|
||||
</table>
|
||||
</form>
|
||||
";
|
||||
|
||||
$page->set_title("Create Account");
|
||||
$page->set_heading("Create Account");
|
||||
$page->add_block(new NavBlock());
|
||||
$page->add_block(new Block("Signup", $html));
|
||||
}
|
||||
|
||||
public function display_signups_disabled($page) {
|
||||
$page->set_title("Signups Disabled");
|
||||
$page->set_heading("Signups Disabled");
|
||||
$page->add_block(new NavBlock());
|
||||
$page->add_block(new Block("Signups Disabled",
|
||||
"The board admin has disabled the ability to create new accounts~"));
|
||||
}
|
||||
|
||||
public function display_login_block($page) {
|
||||
global $config;
|
||||
$html = "
|
||||
<form action='".make_link("user_admin/login")."' method='POST'>
|
||||
<table border='1' summary='Login Form'>
|
||||
<tr><td width='70'>Name</td><td width='70'><input type='text' name='user'></td></tr>
|
||||
<tr><td>Password</td><td><input type='password' name='pass'></td></tr>
|
||||
<tr><td colspan='2'><input type='submit' name='gobu' value='Log In'></td></tr>
|
||||
</table>
|
||||
</form>
|
||||
";
|
||||
if($config->get_bool("login_signup_enabled")) {
|
||||
$html .= "<small><a href='".make_link("user_admin/create")."'>Create Account</a></small>";
|
||||
}
|
||||
$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) {
|
||||
$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)));
|
||||
$page->disable_left();
|
||||
|
||||
if(!$user->is_anonymous()) {
|
||||
if($user->id == $duser->id || $user->is_admin()) {
|
||||
$page->add_block(new Block("Options", $this->build_options($duser), "main", 20));
|
||||
}
|
||||
if($user->is_admin()) {
|
||||
$page->add_block(new Block("More Options", $this->build_more_options($duser)));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
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("post/list", "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_admin/change_pass")."' 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_admin/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;
|
||||
}
|
||||
// }}}
|
||||
}
|
||||
?>
|
Loading…
x
Reference in New Issue
Block a user