173 lines
5.4 KiB
PHP
173 lines
5.4 KiB
PHP
<?php
|
|
/**
|
|
* Name: Favorites
|
|
* Author: Daniel Marschall <info@daniel-marschall.de>
|
|
* License: GPLv2
|
|
* Description: Allow users to favorite images
|
|
*/
|
|
|
|
class FavoriteSetEvent extends Event {
|
|
var $image_id, $user, $do_set;
|
|
|
|
public function FavoriteSetEvent($image_id, $user, $do_set) {
|
|
$this->image_id = $image_id;
|
|
$this->user = $user;
|
|
$this->do_set = $do_set;
|
|
}
|
|
}
|
|
|
|
class Favorites extends SimpleExtension {
|
|
public function onInitExt($event) {
|
|
global $config;
|
|
if($config->get_int("ext_favorites_version", 0) < 1) {
|
|
$this->install();
|
|
}
|
|
}
|
|
|
|
public function onImageAdminBlockBuilding($event) {
|
|
global $database, $page, $user;
|
|
if(!$user->is_anonymous()) {
|
|
$user_id = $user->id;
|
|
$image_id = $event->image->id;
|
|
|
|
$is_favorited = $database->db->GetOne(
|
|
"SELECT COUNT(*) AS ct FROM user_favorites WHERE user_id = ? AND image_id = ?",
|
|
array($user_id, $image_id)) > 0;
|
|
|
|
$event->add_part($this->theme->get_voter_html($event->image, $is_favorited));
|
|
}
|
|
}
|
|
|
|
public function onDisplayingImage($event) {
|
|
$people = $this->list_persons_who_have_favorited($event->image);
|
|
if(count($people) > 0) {
|
|
$html = $this->theme->display_people($people);
|
|
}
|
|
}
|
|
|
|
public function onPageRequest($event) {
|
|
global $page, $user;
|
|
if($event->page_matches("change_favorite") && !$user->is_anonymous()) {
|
|
$image_id = int_escape($_POST['image_id']);
|
|
if (($_POST['favorite_action'] == "set") || ($_POST['favorite_action'] == "unset")) {
|
|
send_event(new FavoriteSetEvent($image_id, $user, ($_POST['favorite_action'] == "set")));
|
|
}
|
|
$page->set_mode("redirect");
|
|
$page->set_redirect(make_link("post/view/$image_id"));
|
|
}
|
|
}
|
|
|
|
public function onUserPageBuilding($event) {
|
|
$i_favorites_count = Image::count_images(array("favorited_by={$event->display_user->name}"));
|
|
$i_days_old = ((time() - strtotime($event->display_user->join_date)) / 86400) + 1;
|
|
$h_favorites_rate = sprintf("%.1f", ($i_favorites_count / $i_days_old));
|
|
$favorites_link = make_link("post/list/favorited_by={$event->display_user->name}/1");
|
|
$event->add_stats("<a href='$favorites_link'>Images favorited</a>: $i_favorites_count, $h_favorites_rate per day");
|
|
}
|
|
|
|
public function onImageInfoSet($event) {
|
|
global $user;
|
|
if(($_POST['favorite_action'] == "set") || ($_POST['favorite_action'] == "unset")) {
|
|
send_event(new FavoriteSetEvent($event->image_id, $user, ($_POST['favorite_action'] == "set")));
|
|
}
|
|
}
|
|
|
|
public function onFavoriteSet($event) {
|
|
global $user;
|
|
$this->add_vote($event->image_id, $user->id, $event->do_set);
|
|
}
|
|
|
|
public function onImageDeletion($event) {
|
|
global $database;
|
|
$database->execute("DELETE FROM user_favorites WHERE image_id=?", array($event->image->id));
|
|
}
|
|
|
|
public function onParseLinkTemplate($event) {
|
|
$event->replace('$favorites', $event->image->favorites);
|
|
}
|
|
|
|
public function onUserBlockBuilding($event) {
|
|
global $user;
|
|
if(strpos($user->name, ' ') === false) {
|
|
$username = url_escape($user->name);
|
|
$link = make_link("post/list/favorited_by=$username/1");
|
|
} else {
|
|
$userid = $user->id;
|
|
$link = make_link("post/list/favorited_by_userno=$userid/1");
|
|
}
|
|
$event->add_link("My Favorites", $link);
|
|
}
|
|
|
|
public function onSearchTermParse($event) {
|
|
$matches = array();
|
|
if(preg_match("/favorites(<|>|<=|>=|=)(\d+)/", $event->term, $matches)) {
|
|
$cmp = $matches[1];
|
|
$favorites = $matches[2];
|
|
$event->add_querylet(new Querylet("images.id IN (SELECT id FROM images WHERE favorites $cmp $favorites)"));
|
|
}
|
|
else if(preg_match("/favorited_by=(.*)/i", $event->term, $matches)) {
|
|
global $database;
|
|
$user = User::by_name($matches[1]);
|
|
if(!is_null($user)) {
|
|
$user_id = $user->id;
|
|
}
|
|
else {
|
|
$user_id = -1;
|
|
}
|
|
|
|
$event->add_querylet(new Querylet("images.id IN (SELECT image_id FROM user_favorites WHERE user_id = $user_id)"));
|
|
}
|
|
else if(preg_match("/favorited_by_userno=([0-9]+)/i", $event->term, $matches)) {
|
|
$user_id = int_escape($matches[1]);
|
|
$event->add_querylet(new Querylet("images.id IN (SELECT image_id FROM user_favorites WHERE user_id = $user_id)"));
|
|
}
|
|
}
|
|
|
|
|
|
private function install() {
|
|
global $database;
|
|
global $config;
|
|
|
|
if($config->get_int("ext_favorites_version") < 1) {
|
|
$database->Execute("ALTER TABLE images ADD COLUMN favorites INTEGER NOT NULL DEFAULT 0");
|
|
$database->Execute("CREATE INDEX images__favorites ON images(favorites)");
|
|
$database->Execute("
|
|
CREATE TABLE user_favorites (
|
|
image_id INTEGER NOT NULL,
|
|
user_id INTEGER NOT NULL,
|
|
created_at DATETIME NOT NULL,
|
|
UNIQUE(image_id, user_id),
|
|
INDEX(image_id)
|
|
)
|
|
");
|
|
$config->set_int("ext_favorites_version", 1);
|
|
}
|
|
}
|
|
|
|
private function add_vote($image_id, $user_id, $do_set) {
|
|
global $database;
|
|
if ($do_set) {
|
|
$database->Execute(
|
|
"INSERT INTO user_favorites(image_id, user_id, created_at) VALUES(?, ?, NOW())",
|
|
array($image_id, $user_id));
|
|
} else {
|
|
$database->Execute(
|
|
"DELETE FROM user_favorites WHERE image_id = ? AND user_id = ?",
|
|
array($image_id, $user_id));
|
|
}
|
|
$database->Execute(
|
|
"UPDATE images SET favorites=(SELECT COUNT(*) FROM user_favorites WHERE image_id=?) WHERE id=?",
|
|
array($image_id, $image_id));
|
|
}
|
|
|
|
private function list_persons_who_have_favorited($image) {
|
|
global $database;
|
|
|
|
$result = $database->execute(
|
|
"SELECT name FROM users WHERE id IN (SELECT user_id FROM user_favorites WHERE image_id = ?) ORDER BY name",
|
|
array($image->id));
|
|
|
|
return $result->GetArray();
|
|
}
|
|
}
|
|
?>
|