mirror of
https://github.com/WhatCD/Gazelle.git
synced 2024-12-13 02:46:30 +00:00
306 lines
11 KiB
PHP
306 lines
11 KiB
PHP
<?
|
|
$DB->query("
|
|
SELECT
|
|
ca.ArtistID,
|
|
ag.Name,
|
|
aw.Image,
|
|
um.ID AS UserID,
|
|
um.Username
|
|
FROM collages_artists AS ca
|
|
JOIN artists_group AS ag ON ag.ArtistID=ca.ArtistID
|
|
LEFT JOIN wiki_artists AS aw ON aw.RevisionID = ag.RevisionID
|
|
LEFT JOIN users_main AS um ON um.ID=ca.UserID
|
|
WHERE ca.CollageID='$CollageID'
|
|
ORDER BY ca.Sort");
|
|
|
|
|
|
$Artists = $DB->to_array('ArtistID', MYSQLI_ASSOC);
|
|
|
|
// Loop through the result set, building up $Collage and $TorrentTable
|
|
// Then we print them.
|
|
$Collage = array();
|
|
$TorrentTable = '';
|
|
|
|
$NumArtists = 0;
|
|
$NumArtistsByUser = 0;
|
|
$Users = array();
|
|
|
|
foreach ($Artists as $Artist) {
|
|
$UserID = $Artist['UserID'];
|
|
$Username = $Artist['Username'];
|
|
$NumArtists++;
|
|
if ($UserID == $LoggedUser['ID']) {
|
|
$NumArtistsByUser++;
|
|
}
|
|
|
|
if ($Username) {
|
|
if (!isset($Users[$UserID])) {
|
|
$Users[$UserID] = array('name' => $Username, 'count' => 1);
|
|
} else {
|
|
$Users[$UserID]['count']++;
|
|
}
|
|
}
|
|
|
|
ob_start();
|
|
?>
|
|
<tr>
|
|
<td><a href="artist.php?id=<?=$Artist['ArtistID']?>"><?=$Artist['Name']?></a></td>
|
|
</tr>
|
|
<?
|
|
$ArtistTable.= ob_get_clean();
|
|
|
|
ob_start();
|
|
?>
|
|
<li class="image_group_<?=$Artist['ArtistID']?>">
|
|
<a href="artist.php?id=<?=$Artist['ArtistID']?>">
|
|
<? if ($Artist['Image']) { ?>
|
|
<img class="tooltip" src="<?=ImageTools::process($Artist['Image'], true)?>" alt="<?=$Artist['Name']?>" title="<?=$Artist['Name']?>" width="118" />
|
|
<? } else { ?>
|
|
<span style="width: 107px; padding: 5px;"><?=$Artist['Name']?></span>
|
|
<? } ?>
|
|
</a>
|
|
</li>
|
|
<?
|
|
$Collage[] = ob_get_clean();
|
|
}
|
|
|
|
|
|
if (!check_perms('site_collages_delete') && ($Locked || ($MaxGroups > 0 && $NumGroups >= $MaxGroups) || ($MaxGroupsPerUser > 0 && $NumGroupsByUser >= $MaxGroupsPerUser))) {
|
|
$PreventAdditions = true;
|
|
}
|
|
|
|
// Silly hack for people who are on the old setting
|
|
$CollageCovers = (isset($LoggedUser['CollageCovers']) ? $LoggedUser['CollageCovers'] : 25 * (abs($LoggedUser['HideCollage'] - 1)));
|
|
$CollagePages = array();
|
|
|
|
// Pad it out
|
|
if ($NumGroups > $CollageCovers) {
|
|
for ($i = $NumGroups + 1; $i <= ceil($NumGroups / $CollageCovers) * $CollageCovers; $i++) {
|
|
$Collage[] = '<li></li>';
|
|
}
|
|
}
|
|
|
|
|
|
for ($i = 0; $i < $NumGroups / $CollageCovers; $i++) {
|
|
$Groups = array_slice($Collage, $i * $CollageCovers, $CollageCovers);
|
|
$CollagePage = '';
|
|
foreach ($Groups as $Group) {
|
|
$CollagePage .= $Group;
|
|
}
|
|
$CollagePages[] = $CollagePage;
|
|
}
|
|
|
|
View::show_header($Name,'browse,collage,bbcode,voting,recommend');
|
|
|
|
?>
|
|
<div class="thin">
|
|
<div class="header">
|
|
<h2><?=$Name?></h2>
|
|
<div class="linkbox">
|
|
<a href="collages.php" class="brackets">List of collages</a>
|
|
<? if (check_perms('site_collages_create')) { ?>
|
|
<a href="collages.php?action=new" class="brackets">New collage</a>
|
|
<? } ?>
|
|
<br /><br />
|
|
<? if (check_perms('site_collages_subscribe')) { ?>
|
|
<a href="#" id="subscribelink<?=$CollageID?>" class="brackets" onclick="CollageSubscribe(<?=$CollageID?>); return false;"><?=(in_array($CollageID, $CollageSubscriptions) ? 'Unsubscribe' : 'Subscribe')?></a>
|
|
<? }
|
|
if (check_perms('site_collages_delete') || (check_perms('site_edit_wiki') && !$Locked)) { ?>
|
|
<a href="collages.php?action=edit&collageid=<?=$CollageID?>" class="brackets">Edit description</a>
|
|
<? } else { ?>
|
|
<span class="brackets">Locked</span>
|
|
<? }
|
|
if (Bookmarks::has_bookmarked('collage', $CollageID)) {
|
|
?>
|
|
<a href="#" id="bookmarklink_collage_<?=$CollageID?>" class="brackets" onclick="Unbookmark('collage', <?=$CollageID?>, 'Bookmark'); return false;">Remove bookmark</a>
|
|
<? } else { ?>
|
|
<a href="#" id="bookmarklink_collage_<?=$CollageID?>" class="brackets" onclick="Bookmark('collage', <?=$CollageID?>, 'Remove bookmark'); return false;">Bookmark</a>
|
|
<? }
|
|
?>
|
|
<!-- <a href="#" id="recommend" class="brackets">Recommend</a> -->
|
|
<?
|
|
if (check_perms('site_collages_manage') && !$Locked) { ?>
|
|
<a href="collages.php?action=manage_artists&collageid=<?=$CollageID?>" class="brackets">Manage artists</a>
|
|
<? } ?>
|
|
<a href="reports.php?action=report&type=collage&id=<?=$CollageID?>" class="brackets">Report collage</a>
|
|
<? if (check_perms('site_collages_delete') || $CreatorID == $LoggedUser['ID']) { ?>
|
|
<a href="collages.php?action=delete&collageid=<?=$CollageID?>&auth=<?=$LoggedUser['AuthKey']?>" class="brackets" onclick="return confirm('Are you sure you want to delete this collage?');">Delete</a>
|
|
<? } ?>
|
|
</div>
|
|
</div>
|
|
<? /* Misc::display_recommend($CollageID, "collage"); */ ?>
|
|
<div class="sidebar">
|
|
<div class="box box_category">
|
|
<div class="head"><strong>Category</strong></div>
|
|
<div class="pad"><a href="collages.php?action=search&cats[<?=(int)$CollageCategoryID?>]=1"><?=$CollageCats[(int)$CollageCategoryID]?></a></div>
|
|
</div>
|
|
<div class="box box_description">
|
|
<div class="head"><strong>Description</strong></div>
|
|
<div class="pad"><?=$Text->full_format($Description)?></div>
|
|
</div>
|
|
<div class="box box_info box_statistics_collage_torrents">
|
|
<div class="head"><strong>Statistics</strong></div>
|
|
<ul class="stats nobullet">
|
|
<li>Artists: <?=number_format($NumArtists)?></li>
|
|
<li>Subscribers: <?=number_format((int)$Subscribers)?></li>
|
|
<li>Built by <?=number_format(count($Users))?> user<?=(count($Users) > 1 ? 's' : '')?></li>
|
|
<li>Last updated: <?=time_diff($Updated)?></li>
|
|
</ul>
|
|
</div>
|
|
<div class="box box_contributors">
|
|
<div class="head"><strong>Top Contributors</strong></div>
|
|
<div class="pad">
|
|
<ol style="padding-left: 5px;">
|
|
<?
|
|
uasort($Users, 'compare');
|
|
$i = 0;
|
|
foreach ($Users as $ID => $User) {
|
|
$i++;
|
|
if ($i > 5) {
|
|
break;
|
|
}
|
|
?>
|
|
<li><?=Users::format_username($ID, false, false, false)?> (<?=number_format($User['count'])?>)</li>
|
|
<?
|
|
}
|
|
?>
|
|
</ol>
|
|
</div>
|
|
</div>
|
|
<? if (check_perms('site_collages_manage') && !$PreventAdditions) { ?>
|
|
<div class="box box_addartist">
|
|
<div class="head"><strong>Add Artists</strong><span class="float_right"><a href="#" onclick="$('.add_artist_container').toggle_class('hidden'); this.innerHTML = (this.innerHTML == 'Batch add' ? 'Individual add' : 'Batch add'); return false;" class="brackets">Batch add</a></span></div>
|
|
<div class="pad add_artist_container">
|
|
<form class="add_form" name="artist" action="collages.php" method="post">
|
|
<input type="hidden" name="action" value="add_artist" />
|
|
<input type="hidden" name="auth" value="<?=$LoggedUser['AuthKey']?>" />
|
|
<input type="hidden" name="collageid" value="<?=$CollageID?>" />
|
|
<div class="field_div">
|
|
<input type="text" id="artist" size="20" name="url"<? Users::has_autocomplete_enabled('other'); ?> />
|
|
</div>
|
|
<div class="submit_div">
|
|
<input type="submit" value="Add" />
|
|
</div>
|
|
<span style="font-style: italic;">Enter the URL of an artist on the site.</span>
|
|
</form>
|
|
</div>
|
|
<div class="pad hidden add_artist_container">
|
|
<form class="add_form" name="artists" action="collages.php" method="post">
|
|
<input type="hidden" name="action" value="add_artist_batch" />
|
|
<input type="hidden" name="auth" value="<?=$LoggedUser['AuthKey']?>" />
|
|
<input type="hidden" name="collageid" value="<?=$CollageID?>" />
|
|
<div class="field_div">
|
|
<textarea name="urls" rows="5" cols="25" style="white-space: nowrap;"></textarea>
|
|
</div>
|
|
<div class="submit_div">
|
|
<input type="submit" value="Add" />
|
|
</div>
|
|
<span style="font-style: italic;">Enter the URLs of artists on the site, one per line.</span>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
<? } ?>
|
|
<h3>Comments</h3>
|
|
<?
|
|
if (empty($CommentList)) {
|
|
$DB->query("
|
|
SELECT
|
|
c.ID,
|
|
c.Body,
|
|
c.AuthorID,
|
|
um.Username,
|
|
c.AddedTime
|
|
FROM comments AS c
|
|
LEFT JOIN users_main AS um ON um.ID = c.AuthorID
|
|
WHERE c.Page = 'collages'
|
|
AND c.PageID = $CollageID
|
|
ORDER BY c.ID DESC
|
|
LIMIT 15");
|
|
$CommentList = $DB->to_array(false, MYSQLI_NUM);
|
|
}
|
|
foreach ($CommentList as $Comment) {
|
|
list($CommentID, $Body, $UserID, $Username, $CommentTime) = $Comment;
|
|
?>
|
|
<div class="box comment">
|
|
<div class="head">
|
|
<?=Users::format_username($UserID, false, false, false) ?> <?=time_diff($CommentTime) ?>
|
|
<br />
|
|
<a href="reports.php?action=report&type=collages_comment&id=<?=$CommentID?>" class="brackets">Report</a>
|
|
</div>
|
|
<div class="pad"><?=$Text->full_format($Body)?></div>
|
|
</div>
|
|
<?
|
|
}
|
|
?>
|
|
<div class="box pad">
|
|
<a href="collages.php?action=comments&collageid=<?=$CollageID?>" class="brackets">View all comments</a>
|
|
</div>
|
|
<?
|
|
if (!$LoggedUser['DisablePosting']) {
|
|
?>
|
|
<div class="box box_addcomment">
|
|
<div class="head"><strong>Add comment</strong></div>
|
|
<form class="send_form" name="comment" id="quickpostform" onsubmit="quickpostform.submit_button.disabled = true;" action="comments.php" method="post">
|
|
<input type="hidden" name="action" value="take_post" />
|
|
<input type="hidden" name="page" value="collages" />
|
|
<input type="hidden" name="auth" value="<?=$LoggedUser['AuthKey']?>" />
|
|
<input type="hidden" name="pageid" value="<?=$CollageID?>" />
|
|
<div class="pad">
|
|
<div class="field_div">
|
|
<textarea name="body" cols="24" rows="5"></textarea>
|
|
</div>
|
|
<div class="submit_div">
|
|
<input type="submit" id="submit_button" value="Add comment" />
|
|
</div>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
<?
|
|
}
|
|
?>
|
|
</div>
|
|
<div class="main_column">
|
|
<?
|
|
if ($CollageCovers != 0) { ?>
|
|
<div id="coverart" class="box">
|
|
<div class="head" id="coverhead"><strong>Cover Art</strong></div>
|
|
<ul class="collage_images" id="collage_page0">
|
|
<?
|
|
$Page1 = array_slice($Collage, 0, $CollageCovers);
|
|
foreach ($Page1 as $Group) {
|
|
echo $Group;
|
|
}
|
|
?>
|
|
</ul>
|
|
</div>
|
|
<? if ($NumGroups > $CollageCovers) { ?>
|
|
<div class="linkbox pager" style="clear: left;" id="pageslinksdiv">
|
|
<span id="firstpage" class="invisible"><a href="#" class="pageslink" onclick="collageShow.page(0, this); return false;"><strong><< First</strong></a> | </span>
|
|
<span id="prevpage" class="invisible"><a href="#" class="pageslink" onclick="collageShow.prevPage(); return false;"><strong>< Prev</strong></a> | </span>
|
|
<? for ($i = 0; $i < $NumGroups / $CollageCovers; $i++) { ?>
|
|
<span id="pagelink<?=$i?>" class="<?=($i > 4 ? 'hidden' : '')?><?=($i == 0 ? 'selected' : '')?>"><a href="#" class="pageslink" onclick="collageShow.page(<?=$i?>, this); return false;"><strong><?=$CollageCovers * $i + 1?>-<?=min($NumGroups, $CollageCovers * ($i + 1))?></strong></a><?=(($i != ceil($NumGroups / $CollageCovers) - 1) ? ' | ' : '')?></span>
|
|
<? } ?>
|
|
<span id="nextbar" class="<?=($NumGroups / $CollageCovers > 5) ? 'hidden' : ''?>"> | </span>
|
|
<span id="nextpage"><a href="#" class="pageslink" onclick="collageShow.nextPage(); return false;"><strong>Next ></strong></a></span>
|
|
<span id="lastpage" class="<?=(ceil($NumGroups / $CollageCovers) == 2 ? 'invisible' : '')?>"> | <a href="#" class="pageslink" onclick="collageShow.page(<?=ceil($NumGroups / $CollageCovers) - 1?>, this); return false;"><strong>Last >></strong></a></span>
|
|
</div>
|
|
<script type="text/javascript">//<![CDATA[
|
|
collageShow.init(<?=json_encode($CollagePages)?>);
|
|
//]]></script>
|
|
<?
|
|
}
|
|
} ?>
|
|
<table class="artist_table grouping cats" id="discog_table">
|
|
<tr class="colhead_dark">
|
|
<td><strong>Artists</strong></td>
|
|
</tr>
|
|
<?=$ArtistTable?>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
<?
|
|
View::show_footer();
|
|
|
|
$Cache->cache_value("collage_$CollageID", array(array($Name, $Description, array(), array(), $CommentList, $Deleted, $CollageCategoryID, $CreatorID, $Locked, $MaxGroups, $MaxGroupsPerUser, $Updated, $Subscribers)), 3600);
|
|
?>
|