GROUP BUTTONS AND GROUP STYLE #171
@@ -2,16 +2,53 @@
|
|||||||
|
|
||||||
session_start();
|
session_start();
|
||||||
|
|
||||||
require("../../queries/post.php");
|
require_once("../../queries/post.php");
|
||||||
require("../../queries/connect.php");
|
require_once("../../queries/group_page.php");
|
||||||
require("../../queries/checkInput.php");
|
require_once("../../queries/connect.php");
|
||||||
|
require_once("../../queries/checkInput.php");
|
||||||
|
|
||||||
if (empty($_POST['newpost-title'])) {
|
if (empty($_POST["title"]) or
|
||||||
} else {
|
empty($_POST["content"]) or
|
||||||
makePost($_SESSION['userID'],
|
empty($_SESSION["userID"])) {
|
||||||
null,
|
header('HTTP/1.1 500 Non enough arguments');
|
||||||
test_input($_POST['newpost-title']),
|
|
||||||
test_input($_POST['newpost-content']));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
header("Location: ../profile.php");
|
if (empty($_POST["group"])) {
|
||||||
|
// User Post
|
||||||
|
makePost(
|
||||||
|
$_SESSION["userID"],
|
||||||
|
null,
|
||||||
|
test_input($_POST["title"]),
|
||||||
|
test_input($_POST["content"])
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
// Group Post
|
||||||
|
|
||||||
|
// Check if the user is an admin or mod of the group.
|
||||||
|
if(!in_array(selectGroupRole($_POST["group"]), array('mod', 'admin'))) {
|
||||||
|
header('HTTP/1.1 500 Non enough rights');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
makePost(
|
||||||
|
$_SESSION["userID"],
|
||||||
|
$_POST["group"],
|
||||||
|
test_input($_POST["title"]),
|
||||||
|
test_input($_POST["content"])
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//if (empty($_POST['newpost-title'])) {
|
||||||
|
//} else {
|
||||||
|
// makePost($_SESSION['userID'],
|
||||||
|
// null,
|
||||||
|
// test_input($_POST['newpost-title']),
|
||||||
|
// test_input($_POST['newpost-content']));
|
||||||
|
//}
|
||||||
|
//
|
||||||
|
//header("Location: ../profile.php");
|
||||||
@@ -34,6 +34,9 @@ include("../views/group.php");
|
|||||||
include("../views/footer.php");
|
include("../views/footer.php");
|
||||||
|
|
||||||
$masonry_mode = 0;
|
$masonry_mode = 0;
|
||||||
|
if ($group["role"] == "mod" OR $group["role"] == "admin") {
|
||||||
|
$masonry_mode = 2;
|
||||||
|
}
|
||||||
?>
|
?>
|
||||||
|
|
||||||
<script src="js/masonry.js"></script>
|
<script src="js/masonry.js"></script>
|
||||||
|
|||||||
@@ -23,6 +23,28 @@ function requestPost(postID) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function postPost() {
|
||||||
|
title = $("input.newpost[name='title']").val();
|
||||||
|
content = $("textarea.newpost[name='content']").val();
|
||||||
|
|
||||||
|
if (masonryMode == 2) {
|
||||||
|
$.post("API/postPost.php", { title: title,
|
||||||
|
content : content,
|
||||||
|
group : groupID })
|
||||||
|
.done(function() {
|
||||||
|
masonry(masonryMode);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
$.post("API/postPost.php", { title: title,
|
||||||
|
content : content })
|
||||||
|
.done(function() {
|
||||||
|
masonry(masonryMode);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
$(window).on("load", function() {
|
$(window).on("load", function() {
|
||||||
$(".modal-close").click(function () {
|
$(".modal-close").click(function () {
|
||||||
$(".modal").hide();
|
$(".modal").hide();
|
||||||
@@ -33,11 +55,15 @@ $(window).on("load", function() {
|
|||||||
});
|
});
|
||||||
|
|
||||||
var masonryMode = 0;
|
var masonryMode = 0;
|
||||||
|
var windowWidth = $(window).width();
|
||||||
|
|
||||||
$(window).resize(function() {
|
$(window).resize(function() {
|
||||||
clearTimeout(window.resizedFinished);
|
clearTimeout(window.resizedFinished);
|
||||||
window.resizeFinished = setTimeout(function() {
|
window.resizeFinished = setTimeout(function() {
|
||||||
masonry(masonryMode);
|
if ($(window).width() != windowWidth) {
|
||||||
|
windowWidth = $(window).width();
|
||||||
|
masonry(masonryMode);
|
||||||
|
}
|
||||||
}, 250);
|
}, 250);
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -60,13 +86,17 @@ function masonry(mode) {
|
|||||||
columns[i] = [0, $column];
|
columns[i] = [0, $column];
|
||||||
}
|
}
|
||||||
|
|
||||||
if(mode == 1) {
|
if(mode > 0) {
|
||||||
$postInput = $("<div class=\"post platform\">");
|
$postInput = $("<div class=\"post platform\">");
|
||||||
$form = $("<form action=\"API/postPost.php\" method=\"post\">");
|
$form = $("<form class=\"newpost\" action=\"API/postPost.php\" method=\"post\" onsubmit=\"postPost(); return false;\">");
|
||||||
$postInput.append($form);
|
$postInput.append($form);
|
||||||
|
|
||||||
$form.append($("<input class=\"newpost\" name=\"newpost-title\" placeholder=\"Titel\" type=\"text\">"));
|
if(mode == 2) {
|
||||||
$form.append($("<textarea class=\"newpost\" name=\"newpost-content\" placeholder=\"Schrijf een berichtje...\">"));
|
$form.append($("<input class=\"newpost\" type=\"hidden\" name=\"group\" value=\"" + groupID + "\">"));
|
||||||
|
}
|
||||||
|
|
||||||
|
$form.append($("<input class=\"newpost\" name=\"title\" placeholder=\"Titel\" type=\"text\">"));
|
||||||
|
$form.append($("<textarea class=\"newpost\" name=\"content\" placeholder=\"Schrijf een berichtje...\">"));
|
||||||
$form.append($("<input value=\"Plaats!\" type=\"submit\">"));
|
$form.append($("<input value=\"Plaats!\" type=\"submit\">"));
|
||||||
columns[0][1].append($postInput);
|
columns[0][1].append($postInput);
|
||||||
|
|
||||||
|
|||||||
@@ -11,6 +11,12 @@ function selectGroupByName($name) {
|
|||||||
`description`,
|
`description`,
|
||||||
`picture`,
|
`picture`,
|
||||||
`status`,
|
`status`,
|
||||||
|
(
|
||||||
|
SELECT `role`
|
||||||
|
FROM `group_member`
|
||||||
|
WHERE `group_member`.`groupID` = `group_page`.`groupID` AND
|
||||||
|
`userID` = :userID
|
||||||
|
) AS `role`,
|
||||||
COUNT(`group_member`.`groupID`) as `members`
|
COUNT(`group_member`.`groupID`) as `members`
|
||||||
FROM
|
FROM
|
||||||
`group_page`
|
`group_page`
|
||||||
@@ -22,13 +28,36 @@ function selectGroupByName($name) {
|
|||||||
name LIKE :name
|
name LIKE :name
|
||||||
");
|
");
|
||||||
|
|
||||||
$stmt->bindParam(':name', $name);
|
$stmt->bindParam(':name', $name, PDO::PARAM_STR);
|
||||||
|
$stmt->bindParam(':userID', $_SESSION["userID"], PDO::PARAM_INT);
|
||||||
if (!$stmt->execute()) {
|
if (!$stmt->execute()) {
|
||||||
return False;
|
return False;
|
||||||
}
|
}
|
||||||
return $stmt->fetch();
|
return $stmt->fetch();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function selectGroupRole(int $groupID) {
|
||||||
|
$stmt = prepareQuery("
|
||||||
|
SELECT
|
||||||
|
`role`
|
||||||
|
FROM
|
||||||
|
`group_member`
|
||||||
|
WHERE
|
||||||
|
`groupID` = :groupID AND
|
||||||
|
`userID` = :userID
|
||||||
|
");
|
||||||
|
|
||||||
|
$stmt->bindParam(':groupID', $groupID, PDO::PARAM_INT);
|
||||||
|
$stmt->bindParam(':userID', $_SESSION["userID"], PDO::PARAM_INT);
|
||||||
|
if(!$stmt->execute()) {
|
||||||
|
return False;
|
||||||
|
}
|
||||||
|
if($stmt->rowCount() == 0) {
|
||||||
|
return "none";
|
||||||
|
}
|
||||||
|
return $stmt->fetch()["role"];
|
||||||
|
}
|
||||||
|
|
||||||
function selectGroupMembers(int $groupID) {
|
function selectGroupMembers(int $groupID) {
|
||||||
$stmt = prepareQuery("
|
$stmt = prepareQuery("
|
||||||
SELECT
|
SELECT
|
||||||
|
|||||||
@@ -107,48 +107,6 @@ function selectAllUserGroups($userID) {
|
|||||||
return $stmt;
|
return $stmt;
|
||||||
}
|
}
|
||||||
|
|
||||||
function selectAllUserPosts($userID) {
|
|
||||||
$stmt = prepareQuery("
|
|
||||||
SELECT
|
|
||||||
`post`.`postID`,
|
|
||||||
`post`.`author`,
|
|
||||||
`title`,
|
|
||||||
CASE LENGTH(`post`.`content`) >= 150 AND `post`.`content` NOT LIKE '<img%'
|
|
||||||
WHEN TRUE THEN
|
|
||||||
CONCAT(LEFT(`post`.`content`, 150), '...')
|
|
||||||
WHEN FALSE THEN
|
|
||||||
`post`.`content`
|
|
||||||
END
|
|
||||||
AS `content`,
|
|
||||||
`post`.`creationdate`,
|
|
||||||
COUNT(`commentID`) AS `comments`,
|
|
||||||
COUNT(`niet_slecht`.`postID`) AS `niet_slechts`
|
|
||||||
FROM
|
|
||||||
`post`
|
|
||||||
LEFT JOIN
|
|
||||||
`niet_slecht`
|
|
||||||
ON
|
|
||||||
`post`.`postID` = `niet_slecht`.`postID`
|
|
||||||
LEFT JOIN
|
|
||||||
`comment`
|
|
||||||
ON
|
|
||||||
`post`.`postID` = `comment`.`postID`
|
|
||||||
WHERE
|
|
||||||
`post`.`author` = :userID AND
|
|
||||||
`groupID` IS NULL
|
|
||||||
GROUP BY
|
|
||||||
`post`.`postID`
|
|
||||||
ORDER BY
|
|
||||||
`post`.`creationdate` DESC
|
|
||||||
");
|
|
||||||
|
|
||||||
$stmt->bindParam(':userID', $userID, PDO::PARAM_INT);
|
|
||||||
if(!$stmt->execute()) {
|
|
||||||
return False;
|
|
||||||
}
|
|
||||||
return $stmt;
|
|
||||||
}
|
|
||||||
|
|
||||||
function select20UsersFromN($n) {
|
function select20UsersFromN($n) {
|
||||||
$q = prepareQuery("
|
$q = prepareQuery("
|
||||||
SELECT
|
SELECT
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
<div class="content">
|
<div class="content">
|
||||||
<div class="profile-box platform">
|
<div class="profile-box platform">
|
||||||
<img class="left group-picture" src="<?= $group['picture'] ?>">
|
<img class="left main-picture" src="<?= $group['picture'] ?>">
|
||||||
<div class="profile-button">
|
<div class="profile-button">
|
||||||
<p><img src="img/leave-group.png"> Groep verlaten</p>
|
<p><img src="img/leave-group.png"> Groep verlaten</p>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
Reference in New Issue
Block a user