Gazelle/sections/userhistory/subscriptions.php

247 lines
10 KiB
PHP
Raw Normal View History

2013-08-28 23:08:41 +00:00
<?
2011-03-28 14:21:28 +00:00
/*
2013-08-28 23:08:41 +00:00
User subscription page
2011-03-28 14:21:28 +00:00
*/
2013-01-14 08:00:16 +00:00
2011-03-28 14:21:28 +00:00
if (isset($LoggedUser['PostsPerPage'])) {
$PerPage = $LoggedUser['PostsPerPage'];
} else {
$PerPage = POSTS_PER_PAGE;
}
2013-05-28 08:01:02 +00:00
list($Page, $Limit) = Format::page_limit($PerPage);
2011-03-28 14:21:28 +00:00
2013-08-28 23:08:41 +00:00
View::show_header('Subscriptions','subscriptions,bbcode');
2011-10-11 08:00:15 +00:00
2011-03-28 14:21:28 +00:00
$ShowUnread = (!isset($_GET['showunread']) && !isset($HeavyInfo['SubscriptionsUnread']) || isset($HeavyInfo['SubscriptionsUnread']) && !!$HeavyInfo['SubscriptionsUnread'] || isset($_GET['showunread']) && !!$_GET['showunread']);
$ShowCollapsed = (!isset($_GET['collapse']) && !isset($HeavyInfo['SubscriptionsCollapse']) || isset($HeavyInfo['SubscriptionsCollapse']) && !!$HeavyInfo['SubscriptionsCollapse'] || isset($_GET['collapse']) && !!$_GET['collapse']);
2012-04-02 08:00:21 +00:00
2013-08-28 23:08:41 +00:00
// The monster sql query:
/*
* Fields:
* Page (artist, collages, requests, torrents or forums)
* PageID (ArtistID, CollageID, RequestID, GroupID, TopicID)
* PostID (of the last read post)
* ForumID
* ForumName
* Name (for artists and collages; carries the topic title for forum subscriptions)
* LastPost (PostID of the last post)
* LastPostTime
* LastReadBody
* LastReadEditedTime
* LastReadUserID
* LastReadUsername
* LastReadAvatar
* LastReadEditedUserID
*/
$DB->query("
(SELECT
SQL_CALC_FOUND_ROWS
s.Page,
s.PageID,
lr.PostID,
null AS ForumID,
null AS ForumName,
IF(s.Page = 'artist', a.Name, co.Name) AS Name,
c.ID AS LastPost,
c.AddedTime AS LastPostTime,
c_lr.Body AS LastReadBody,
c_lr.EditedTime AS LastReadEditedTime,
um.ID AS LastReadUserID,
um.Username AS LastReadUsername,
ui.Avatar AS LastReadAvatar,
c_lr.EditedUserID AS LastReadEditedUserID
FROM users_subscriptions_comments AS s
LEFT JOIN users_comments_last_read AS lr ON lr.UserID = $LoggedUser[ID] AND lr.Page = s.Page AND lr.PageID = s.PageID
LEFT JOIN artists_group AS a ON s.Page = 'artist' AND a.ArtistID = s.PageID
LEFT JOIN collages AS co ON s.Page = 'collages' AND co.ID = s.PageID
LEFT JOIN comments AS c ON c.ID = (SELECT MAX(ID) FROM comments WHERE Page = s.Page AND PageID = s.PageID)
LEFT JOIN comments AS c_lr ON c_lr.ID = lr.PostID
LEFT JOIN users_main AS um ON um.ID = c_lr.AuthorID
LEFT JOIN users_info AS ui ON ui.UserID = um.ID
WHERE s.UserID = $LoggedUser[ID] AND s.Page IN ('artist', 'collages', 'requests', 'torrents') AND (s.Page != 'collages' OR co.Deleted = '0')" . ($ShowUnread ? ' AND c.ID > IF(lr.PostID IS NULL, 0, lr.PostID)' : '') . "
GROUP BY s.PageID)
UNION ALL
(SELECT 'forums', s.TopicID, lr.PostID, f.ID, f.Name, t.Title, p.ID, p.AddedTime, p_lr.Body, p_lr.EditedTime, um.ID, um.Username, ui.Avatar, p_lr.EditedUserID
FROM users_subscriptions AS s
LEFT JOIN forums_last_read_topics AS lr ON lr.UserID = $LoggedUser[ID] AND s.TopicID = lr.TopicID
LEFT JOIN forums_topics AS t ON t.ID = s.TopicID
LEFT JOIN forums AS f ON f.ID = t.ForumID
LEFT JOIN forums_posts AS p ON p.ID = (SELECT MAX(ID) FROM forums_posts WHERE TopicID = s.TopicID)
LEFT JOIN forums_posts AS p_lr ON p_lr.ID = lr.PostID
LEFT JOIN users_main AS um ON um.ID = p_lr.AuthorID
LEFT JOIN users_info AS ui ON ui.UserID = um.ID
WHERE s.UserID = $LoggedUser[ID]" .
($ShowUnread ? " AND p.ID > IF(t.IsLocked = '1' AND t.IsSticky = '0'" . ", p.ID, IF(lr.PostID IS NULL, 0, lr.PostID))" : '') .
' AND ' . Forums::user_forums_sql() . "
GROUP BY t.ID)
ORDER BY LastPostTime DESC
LIMIT $Limit");
$Results = $DB->to_array(false, MYSQLI_ASSOC, false);
$DB->query('SELECT FOUND_ROWS()');
list($NumResults) = $DB->next_record();
2013-08-28 23:08:41 +00:00
$Debug->log_var($Results, 'Results');
$TorrentGroups = $Requests = array();
foreach ($Results as $Result) {
if ($Result['Page'] == 'torrents') {
$TorrentGroups[] = $Result['PageID'];
} elseif ($Result['Page'] == 'requests') {
$Requests[] = $Result['PageID'];
}
2011-03-28 14:21:28 +00:00
}
2013-08-28 23:08:41 +00:00
$TorrentGroups = Torrents::get_groups($TorrentGroups, true, true, false);
$Requests = Requests::get_requests($Requests);
include(SERVER_ROOT.'/classes/text.class.php'); // Text formatting class
$Text = new TEXT;
2011-03-28 14:21:28 +00:00
?>
<div class="thin">
2012-08-19 08:00:19 +00:00
<div class="header">
2013-08-28 23:08:41 +00:00
<h2>Subscriptions<?=$ShowUnread ? ' with unread posts' . ($NumResults ? ' (' . $NumResults . ' new)' : '') : ''?></h2>
2011-03-28 14:21:28 +00:00
2012-08-19 08:00:19 +00:00
<div class="linkbox">
2011-03-28 14:21:28 +00:00
<?
2013-04-20 08:01:01 +00:00
if (!$ShowUnread) {
2011-03-28 14:21:28 +00:00
?>
<br /><br />
2013-08-28 23:08:41 +00:00
<a href="userhistory.php?action=subscriptions&amp;showunread=1" class="brackets">Only display subscriptions with unread replies</a>&nbsp;&nbsp;&nbsp;
2011-03-28 14:21:28 +00:00
<?
} else {
?>
<br /><br />
2013-08-28 23:08:41 +00:00
<a href="userhistory.php?action=subscriptions&amp;showunread=0" class="brackets">Show all subscriptions</a>&nbsp;&nbsp;&nbsp;
2011-03-28 14:21:28 +00:00
<?
}
2013-04-20 08:01:01 +00:00
if ($NumResults) {
2011-03-28 14:21:28 +00:00
?>
2013-08-28 23:08:41 +00:00
<a href="#" onclick="Collapse(); return false;" id="collapselink" class="brackets"><?=$ShowCollapsed ? 'Show' : 'Hide' ?> post bodies</a>&nbsp;&nbsp;&nbsp;
2011-03-28 14:21:28 +00:00
<?
}
?>
2013-01-24 08:00:24 +00:00
<a href="userhistory.php?action=catchup&amp;auth=<?=$LoggedUser['AuthKey']?>" class="brackets">Catch up</a>&nbsp;&nbsp;&nbsp;
<a href="userhistory.php?action=posts&amp;userid=<?=$LoggedUser['ID']?>" class="brackets">Go to post history</a>&nbsp;&nbsp;&nbsp;
<a href="userhistory.php?action=quote_notifications" class="brackets">Quote notifications</a>&nbsp;&nbsp;&nbsp;
2012-08-19 08:00:19 +00:00
</div>
2011-03-28 14:21:28 +00:00
</div>
<?
2013-04-20 08:01:01 +00:00
if (!$NumResults) {
2011-03-28 14:21:28 +00:00
?>
<div class="center">
2013-08-28 23:08:41 +00:00
No subscriptions<?=$ShowUnread ? ' with unread posts' : ''?>
2011-03-28 14:21:28 +00:00
</div>
<?
} else {
?>
<div class="linkbox">
<?
2013-05-15 08:00:54 +00:00
$Pages = Format::get_pages($Page, $NumResults, $PerPage, 11);
2011-03-28 14:21:28 +00:00
echo $Pages;
?>
</div>
<?
2013-08-28 23:08:41 +00:00
foreach ($Results as $Result) {
switch ($Result['Page']) {
case 'artist':
$Links = 'Artist: <a href="artist.php?id=' . $Result['PageID'] . '">' . display_str($Result['Name']) . '</a>';
$JumpLink = 'artist.php?id=' . $Result['PageID'] . '&amp;postid=' . $Result['PostID'] . '#post' . $Result['PostID'];
break;
case 'collages':
$Links = 'Collage: <a href="collages.php?id=' . $Result['PageID'] . '">' . display_str($Result['Name']) . '</a>';
$JumpLink = 'collages.php?id=' . $Result['PageID'] . '&amp;postid=' . $Result['PostID'] . '#post' . $Result['PostID'];
break;
case 'requests':
2013-09-13 08:00:53 +00:00
if (!isset($Requests[$Result['PageID']])) {
continue;
2013-08-28 23:08:41 +00:00
}
2013-09-13 08:00:53 +00:00
$Request = $Requests[$Result['PageID']];
2013-08-28 23:08:41 +00:00
$CategoryName = $Categories[$CategoryID - 1];
$Links = 'Request: ';
if($CategoryName == "Music" || $CategoryName == "Audiobooks" || $CategoryName == "Comedy") {
2013-09-13 08:00:53 +00:00
$Links .= ($CategoryName == 'Music' ? Artists::display_artists(Requests::get_artists($Result['PageID'])) : '') . '<a href="requests.php?action=view&amp;id=' . $Result['PageID'] . '" dir="ltr">' . $Request['Title'] . " [" . $Request['Year'] . "]</a>";
2013-08-28 23:08:41 +00:00
} else {
2013-09-13 08:00:53 +00:00
$Links .= '<a href="requests.php?action=view&amp;id=' . $Result['PageID'] . '">' . $Request['Title'] . "</a>";
2013-08-28 23:08:41 +00:00
}
$JumpLink = 'requests.php?action=view&amp;id=' . $Result['PageID'] . '&amp;postid=' . $Result['PostID'] . '#post' . $Result['PostID'];
break;
case 'torrents':
2013-09-13 08:00:53 +00:00
if (!isset($TorrentGroups[$Result['PageID']])) {
continue;
2013-08-28 23:08:41 +00:00
}
2013-09-13 08:00:53 +00:00
$GroupInfo = $TorrentGroups[$Result['PageID']];
2013-08-28 23:08:41 +00:00
$Links = 'Torrent: ' . Artists::display_artists($GroupInfo['ExtendedArtists']) . '<a href="torrents.php?id=' . $GroupInfo['ID'] . '" dir="ltr">' . $GroupInfo['Name'] . '</a>';
if($GroupInfo['Year'] > 0) {
$Links .= " [" . $GroupInfo['Year'] . "]";
}
if ($GroupInfo['ReleaseType'] > 0) {
$Links .= " [" . $ReleaseTypes[$GroupInfo['ReleaseType']] . "]";
}
$JumpLink = 'torrents.php?id=' . $GroupInfo['ID'] . '&amp;postid=' . $Result['PostID'] . '#post' . $Result['PostID'];
break;
case 'forums':
$Links = 'Forums: <a href="forums.php?action=viewforum&amp;forumid=' . $Result['ForumID'] . '">' . display_str($Result['ForumName']) . '</a> &gt; ' .
'<a href="forums.php?action=viewthread&amp;threadid=' . $Result['PageID'] . '" title="' . display_str($Result['Name']) . '">' . Format::cut_string($Result['Name'], 75) . '</a>';
$JumpLink = 'forums.php?action=viewthread&amp;threadid=' . $Result['PageID'] . '&amp;postid=' . $Result['PostID'] . '#post' . $Result['PostID'];
break;
default:
error(0);
}
2011-03-28 14:21:28 +00:00
?>
2013-08-28 23:08:41 +00:00
<table class="forum_post box vertical_margin<?=(!Users::has_avatars_enabled() ? ' noavatar' : '')?>">
2013-09-06 08:00:41 +00:00
<colgroup>
<? if (Users::has_avatars_enabled()) { ?>
<col class="col_avatar" />
<? } ?>
<col class="col_post_body" />
</colgroup>
2013-08-28 23:08:41 +00:00
<tr class="colhead_dark notify_<?=$Result['Page']?>">
2013-05-01 08:00:16 +00:00
<td colspan="<?=Users::has_avatars_enabled() ? 2 : 1 ?>">
2013-08-28 23:08:41 +00:00
<span style="float:left;">
<?=$Links . ($Result['PostID'] < $Result['LastPost'] ? ' <span class="new">(New!)</span>' : '')?>
2011-03-28 14:21:28 +00:00
</span>
2013-08-28 23:08:41 +00:00
<span style="float: left;" class="tooltip last_read" title="Jump to last read">
<a href="<?=$JumpLink?>"></a>
2011-03-28 14:21:28 +00:00
</span>
2013-08-28 23:08:41 +00:00
<? if ($Result['Page'] == 'forums') { ?>
<span id="bar<?=$Result['PostID'] ?>" style="float:right;">
<a href="#" onclick="Subscribe(<?=$Result['PageID']?>); return false;" id="subscribelink<?=$Result['PageID']?>" class="brackets">Unsubscribe</a>
<? } else { ?>
<span id="bar_<?=$Result['Page'] . $Result['PostID'] ?>" style="float:right;">
<a href="#" onclick="SubscribeComments('<?=$Result['Page']?>', <?=$Result['PageID']?>); return false;" id="subscribelink_<?=$Result['Page'] . $Result['PageID']?>" class="brackets">Unsubscribe</a>
<? } ?>
2011-03-28 14:21:28 +00:00
&nbsp;
<a href="#">&uarr;</a>
</span>
</td>
</tr>
2013-08-28 23:08:41 +00:00
<? if (!empty($Result['LastReadBody'])) { // if a user is subscribed to a topic/comments but hasn't accessed the site ever, LastReadBody will be null - in this case we don't display a post. ?>
2013-04-20 08:01:01 +00:00
<tr class="row<?=$ShowCollapsed ? ' hidden' : '' ?>">
2013-08-28 23:08:41 +00:00
<? if (Users::has_avatars_enabled()) { ?>
2012-10-09 08:00:17 +00:00
<td class="avatar" valign="top">
2013-08-28 23:08:41 +00:00
<?=Users::show_avatar($Result['LastReadAvatar'], $Result['LastReadUsername'], $HeavyInfo['DisableAvatars'])?>
2011-03-28 14:21:28 +00:00
</td>
2013-08-28 23:08:41 +00:00
<? } ?>
2012-10-09 08:00:17 +00:00
<td class="body" valign="top">
2011-03-28 14:21:28 +00:00
<div class="content3">
2013-08-28 23:08:41 +00:00
<?=$Text->full_format($Result['LastReadBody']) ?>
<? if ($Result['LastReadEditedUserID']) { ?>
2011-03-28 14:21:28 +00:00
<br /><br />
2013-08-28 23:08:41 +00:00
Last edited by <?=Users::format_username($Result['LastReadEditedUserID'], false, false, false) ?> <?=time_diff($Result['LastReadEditedTime'])?>
<? } ?>
2011-03-28 14:21:28 +00:00
</div>
</td>
</tr>
2013-08-28 23:08:41 +00:00
<? } ?>
2011-03-28 14:21:28 +00:00
</table>
2013-08-28 23:08:41 +00:00
<? } ?>
2011-03-28 14:21:28 +00:00
<div class="linkbox">
<?=$Pages?>
</div>
2013-08-28 23:08:41 +00:00
<? }?>
2011-03-28 14:21:28 +00:00
</div>
<?
2012-10-11 08:00:15 +00:00
View::show_footer();