From 27c8ab854c233ce373f2acf4cd8ffe349ad7eb78 Mon Sep 17 00:00:00 2001 From: David Anderson Date: Fri, 1 Aug 2003 20:27:53 +0000 Subject: [PATCH] Added helpdesk forums. svn path=/trunk/boinc/; revision=1938 --- html/forum/forum.inc | 170 +++++++++++++++++++++++++++++++------------ 1 file changed, 125 insertions(+), 45 deletions(-) diff --git a/html/forum/forum.inc b/html/forum/forum.inc index 4423765096..43d2eeab08 100644 --- a/html/forum/forum.inc +++ b/html/forum/forum.inc @@ -2,6 +2,14 @@ require_once('../include/database.inc'); +define('NO_CONTROLS', 0); +define('FORUM_CONTROLS', 1); +define('HELPDESK_CONTROLS', 2); + +define ('SOLUTION', 'This solved my problem'); +define ('SUFFERER', 'I also have this problem'); +define ('OFF_TOPIC', 'Off-topic'); + class Category { var $id; var $name; @@ -27,8 +35,9 @@ class Forum { var $timestamp; var $threads; var $posts; + var $is_helpdesk; - function Forum($id = -1, $category = -1, $orderID = -1, $title = '', $description = '', $timestamp = 0, $threads = 0, $posts = 0) { + function Forum($id = -1, $category = -1, $orderID = -1, $title = '', $description = '', $timestamp = 0, $threads = 0, $posts = 0, $is_helpdesk = 0) { $vars = get_class_vars('Forum'); foreach ($vars as $var => $value) $this->$var = $$var; @@ -40,22 +49,25 @@ class Forum { function getThreads($min = -1, $nRec = -1, $sort_style='modified-new') { $sql = 'SELECT * FROM thread WHERE forum = '.$this->id; switch($sort_style) { - case 'modified-new': - $sql = $sql . ' ORDER BY timestamp DESC'; - break; - case 'modified-old': - $sql = $sql . ' ORDER BY timestamp ASC'; - break; - case 'views-most': - $sql = $sql . ' ORDER BY views DESC'; - break; - case 'replies-most': - $sql = $sql . ' ORDER BY replies DESC'; - break; - case 'activity-most': - $sql = $sql . ' ORDER by activity DESC, views DESC'; - break; - } + case 'modified-new': + $sql = $sql . ' ORDER BY timestamp DESC'; + break; + case 'modified-old': + $sql = $sql . ' ORDER BY timestamp ASC'; + break; + case 'views-most': + $sql = $sql . ' ORDER BY views DESC'; + break; + case 'replies-most': + $sql = $sql . ' ORDER BY replies DESC'; + break; + case 'activity-most': + $sql = $sql . ' ORDER by activity DESC, timestamp DESC'; + break; + case 'help-question-most': + $sql = $sql . ' ORDER by sufferers DESC, timestamp DESC'; + break; + } if ($min > -1) { $sql .= ' LIMIT '.$min; if ($nRec > -1) @@ -76,8 +88,9 @@ class Thread { var $timestamp; var $views; var $replies; + var $sufferers; - function Thread($id = -1, $forum = -1, $owner = -1, $title = '', $timestamp = 0, $views = 0, $replies = 0) { + function Thread($id = -1, $forum = -1, $owner = -1, $title = '', $timestamp = 0, $views = 0, $replies = 0, $sufferers = 0) { $vars = get_class_vars('Thread'); foreach ($vars as $var => $value) $this->$var = $$var; @@ -93,6 +106,9 @@ class Thread { case 'date-new': $sql = $sql . ' ORDER BY timestamp DESC'; break; + case 'score-high': + $sql = $sql . ' ORDER BY score DESC'; + break; case 'rating-high': $sql = $sql . ' ORDER BY rating DESC'; break; @@ -271,7 +287,7 @@ function getNextForum($result) { return false; foreach ($forum as $var => $value) $forum[$var] = stripslashes($value); - return new Forum($forum['id'], $forum['category'], $forum['orderID'], $forum['title'], $forum['description'], $forum['timestamp'], $forum['threads'], $forum['posts']); + return new Forum($forum['id'], $forum['category'], $forum['orderID'], $forum['title'], $forum['description'], $forum['timestamp'], $forum['threads'], $forum['posts'], $forum['is_helpdesk']); } function getNextThread($result) { @@ -280,7 +296,7 @@ function getNextThread($result) { return false; foreach ($thread as $var => $value) $thread[$var] = stripslashes($value); - return new Thread($thread['id'], $thread['forum'], $thread['owner'], $thread['title'], $thread['timestamp'], $thread['views'], $thread['replies']); + return new Thread($thread['id'], $thread['forum'], $thread['owner'], $thread['title'], $thread['timestamp'], $thread['views'], $thread['replies'], $thread['sufferers']); } function getNextPost($result) { @@ -309,30 +325,56 @@ function getPost($postID) { return getNextPost(sql_query($sql)); } +// Returns the post that started the thread with id = $threadId +function getFirstPost($threadID) { + $sql = "SELECT * FROM post WHERE thread = " . $threadID ." ORDER BY id ASC"; + $result = mysql_query($sql); + return mysql_fetch_object($result); +} + /* display functions */ -function show_posts($thread, $sort_style, $filter, $show_controls=true, $do_coloring=true) { +function show_posts($thread, $sort_style, $filter, $show_controls=true, $do_coloring=true, $is_helpdesk=false) { global $logged_in_user; $n = 0; + + if ($show_controls && !$is_helpdesk) { + $controls = FORUM_CONTROLS; + } else if ($show_controls && $is_helpdesk) { + $controls = HELPDESK_CONTROLS; + } else { + $controls = NO_CONTROLS; + } + $posts = $thread->getPosts(-1, -1, $sort_style); + $firstPost = getFirstPost($thread->id); + + if ($is_helpdesk) { + if ($firstPost) { + show_post($firstPost, $thread, $logged_in_user, $n, $controls, true); + } + } + while ($post = getNextPost($posts)) { if ($post->score >= $filter) { - show_post($post, $thread, $logged_in_user, $n, $show_controls); - if ($do_coloring) $n = ($n+1)%2; + if (!$is_helpdesk || ($is_helpdesk && $post->id != $firstPost->id)) { + show_post($post, $thread, $logged_in_user, $n, $controls, false); + if ($do_coloring) $n = ($n+1)%2; + } } } } -function show_post($post, $thread, $logged_in_user, $n, $show_controls=true) { +function show_post($post, $thread, $logged_in_user, $n, $controls=FORUM_CONTROLS, $separate=false) { $user = getUser($post->user); $can_edit = $logged_in_user && $user->id == $logged_in_user->id; echo " - - - id > -

- "; + + + id > +

+ "; if ($user->has_profile) { echo "user\">$user->name"; } else { @@ -341,25 +383,28 @@ function show_post($post, $thread, $logged_in_user, $n, $show_controls=true) { echo "

- Joined: ", date('M j, Y', $user->create_time), - "
Posts: $user->posts + Joined: ", date('M j, Y', $user->create_time), "
Posts: $user->posts

-
id, "\" method=\"post\"> - - -

- Posted: ", date('D M j, Y g:i a', $post->timestamp); + "; + if ($controls == FORUM_CONTROLS || $controls == HELPDESK_CONTROLS) { + echo "id, "\" method=\"post\">"; + } + echo " + + + "; - if ($show_controls) { + if ($controls == FORUM_CONTROLS) { echo " "; + } else if ($controls == HELPDESK_CONTROLS && $separate) { + echo " + + "; + } else if ($controls == HELPDESK_CONTROLS && !$separate) { + echo " + + "; } echo " -

+ Posted: ", date('D M j, Y g:i a', $post->timestamp); if ($post->parent_post) echo " in response to parent_post>Message ID $post->parent_post."; - if ($can_edit && $show_controls) echo " id\">[Edit this post]"; + if ($can_edit && $controls != NO_CONTROLS) echo " id\">[Edit this post]"; if ($post->modified) echo "
Last Modified: ", date('D M j, Y g:i a', $post->modified); echo "

Rate this post: + + + + +
- -

", nl2br(stripslashes($post->content)), "

"; +
"; + if ($controls == FORUM_CONTROLS || $controls == HELPDESK_CONTROLS) { + echo ""; + } + echo "

", nl2br(stripslashes($post->content)), "

"; echo " - "; - if ($show_controls) { - echo ""; - + "; + } else if ($controls == HELPDESK_CONTROLS && !$separate) { + echo " / Score: ", ($post->score * $post->votes), ""; + } else { + echo " / Rating: ", $post->score, ""; } + + if ($controls == FORUM_CONTROLS) { + echo ""; + } else if ($controls == HELPDESK_CONTROLS && !$separate) { + echo ""; + } echo "
ID: ", $post->id, ", Rating: ", $post->score, "[id, "&post=", $post->id, "#input\">Reply to this post]ID: ", $post->id; + if ($controls == HELPDESK_CONTROLS && $separate) { + echo "[id . "&post=" . $post->id . "#input\">Reply to this post][id . "&post=" . $post->id . "&helpdesk=1#input\">Reply to this answer]
"; + + if ($separate) { + echo " + +

+ + + + + "; + } } ?> \ No newline at end of file
AuthorAnswers