basic user list

This commit is contained in:
Shish Moom 2009-05-30 06:47:57 -07:00
parent c5e9788358
commit 413a0ede91
2 changed files with 86 additions and 64 deletions

View File

@ -31,21 +31,30 @@ class UserCreationEvent extends Event {
class UserCreationException extends SCoreException {} class UserCreationException extends SCoreException {}
class UserPage implements Extension { class UserPage extends SimpleExtension {
var $theme; var $theme;
// event handling {{{ public function onInitExt(Event $event) {
public function receive_event(Event $event) { global $config;
global $config, $database, $page, $user;
if(is_null($this->theme)) $this->theme = get_theme_object($this);
if($event instanceof InitExtEvent) {
$config->set_default_bool("login_signup_enabled", true); $config->set_default_bool("login_signup_enabled", true);
$config->set_default_int("login_memory", 365); $config->set_default_int("login_memory", 365);
} }
if(($event instanceof PageRequestEvent) && $event->page_matches("user_admin")) { public function onPageRequest(Event $event) {
global $config, $database, $page, $user;
// user info is shown on all pages
if($user->is_anonymous()) {
$this->theme->display_login_block($page);
}
else {
$ubbe = new UserBlockBuildingEvent();
send_event($ubbe);
ksort($ubbe->parts);
$this->theme->display_user_block($page, $user, $ubbe->parts);
}
if($event->page_matches("user_admin")) {
if($event->get_arg(0) == "login") { if($event->get_arg(0) == "login") {
if(isset($_POST['user']) && isset($_POST['pass'])) { if(isset($_POST['user']) && isset($_POST['pass'])) {
$this->login($page); $this->login($page);
@ -89,7 +98,19 @@ class UserPage implements Extension {
else if($event->get_arg(0) == "set_more") { else if($event->get_arg(0) == "set_more") {
$this->set_more_wrapper($page); $this->set_more_wrapper($page);
} }
else if($event->get_arg(0) == "list") {
// select users.id,name,joindate,admin,
// (select count(*) from images where images.owner_id=users.id) as images,
// (select count(*) from comments where comments.owner_id=users.id) as comments from users;
// select users.id,name,joindate,admin,image_count,comment_count
// from users
// join (select owner_id,count(*) as image_count from images group by owner_id) as _images on _images.owner_id=users.id
// join (select owner_id,count(*) as comment_count from comments group by owner_id) as _comments on _comments.owner_id=users.id;
$this->theme->display_user_list($page, User::by_list(0), $user);
} }
}
if(($event instanceof PageRequestEvent) && $event->page_matches("user")) { if(($event instanceof PageRequestEvent) && $event->page_matches("user")) {
$display_user = ($event->count_args() == 0) ? $user : User::by_name($event->get_arg(0)); $display_user = ($event->count_args() == 0) ? $user : User::by_name($event->get_arg(0));
if(!is_null($display_user)) { if(!is_null($display_user)) {
@ -101,8 +122,10 @@ class UserPage implements Extension {
"site, it might be bug report time..."); "site, it might be bug report time...");
} }
} }
}
if($event instanceof UserPageBuildingEvent) { public function onUserPageBuilding(Event $event) {
global $user, $config;
$this->theme->display_user_page($page, $event->display_user, $user); $this->theme->display_user_page($page, $event->display_user, $user);
if($user->id == $event->display_user->id) { if($user->id == $event->display_user->id) {
$ubbe = new UserBlockBuildingEvent(); $ubbe = new UserBlockBuildingEvent();
@ -115,41 +138,26 @@ class UserPage implements Extension {
} }
} }
// user info is shown on all pages public function onSetupBuilding(Event $event) {
if($event instanceof PageRequestEvent) {
if($user->is_anonymous()) {
$this->theme->display_login_block($page);
}
else {
$ubbe = new UserBlockBuildingEvent();
send_event($ubbe);
ksort($ubbe->parts);
$this->theme->display_user_block($page, $user, $ubbe->parts);
}
}
if($event instanceof SetupBuildingEvent) {
$sb = new SetupBlock("User Options"); $sb = new SetupBlock("User Options");
$sb->add_bool_option("login_signup_enabled", "Allow new signups: "); $sb->add_bool_option("login_signup_enabled", "Allow new signups: ");
$sb->add_longtext_option("login_tac", "<br>Terms &amp; Conditions:<br>"); $sb->add_longtext_option("login_tac", "<br>Terms &amp; Conditions:<br>");
$event->panel->add_block($sb); $event->panel->add_block($sb);
} }
if($event instanceof UserBlockBuildingEvent) { public function onUserBlockBuilding(Event $event) {
$event->add_link("My Profile", make_link("user")); $event->add_link("My Profile", make_link("user"));
$event->add_link("Log Out", make_link("user_admin/logout"), 99); $event->add_link("Log Out", make_link("user_admin/logout"), 99);
} }
if($event instanceof UserCreationEvent) { public function onUserCreation(Event $event) {
$this->check_user_creation($event); $this->check_user_creation($event);
$this->create_user($event); $this->create_user($event);
} }
if($event instanceof SearchTermParseEvent) { public function onSearchTermParse(Event $event) {
$matches = array(); $matches = array();
if(preg_match("/^(poster|user)=(.*)$/i", $event->term, $matches)) { if(preg_match("/^(poster|user)=(.*)$/i", $event->term, $matches)) {
global $config;
global $database;
$user = User::by_name($matches[2]); $user = User::by_name($matches[2]);
if(!is_null($user)) { if(!is_null($user)) {
$user_id = $user->id; $user_id = $user->id;
@ -164,7 +172,6 @@ class UserPage implements Extension {
$event->add_querylet(new Querylet("images.owner_id = $user_id")); $event->add_querylet(new Querylet("images.owner_id = $user_id"));
} }
} }
}
// }}} // }}}
// Things done *with* the user {{{ // Things done *with* the user {{{
private function login($page) { private function login($page) {

View File

@ -9,6 +9,21 @@ 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_list(Page $page, $users, User $user) {
$page->set_title("User List");
$page->set_heading("User List");
$page->add_block(new NavBlock());
$html = "<table>";
$html .= "<tr><td>Name</td></tr>";
foreach($users as $duser) {
$html .= "<tr>";
$html .= "<td><a href='".make_link("user/"+$duser->name)."'>".html_escape($duser->name)."</a></td>";
$html .= "</tr>";
}
$html .= "</table>";
$page->add_block(new Block("Users", $html));
}
public function display_user_links(Page $page, User $user, $parts) { public function display_user_links(Page $page, User $user, $parts) {
# $page->add_block(new Block("User Links", join(", ", $parts), "main", 10)); # $page->add_block(new Block("User Links", join(", ", $parts), "main", 10));
} }