Вход Регистрация
Файл: poll.php
Строк: 130
<?php
/**
 * poll app
 * 
 * @package Sngine
 * @author Zamblek
 */
// fetch kernal
require('kernal.php');

// check access level
AccessLevel();

// check data ID
if(!isset($_GET['id']) || $_GET['id'] == || $_GET['id'] == "") {
    
SystemError($translate->__("Invalid Link"), $translate->__("You may have clicked an expired link or mistyped the address."));
}else {
    
// get post
    
$getPost $db->query(sprintf("SELECT poll.*, post.*, user.UserName, user.UserFirstName, user.UserLastName, user.UserAvatarPathMedium AS UserAvatarPath FROM posts_polls poll INNER JOIN posts post ON poll.ID = post.PostID AND post.PostType = 7 INNER JOIN users user ON post.UserID = user.UserID WHERE post.PostID = %s"SafeSQL($_GET['id'], 'int') )) or SQLError();
    if(
$getPost->num_rows == 0) {
        
SystemError($translate->__("This content is currently unavailable"), $translate->__("The page you requested cannot be displayed right now. It may be temporarily unavailable, the link you clicked on may have expired, or you may not have permission to view this page."));
    }
    
$post $getPost->fetch_array(MYSQLI_ASSOC);
}

// page header
PageHeader($post['Question'], $post['Question']);

// check if user favorited this post before
$getPostStatus $db->query(sprintf("SELECT Favorited FROM users_posts_favorites WHERE UserID = %s AND PostType = %s AND PostID = %s"SafeSQL($userArray['UserID'], 'int'), SafeSQL($post['PostType'], 'int'), SafeSQL($post['PostID'], 'int') )) or SQLError();
if(
$getPostStatus->num_rows 0) {
    
$post['favorited'] = true;
}else {
    
$post['favorited'] = false;
}

// check if user liked|disliked this post before
$getPostStatus $db->query(sprintf("SELECT Liked FROM users_posts_likes WHERE UserID = %s AND PostType = %s AND PostID = %s"SafeSQL($userArray['UserID'], 'int'), SafeSQL($post['PostType'], 'int'), SafeSQL($post['PostID'], 'int') )) or SQLError();
if(
$getPostStatus->num_rows 0) {
    
$postStatus $getPostStatus->fetch_array(MYSQLI_ASSOC);
    
$post['liked'] = $postStatus['Liked'];
}

// get poll options
$getPollOptions $db->query(sprintf("SELECT * FROM posts_polls_options WHERE PollID = %s"SafeSQL($post['PostID']))) or SQLError();
while(
$pollOption $getPollOptions->fetch_array(MYSQLI_ASSOC)) {
    
$pollOption['Bar'] = ($pollOption['Votes'] / $post['Votes']) * 100;
    
// check if user select the option
    
$getOption $db->query(sprintf("SELECT * FROM users_polls_options WHERE UserID = %s AND PollID = %s AND OptionID = %s"SafeSQL($userArray['UserID'], 'int'), SafeSQL($post['PostID'], 'int'), SafeSQL($pollOption['ID'], 'int') )) or SQLError();
    if(
$getOption->num_rows == 0) {
        
$pollOption['select'] = false;
    }else {
        
$pollOption['select'] = true;
        
$post['data']['selected'] = $pollOption['ID'];
    }
    
$post['pollOptions'][] = $pollOption;
}

// get comments
if($post['Comments'] > 0) {
    
// prepare where statement
    
if(count($userBlockedUsers) > 0) {
        
$whereStatement ' AND comm.UserID NOT IN (' implode(','$userBlockedUsers) . ')';
    }
    
$post['prevComments'] = ($post['PComments'] > $systemSetting['MaxComments'])? $post['PComments'] - $systemSetting['MaxComments']: 0;
    
$getComments $db->query(sprintf("SELECT comm.*, user.UserName, user.UserFirstName, user.UserLastName, user.UserAvatarPathMedium AS UserAvatarPath FROM posts_comments comm INNER JOIN users user ON comm.UserID = user.UserID WHERE comm.PostType = %s AND comm.PostID = %s AND comm.ParentNodeID = 0 ".$whereStatement." ORDER BY comm.Time ASC LIMIT %s,".$systemSetting['MaxComments'], SafeSQL($post['PostType'], 'int'), SafeSQL($post['PostID'], 'int'), $post['prevComments'] )) or SQLError();
    while(
$comment $getComments->fetch_array(MYSQLI_ASSOC)) {
        
// get Replies
        
if($comment['Replies'] > 0) {
            
$comment['prevReplies'] = ($comment['Replies'] > $systemSetting['MaxReplies'])? $comment['Replies'] - $systemSetting['MaxReplies']: 0;
            
$getReplies $db->query(sprintf("SELECT comm.*, user.UserName, user.UserFirstName, user.UserLastName, user.UserAvatarPathMedium AS UserAvatarPath FROM posts_comments comm INNER JOIN users user ON comm.UserID = user.UserID WHERE comm.ParentNodeID = %s ".$whereStatement." ORDER BY comm.Time ASC LIMIT %s,".$systemSetting['MaxReplies'], SafeSQL($comment['ID'], 'int'), $comment['prevReplies'] )) or SQLError();
            while(
$reply $getReplies->fetch_array(MYSQLI_ASSOC)) {
                
// check if user liked|disliked this reply before
                
$getReplyStatus $db->query(sprintf("SELECT Liked FROM users_comments_likes WHERE UserID = %s AND CommentID = %s"SafeSQL($userArray['UserID'], 'int'), SafeSQL($reply['ID'], 'int') )) or SQLError();
                if(
$getReplyStatus->num_rows 0) {
                    
$replyStatus $getReplyStatus->fetch_array(MYSQLI_ASSOC);
                    
$reply['liked'] = $replyStatus['Liked'];
                }
                
// decode text
                
$reply['Text'] = DecodeText($reply['Text']);
                
$comment['replies'][] = $reply;
            }
        }
        
// check if user liked|disliked this comment before
        
$getCommentStatus $db->query(sprintf("SELECT Liked FROM users_comments_likes WHERE UserID = %s AND CommentID = %s"SafeSQL($userArray['UserID'], 'int'), SafeSQL($comment['ID'], 'int') )) or SQLError();
        if(
$getCommentStatus->num_rows 0) {
            
$commentStatus $getCommentStatus->fetch_array(MYSQLI_ASSOC);
            
$comment['liked'] = $commentStatus['Liked'];
        }
        
// decode comment text
        
$comment['Text'] = DecodeText($comment['Text']);
        
$post['comments'][] = $comment;
    }
}

// assign variables
$smarty->assign('post'$post);

// page footer
PageFooter("poll");

?>
Онлайн: 2
Реклама