mirror of
https://github.com/pierre42100/ComunicWeb
synced 2025-01-23 23:31:00 +00:00
Improved project structure
This commit is contained in:
parent
8072d1eb3e
commit
59e6eb3c30
@ -118,6 +118,9 @@
|
||||
<!--JavaScript at end of body for optimized loading-->
|
||||
<script type="text/javascript" src="assets/materialize/js/materialize.min.js"></script>
|
||||
<script src="assets/js/utils.js"></script>
|
||||
<script src="assets/js/categories/userInfo.js"></script>
|
||||
<script src="assets/js/categories/friends.js"></script>
|
||||
<script src="assets/js/categories/posts.js"></script>
|
||||
<script src="assets/js/main.js"></script>
|
||||
</body>
|
||||
</html>
|
@ -0,0 +1,48 @@
|
||||
/**
|
||||
* Friends category
|
||||
*
|
||||
* @author Pierre HUBERT
|
||||
*/
|
||||
|
||||
/**
|
||||
* Apply friends list
|
||||
*/
|
||||
function ApplyFriendsList(){
|
||||
|
||||
let target = document.querySelector("#friends-list-table tbody");
|
||||
|
||||
data.friends_list.forEach(friend => {
|
||||
|
||||
let friendInfo = getUserInfo(friend.ID_friend);
|
||||
|
||||
let friendTR = createElem2({
|
||||
appendTo: target,
|
||||
type: "tr"
|
||||
});
|
||||
|
||||
let friendName = createElem2({
|
||||
appendTo: friendTR,
|
||||
type: "td"
|
||||
});
|
||||
|
||||
let friendAccoutImage = createElem2({
|
||||
appendTo: friendName,
|
||||
type: "img"
|
||||
});
|
||||
applyUserAccountImage(friendAccoutImage, friendInfo)
|
||||
|
||||
friendName.innerHTML += friendInfo.full_name;
|
||||
|
||||
let friendAccepted = createElem2({
|
||||
appendTo: friendTR,
|
||||
type: "td",
|
||||
innerHTML: friend.accepted ? "Yes" : "Not yet"
|
||||
});
|
||||
|
||||
let friendLastActive = createElem2({
|
||||
appendTo: friendTR,
|
||||
type: "td",
|
||||
innerHTML: timeToStr(friend.time_last_activity)
|
||||
});
|
||||
});
|
||||
}
|
@ -0,0 +1,368 @@
|
||||
/**
|
||||
* Posts category
|
||||
*
|
||||
* @author Pierre HUBERT
|
||||
*/
|
||||
|
||||
/**
|
||||
* Apply the list of posts
|
||||
*/
|
||||
function ApplyPosts(){
|
||||
|
||||
let target = byId("posts-target");
|
||||
|
||||
data.posts.forEach(post => {
|
||||
|
||||
let userInfo = getUserInfo(post.userID);
|
||||
|
||||
let card = createElem2({
|
||||
appendTo: target,
|
||||
type: "div",
|
||||
class: "post card blue-grey darken-1"
|
||||
});
|
||||
|
||||
let cardContent = createElem2({
|
||||
appendTo: card,
|
||||
type: "div",
|
||||
class: "card-content white-text"
|
||||
});
|
||||
|
||||
let userInfoEl = createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "div",
|
||||
class: "user-info-container"
|
||||
});
|
||||
|
||||
let userImage = createElem2({
|
||||
appendTo: userInfoEl,
|
||||
type: "img"
|
||||
});
|
||||
applyUserAccountImage(userImage, userInfo);
|
||||
|
||||
userInfoEl.innerHTML += userInfo.full_name;
|
||||
|
||||
|
||||
//Check if the post was target another page than the user page
|
||||
if(post.user_page_id != 0 && post.user_page_id != post.userID){
|
||||
|
||||
userInfoEl.innerHTML += " > ";
|
||||
let targetUserInfo = getUserInfo(post.user_page_id);
|
||||
|
||||
let targetUserImage = createElem2({
|
||||
appendTo: userInfoEl,
|
||||
type: "img"
|
||||
});
|
||||
|
||||
applyUserAccountImage(targetUserImage, targetUserInfo);
|
||||
|
||||
userInfoEl.innerHTML += targetUserInfo.full_name;
|
||||
}
|
||||
|
||||
//Check if the post was targeting a group
|
||||
if(post.group_id > 0){
|
||||
userInfoEl.innerHTML += " > ";
|
||||
|
||||
userInfoEl.innerHTML += "Group " + post.group_id;
|
||||
}
|
||||
|
||||
//Post metadata
|
||||
let postMetadata = createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "div",
|
||||
class: "post-metadata"
|
||||
});
|
||||
|
||||
let addMetadata = function(content){
|
||||
createElem2({
|
||||
appendTo: postMetadata,
|
||||
type: "p",
|
||||
class: "post-date",
|
||||
innerHTML: content
|
||||
});
|
||||
}
|
||||
|
||||
//Post time
|
||||
addMetadata(timeToStr(post.post_time));
|
||||
|
||||
//Post visibility
|
||||
addMetadata("Visibility: " + post.visibility_level);
|
||||
|
||||
//Post type
|
||||
addMetadata("Kind of post: " + post.kind);
|
||||
|
||||
//Likes
|
||||
addMetadata("Number of likes: " + post.likes);
|
||||
addMetadata("Does user like this post: " + (post.userlike ? "Yes" : "No"));
|
||||
|
||||
//Files info
|
||||
if(post.file_size != null) addMetadata("File size: " + post.file_size);
|
||||
if(post.file_type != null) addMetadata("File type: " + post.file_type);
|
||||
if(post.file_path != null) addMetadata("File path: " + post.file_path);
|
||||
if(post.file_path_url != null) addMetadata("File path as URL: " + post.file_path_url);
|
||||
|
||||
|
||||
//Post content
|
||||
createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "div",
|
||||
class: "post-content",
|
||||
innerHTML: post.content
|
||||
});
|
||||
|
||||
|
||||
//Process different kind of posts
|
||||
//Post with image
|
||||
if(post.kind == "image") {
|
||||
|
||||
var image = createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "img"
|
||||
});
|
||||
|
||||
applyURLToImage(image, post.file_path_url);
|
||||
|
||||
}
|
||||
|
||||
//Post with YouTube video
|
||||
if(post.kind == "youtube"){
|
||||
|
||||
let youtube_link = "https://www.youtube.com/watch?v=" + post.file_path;
|
||||
|
||||
createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "p",
|
||||
innerHTML: "Target Video : <a href='" + youtube_link + "' target='_blank'>" + youtube_link + "</a>"
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
|
||||
//Post with movie
|
||||
if(post.kind == "movie"){
|
||||
|
||||
//Display the movie only (movies have a dedicated tab)
|
||||
createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "a",
|
||||
href: getFilePathFromURL(post.video_info.url),
|
||||
innerHTML: "Open movie"
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
|
||||
//Post with weblink
|
||||
if(post.kind == "weblink"){
|
||||
|
||||
let linkCard = createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "div",
|
||||
class: "card blue-text"
|
||||
});
|
||||
|
||||
let linkCardImage = createElem2({
|
||||
appendTo: linkCard,
|
||||
type: "div",
|
||||
class: "card-image"
|
||||
});
|
||||
|
||||
//Image
|
||||
createElem2({
|
||||
appendTo: linkCardImage,
|
||||
type: "img",
|
||||
src: post.link_image
|
||||
});
|
||||
|
||||
//Title
|
||||
createElem2({
|
||||
appendTo: linkCardImage,
|
||||
type: "span",
|
||||
class: "card-title",
|
||||
innerHTML: post.link_title
|
||||
});
|
||||
|
||||
createElem2({
|
||||
appendTo: linkCard,
|
||||
type: "div",
|
||||
class: "card-content",
|
||||
innerHTML: "<p>"+post.link_description+"</p>"
|
||||
});
|
||||
|
||||
let linkCardActions = createElem2({
|
||||
appendTo: linkCard,
|
||||
type: "div",
|
||||
class: "card-action"
|
||||
});
|
||||
|
||||
createElem2({
|
||||
appendTo: linkCardActions,
|
||||
type: "a",
|
||||
href: post.link_url,
|
||||
innerHTML: post.link_url
|
||||
})
|
||||
}
|
||||
|
||||
|
||||
//Post with PDF
|
||||
if(post.kind == "pdf"){
|
||||
|
||||
createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "a",
|
||||
class: "waves-effect waves-light btn-large post-btn-pdf",
|
||||
innerHTML: '<i class="material-icons left">picture_as_pdf</i> PDF',
|
||||
href: getFilePathFromURL(post.file_path_url)
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
|
||||
//Post with countdown timer
|
||||
if(post.kind == "countdown"){
|
||||
|
||||
createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "p",
|
||||
class: "post-end-countdown",
|
||||
innerHTML: "Countdown terminates on: " + timeToStr(post.time_end)
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
//Post with survey
|
||||
if(post.kind == "survey"){
|
||||
|
||||
let infoSurvey = post.data_survey;
|
||||
|
||||
let surveyContainer = createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "div",
|
||||
class: "post-survey card blue"
|
||||
});
|
||||
|
||||
//Survey content
|
||||
let surveyContent = createElem2({
|
||||
appendTo: surveyContainer,
|
||||
type: "div",
|
||||
class: "card-content"
|
||||
});
|
||||
|
||||
//Survey title
|
||||
createElem2({
|
||||
appendTo: surveyContent,
|
||||
type: "h2",
|
||||
class: "survey-title",
|
||||
innerHTML: infoSurvey.question
|
||||
});
|
||||
|
||||
//User choice (if any)
|
||||
if(infoSurvey.user_choice > 0){
|
||||
|
||||
createElem2({
|
||||
appendTo: surveyContent,
|
||||
type: "p",
|
||||
innerHTML: "Your choice : " + infoSurvey.choices[infoSurvey.user_choice].name
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
//Survey choices
|
||||
let surveyChoicesTable = createElem2({
|
||||
appendTo: surveyContainer,
|
||||
type: "table",
|
||||
class: "survey-choices-table"
|
||||
});
|
||||
|
||||
//Table header
|
||||
createElem2({
|
||||
appendTo: surveyChoicesTable,
|
||||
type: "thead",
|
||||
innerHTML: "<tr><th>Choice</th><th>Responses</th></tr>"
|
||||
});
|
||||
|
||||
//Table body
|
||||
let surveyTableBody = createElem2({
|
||||
appendTo: surveyChoicesTable,
|
||||
type: "tbody"
|
||||
});
|
||||
|
||||
for (const key in infoSurvey.choices) {
|
||||
if (!infoSurvey.choices.hasOwnProperty(key))
|
||||
continue;
|
||||
const choice = infoSurvey.choices[key];
|
||||
|
||||
//Add choice
|
||||
createElem2({
|
||||
appendTo: surveyTableBody,
|
||||
type: "tr",
|
||||
innerHTML: "<td>" + choice.name + "</td><td>" + choice.responses + "</td>"
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
//Display the list of comments
|
||||
let postComments = createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "div",
|
||||
class: "post-comments",
|
||||
innerHTML: "Comments"
|
||||
});
|
||||
post.comments.forEach(comment => {
|
||||
|
||||
//Create comment container
|
||||
let commentContainer = createElem2({
|
||||
appendTo: postComments,
|
||||
type: "div",
|
||||
class: "comment"
|
||||
});
|
||||
|
||||
let commentCreator = createElem2({
|
||||
appendTo: commentContainer,
|
||||
type: "div",
|
||||
class: "comment-author"
|
||||
});
|
||||
|
||||
fillElWithUserInfo(commentCreator, comment.userID);
|
||||
|
||||
let commentContent = createElem2({
|
||||
appendTo: commentContainer,
|
||||
type: "div",
|
||||
innerHTML: comment.content
|
||||
});
|
||||
|
||||
|
||||
//Add comment image (if any)
|
||||
if(comment.img_url != null){
|
||||
|
||||
let img = createElem2({
|
||||
appendTo: commentContainer,
|
||||
type: "img",
|
||||
class: "comment-image"
|
||||
});
|
||||
|
||||
applyURLToImage(img, comment.img_url);
|
||||
|
||||
}
|
||||
|
||||
|
||||
let commentMetadata = createElem2({
|
||||
appendTo: commentContainer,
|
||||
type: "div",
|
||||
class: "comment-metadata"
|
||||
});
|
||||
|
||||
let addCommentMetadata = function(content){
|
||||
createElem2({
|
||||
appendTo: commentMetadata,
|
||||
type: "div",
|
||||
innerHTML: content
|
||||
});
|
||||
};
|
||||
|
||||
addCommentMetadata(timeToStr(comment.time_sent));
|
||||
addCommentMetadata("Likes: " + comment.likes);
|
||||
addCommentMetadata("User like: " + (comment.userlike ? "Yes" : "No"));
|
||||
})
|
||||
});
|
||||
|
||||
}
|
@ -0,0 +1,28 @@
|
||||
/**
|
||||
* User information category
|
||||
*
|
||||
* @author Pierre HUBERT
|
||||
*/
|
||||
|
||||
/**
|
||||
* Apply user information
|
||||
*/
|
||||
function ApplyUserInfo() {
|
||||
|
||||
let userInfo = data.advanced_info;
|
||||
setInnerHTMLById("u-uid", userInfo.userID);
|
||||
setInnerHTMLById("u-firstname", userInfo.firstName);
|
||||
setInnerHTMLById("u-lastname", userInfo.lastName);
|
||||
setBoolInnerHTMLById("u-pagepublic", userInfo.publicPage);
|
||||
setBoolInnerHTMLById("u-pageopen", userInfo.openPage);
|
||||
setInnerHTMLById("u-virtualdirectory", userInfo.virtualDirectory);
|
||||
applyUserAccountImage(byId("u-accountimage"), userInfo);
|
||||
setBoolInnerHTMLById("u-publicfriendslist", userInfo.friend_list_public);
|
||||
setInnerHTMLById("u-personnalwebsite", userInfo.personnalWebsite);
|
||||
setInnerHTMLById("u-publicnote", userInfo.publicNote);
|
||||
setBoolInnerHTMLById("u-commentsforbidden", userInfo.noCommentOnHisPage);
|
||||
setBoolInnerHTMLById("u-allowpostsfromfriends", userInfo.allowPostFromFriendOnHisPage);
|
||||
setInnerHTMLById("u-accountcreationtime", timeToStr(userInfo.account_creation_time));
|
||||
applyURLToImage(byId("u-bgimage"), userInfo.backgroundImage);
|
||||
setInnerHTMLById("u-pagelikes", timeToStr(userInfo.pageLikes));
|
||||
}
|
@ -42,436 +42,6 @@ function RefreshTabsVisibility(){
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Apply user information
|
||||
*/
|
||||
function ApplyUserInfo() {
|
||||
|
||||
let userInfo = data.advanced_info;
|
||||
setInnerHTMLById("u-uid", userInfo.userID);
|
||||
setInnerHTMLById("u-firstname", userInfo.firstName);
|
||||
setInnerHTMLById("u-lastname", userInfo.lastName);
|
||||
setBoolInnerHTMLById("u-pagepublic", userInfo.publicPage);
|
||||
setBoolInnerHTMLById("u-pageopen", userInfo.openPage);
|
||||
setInnerHTMLById("u-virtualdirectory", userInfo.virtualDirectory);
|
||||
applyUserAccountImage(byId("u-accountimage"), userInfo);
|
||||
setBoolInnerHTMLById("u-publicfriendslist", userInfo.friend_list_public);
|
||||
setInnerHTMLById("u-personnalwebsite", userInfo.personnalWebsite);
|
||||
setInnerHTMLById("u-publicnote", userInfo.publicNote);
|
||||
setBoolInnerHTMLById("u-commentsforbidden", userInfo.noCommentOnHisPage);
|
||||
setBoolInnerHTMLById("u-allowpostsfromfriends", userInfo.allowPostFromFriendOnHisPage);
|
||||
setInnerHTMLById("u-accountcreationtime", timeToStr(userInfo.account_creation_time));
|
||||
applyURLToImage(byId("u-bgimage"), userInfo.backgroundImage);
|
||||
setInnerHTMLById("u-pagelikes", timeToStr(userInfo.pageLikes));
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Apply friends list
|
||||
*/
|
||||
function ApplyFriendsList(){
|
||||
|
||||
let target = document.querySelector("#friends-list-table tbody");
|
||||
|
||||
data.friends_list.forEach(friend => {
|
||||
|
||||
let friendInfo = getUserInfo(friend.ID_friend);
|
||||
|
||||
let friendTR = createElem2({
|
||||
appendTo: target,
|
||||
type: "tr"
|
||||
});
|
||||
|
||||
let friendName = createElem2({
|
||||
appendTo: friendTR,
|
||||
type: "td"
|
||||
});
|
||||
|
||||
let friendAccoutImage = createElem2({
|
||||
appendTo: friendName,
|
||||
type: "img"
|
||||
});
|
||||
applyUserAccountImage(friendAccoutImage, friendInfo)
|
||||
|
||||
friendName.innerHTML += friendInfo.full_name;
|
||||
|
||||
let friendAccepted = createElem2({
|
||||
appendTo: friendTR,
|
||||
type: "td",
|
||||
innerHTML: friend.accepted ? "Yes" : "Not yet"
|
||||
});
|
||||
|
||||
let friendLastActive = createElem2({
|
||||
appendTo: friendTR,
|
||||
type: "td",
|
||||
innerHTML: timeToStr(friend.time_last_activity)
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Apply the list of posts
|
||||
*/
|
||||
function ApplyPosts(){
|
||||
|
||||
let target = byId("posts-target");
|
||||
|
||||
data.posts.forEach(post => {
|
||||
|
||||
let userInfo = getUserInfo(post.userID);
|
||||
|
||||
let card = createElem2({
|
||||
appendTo: target,
|
||||
type: "div",
|
||||
class: "post card blue-grey darken-1"
|
||||
});
|
||||
|
||||
let cardContent = createElem2({
|
||||
appendTo: card,
|
||||
type: "div",
|
||||
class: "card-content white-text"
|
||||
});
|
||||
|
||||
let userInfoEl = createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "div",
|
||||
class: "user-info-container"
|
||||
});
|
||||
|
||||
let userImage = createElem2({
|
||||
appendTo: userInfoEl,
|
||||
type: "img"
|
||||
});
|
||||
applyUserAccountImage(userImage, userInfo);
|
||||
|
||||
userInfoEl.innerHTML += userInfo.full_name;
|
||||
|
||||
|
||||
//Check if the post was target another page than the user page
|
||||
if(post.user_page_id != 0 && post.user_page_id != post.userID){
|
||||
|
||||
userInfoEl.innerHTML += " > ";
|
||||
let targetUserInfo = getUserInfo(post.user_page_id);
|
||||
|
||||
let targetUserImage = createElem2({
|
||||
appendTo: userInfoEl,
|
||||
type: "img"
|
||||
});
|
||||
|
||||
applyUserAccountImage(targetUserImage, targetUserInfo);
|
||||
|
||||
userInfoEl.innerHTML += targetUserInfo.full_name;
|
||||
}
|
||||
|
||||
//Check if the post was targeting a group
|
||||
if(post.group_id > 0){
|
||||
userInfoEl.innerHTML += " > ";
|
||||
|
||||
userInfoEl.innerHTML += "Group " + post.group_id;
|
||||
}
|
||||
|
||||
//Post metadata
|
||||
let postMetadata = createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "div",
|
||||
class: "post-metadata"
|
||||
});
|
||||
|
||||
let addMetadata = function(content){
|
||||
createElem2({
|
||||
appendTo: postMetadata,
|
||||
type: "p",
|
||||
class: "post-date",
|
||||
innerHTML: content
|
||||
});
|
||||
}
|
||||
|
||||
//Post time
|
||||
addMetadata(timeToStr(post.post_time));
|
||||
|
||||
//Post visibility
|
||||
addMetadata("Visibility: " + post.visibility_level);
|
||||
|
||||
//Post type
|
||||
addMetadata("Kind of post: " + post.kind);
|
||||
|
||||
//Likes
|
||||
addMetadata("Number of likes: " + post.likes);
|
||||
addMetadata("Does user like this post: " + (post.userlike ? "Yes" : "No"));
|
||||
|
||||
//Files info
|
||||
if(post.file_size != null) addMetadata("File size: " + post.file_size);
|
||||
if(post.file_type != null) addMetadata("File type: " + post.file_type);
|
||||
if(post.file_path != null) addMetadata("File path: " + post.file_path);
|
||||
if(post.file_path_url != null) addMetadata("File path as URL: " + post.file_path_url);
|
||||
|
||||
|
||||
//Post content
|
||||
createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "div",
|
||||
class: "post-content",
|
||||
innerHTML: post.content
|
||||
});
|
||||
|
||||
|
||||
//Process different kind of posts
|
||||
//Post with image
|
||||
if(post.kind == "image") {
|
||||
|
||||
var image = createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "img"
|
||||
});
|
||||
|
||||
applyURLToImage(image, post.file_path_url);
|
||||
|
||||
}
|
||||
|
||||
//Post with YouTube video
|
||||
if(post.kind == "youtube"){
|
||||
|
||||
let youtube_link = "https://www.youtube.com/watch?v=" + post.file_path;
|
||||
|
||||
createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "p",
|
||||
innerHTML: "Target Video : <a href='" + youtube_link + "' target='_blank'>" + youtube_link + "</a>"
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
|
||||
//Post with movie
|
||||
if(post.kind == "movie"){
|
||||
|
||||
//Display the movie only (movies have a dedicated tab)
|
||||
createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "a",
|
||||
href: getFilePathFromURL(post.video_info.url),
|
||||
innerHTML: "Open movie"
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
|
||||
//Post with weblink
|
||||
if(post.kind == "weblink"){
|
||||
|
||||
let linkCard = createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "div",
|
||||
class: "card blue-text"
|
||||
});
|
||||
|
||||
let linkCardImage = createElem2({
|
||||
appendTo: linkCard,
|
||||
type: "div",
|
||||
class: "card-image"
|
||||
});
|
||||
|
||||
//Image
|
||||
createElem2({
|
||||
appendTo: linkCardImage,
|
||||
type: "img",
|
||||
src: post.link_image
|
||||
});
|
||||
|
||||
//Title
|
||||
createElem2({
|
||||
appendTo: linkCardImage,
|
||||
type: "span",
|
||||
class: "card-title",
|
||||
innerHTML: post.link_title
|
||||
});
|
||||
|
||||
createElem2({
|
||||
appendTo: linkCard,
|
||||
type: "div",
|
||||
class: "card-content",
|
||||
innerHTML: "<p>"+post.link_description+"</p>"
|
||||
});
|
||||
|
||||
let linkCardActions = createElem2({
|
||||
appendTo: linkCard,
|
||||
type: "div",
|
||||
class: "card-action"
|
||||
});
|
||||
|
||||
createElem2({
|
||||
appendTo: linkCardActions,
|
||||
type: "a",
|
||||
href: post.link_url,
|
||||
innerHTML: post.link_url
|
||||
})
|
||||
}
|
||||
|
||||
|
||||
//Post with PDF
|
||||
if(post.kind == "pdf"){
|
||||
|
||||
createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "a",
|
||||
class: "waves-effect waves-light btn-large post-btn-pdf",
|
||||
innerHTML: '<i class="material-icons left">picture_as_pdf</i> PDF',
|
||||
href: getFilePathFromURL(post.file_path_url)
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
|
||||
//Post with countdown timer
|
||||
if(post.kind == "countdown"){
|
||||
|
||||
createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "p",
|
||||
class: "post-end-countdown",
|
||||
innerHTML: "Countdown terminates on: " + timeToStr(post.time_end)
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
//Post with survey
|
||||
if(post.kind == "survey"){
|
||||
|
||||
let infoSurvey = post.data_survey;
|
||||
|
||||
let surveyContainer = createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "div",
|
||||
class: "post-survey card blue"
|
||||
});
|
||||
|
||||
//Survey content
|
||||
let surveyContent = createElem2({
|
||||
appendTo: surveyContainer,
|
||||
type: "div",
|
||||
class: "card-content"
|
||||
});
|
||||
|
||||
//Survey title
|
||||
createElem2({
|
||||
appendTo: surveyContent,
|
||||
type: "h2",
|
||||
class: "survey-title",
|
||||
innerHTML: infoSurvey.question
|
||||
});
|
||||
|
||||
//User choice (if any)
|
||||
if(infoSurvey.user_choice > 0){
|
||||
|
||||
createElem2({
|
||||
appendTo: surveyContent,
|
||||
type: "p",
|
||||
innerHTML: "Your choice : " + infoSurvey.choices[infoSurvey.user_choice].name
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
//Survey choices
|
||||
let surveyChoicesTable = createElem2({
|
||||
appendTo: surveyContainer,
|
||||
type: "table",
|
||||
class: "survey-choices-table"
|
||||
});
|
||||
|
||||
//Table header
|
||||
createElem2({
|
||||
appendTo: surveyChoicesTable,
|
||||
type: "thead",
|
||||
innerHTML: "<tr><th>Choice</th><th>Responses</th></tr>"
|
||||
});
|
||||
|
||||
//Table body
|
||||
let surveyTableBody = createElem2({
|
||||
appendTo: surveyChoicesTable,
|
||||
type: "tbody"
|
||||
});
|
||||
|
||||
for (const key in infoSurvey.choices) {
|
||||
if (!infoSurvey.choices.hasOwnProperty(key))
|
||||
continue;
|
||||
const choice = infoSurvey.choices[key];
|
||||
|
||||
//Add choice
|
||||
createElem2({
|
||||
appendTo: surveyTableBody,
|
||||
type: "tr",
|
||||
innerHTML: "<td>" + choice.name + "</td><td>" + choice.responses + "</td>"
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
//Display the list of comments
|
||||
let postComments = createElem2({
|
||||
appendTo: cardContent,
|
||||
type: "div",
|
||||
class: "post-comments",
|
||||
innerHTML: "Comments"
|
||||
});
|
||||
post.comments.forEach(comment => {
|
||||
|
||||
//Create comment container
|
||||
let commentContainer = createElem2({
|
||||
appendTo: postComments,
|
||||
type: "div",
|
||||
class: "comment"
|
||||
});
|
||||
|
||||
let commentCreator = createElem2({
|
||||
appendTo: commentContainer,
|
||||
type: "div",
|
||||
class: "comment-author"
|
||||
});
|
||||
|
||||
fillElWithUserInfo(commentCreator, comment.userID);
|
||||
|
||||
let commentContent = createElem2({
|
||||
appendTo: commentContainer,
|
||||
type: "div",
|
||||
innerHTML: comment.content
|
||||
});
|
||||
|
||||
|
||||
//Add comment image (if any)
|
||||
if(comment.img_url != null){
|
||||
|
||||
let img = createElem2({
|
||||
appendTo: commentContainer,
|
||||
type: "img",
|
||||
class: "comment-image"
|
||||
});
|
||||
|
||||
applyURLToImage(img, comment.img_url);
|
||||
|
||||
}
|
||||
|
||||
|
||||
let commentMetadata = createElem2({
|
||||
appendTo: commentContainer,
|
||||
type: "div",
|
||||
class: "comment-metadata"
|
||||
});
|
||||
|
||||
let addCommentMetadata = function(content){
|
||||
createElem2({
|
||||
appendTo: commentMetadata,
|
||||
type: "div",
|
||||
innerHTML: content
|
||||
});
|
||||
};
|
||||
|
||||
addCommentMetadata(timeToStr(comment.time_sent));
|
||||
addCommentMetadata("Likes: " + comment.likes);
|
||||
addCommentMetadata("User like: " + (comment.userlike ? "Yes" : "No"));
|
||||
})
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Automatically switch the tab when it
|
||||
|
Loading…
Reference in New Issue
Block a user