diff options
author | Paul S. Owen <psotfx@users.sourceforge.net> | 2002-11-21 01:35:53 +0000 |
---|---|---|
committer | Paul S. Owen <psotfx@users.sourceforge.net> | 2002-11-21 01:35:53 +0000 |
commit | f44c9705722d4bf3f05342c492d959df3131eccc (patch) | |
tree | 7e7ef3d77a364e35b0827c68df720c7e3303ffe6 /phpBB | |
parent | 44af2623123cd02a8baa484b69f88af8e6d1782b (diff) | |
download | forums-f44c9705722d4bf3f05342c492d959df3131eccc.tar forums-f44c9705722d4bf3f05342c492d959df3131eccc.tar.gz forums-f44c9705722d4bf3f05342c492d959df3131eccc.tar.bz2 forums-f44c9705722d4bf3f05342c492d959df3131eccc.tar.xz forums-f44c9705722d4bf3f05342c492d959df3131eccc.zip |
Just to get topic review working again ...
git-svn-id: file:///svn/phpbb/trunk@3072 89ea8834-ac86-4346-8a33-228a782c2dd0
Diffstat (limited to 'phpBB')
-rw-r--r-- | phpBB/posting.php | 175 | ||||
-rw-r--r-- | phpBB/templates/subSilver/posting_body.html | 2 | ||||
-rw-r--r-- | phpBB/templates/subSilver/posting_topic_review.html | 23 |
3 files changed, 182 insertions, 18 deletions
diff --git a/phpBB/posting.php b/phpBB/posting.php index a1cf2a130b..a6eab7bb02 100644 --- a/phpBB/posting.php +++ b/phpBB/posting.php @@ -42,6 +42,19 @@ if (!empty($cancel)) } +// TODO: +// * deletion of posts/polls? or should this (at least posts) +// be entirely handled by the mcp? +// * topic review +// * post preview (poll preview too?) +// * check for reply since started posting upon submission? +// * hidden form element containing sid to prevent remote +// posting - Edwin van Vliet +// * attachments +// * bbcode parsing +// * lock topic option within posting + + // --------- // POST INFO @@ -89,7 +102,11 @@ switch ($mode) break; case 'topicreview': - require($phpbb_root_path . 'includes/topic_review.'.$phpEx); + if (!isset($t)) + { + trigger_error($user->lang['Topic_not_exist']); + } + topic_review(intval($t), false); break; @@ -170,6 +187,13 @@ if (($mode == 'edit' || $mode == 'delete') && !empty($config['edit_time']) && $p if (isset($post)) { + // If replying/quoting and last post id has changed + // give user option of continuing submit or return to post + if (($mode == 'reply' || $mode == 'quote') && intval($topic_last_post_id) != intval($topic_cur_post_id)) + { + + } + $err_msg = ''; $parse_msg = new parse_message(); $search = new fulltext_search(); @@ -272,7 +296,7 @@ if (isset($post)) break; } - if (!$auth->acl_gets('f_' . $auth_option, 'm_' . $auth_option, 'a_', intval($forum_id))) + if (!$auth->acl_gets('f_' . $auth_option, 'm_', 'a_', intval($forum_id))) { $err_msg .= ((!empty($err_msg)) ? '<br />' : '') . $user->lang['Cannot_post_' . $auth_option]; } @@ -663,7 +687,7 @@ $template->assign_vars(array( 'U_VIEW_FORUM' => "viewforum.$phpEx$SID&f=" . intval($forum_id), 'U_VIEWTOPIC' => ($mode != 'post') ? "viewtopic.$phpEx$SID&t=" . intval($topic_id) : '', - 'U_REVIEW_TOPIC' => ($mode != 'post') ? "posting.$phpEx$SID&mmode=topicreview&t=" . intval($topic_id) : '', + 'U_REVIEW_TOPIC' => ($mode != 'post') ? "posting.$phpEx$SID&mode=topicreview&t=" . intval($topic_id) : '', 'U_VIEW_MODERATORS' => 'memberslist.' . $phpEx . $SID . '&mode=moderators&f=' . intval($forum_id), 'S_SHOW_TOPIC_ICONS' => $s_topic_icons, @@ -684,8 +708,10 @@ $template->assign_vars(array( 'S_DELETE_ALLOWED' => ($mode == 'edit' && (($post_id == $topic_last_post_id && $poster_id == $user->data['user_id'] && $auth->acl_get('f_delete', intval($forum_id))) || $auth->acl_gets('m_delete', 'a_', intval($forum_id)))) ? true : false, 'S_TYPE_TOGGLE' => $topic_type_toggle, + 'S_DISPLAY_REVIEW' => ($mode == 'reply' || $mode == 'quote') ? true : false, 'S_TOPIC_ID' => intval($topic_id), - 'S_POST_ACTION' => $s_action) + 'S_POST_ACTION' => $s_action, + 'S_HIDDEN_FIELDS' => ($mode == 'reply' || $mode == 'quote') ? '<input type="hidden" name="topic_cur_post_id" value="' . $topic_last_post_id . '" />' : '') ); // Poll entry @@ -693,7 +719,7 @@ if ((($mode == 'post' || ($mode == 'edit' && intval($post_id) == intval($topic_f { $template->assign_vars(array( 'S_SHOW_POLL_BOX' => true, - 'S_POLL_DELETE' => ($mode = 'edit' && !empty($poll_options) && ((empty($poll_last_vote) && $poster_id == $user->data['user_id'] && $auth->acl_get('f_delete', intval($forum_id))) || $auth->acl_gets('m_delete', 'a_', intval($forum_id)))) ? true : false, + 'S_POLL_DELETE' => ($mode == 'edit' && !empty($poll_options) && ((empty($poll_last_vote) && $poster_id == $user->data['user_id'] && $auth->acl_get('f_delete', intval($forum_id))) || $auth->acl_gets('m_delete', 'a_', intval($forum_id)))) ? true : false, 'L_POLL_OPTIONS_EXPLAIN'=> sprintf($user->lang['POLL_OPTIONS_EXPLAIN'], $config['max_poll_options']), @@ -715,20 +741,145 @@ if ($auth->acl_gets('f_attach', 'm_edit', 'a_', $forum_id)) include($phpbb_root_path . 'includes/page_header.'.$phpEx); $template->set_filenames(array( - 'body' => 'posting_body.html', - 'reviewbody' => 'posting_topic_review.html') + 'body' => 'posting_body.html') ); make_jumpbox('viewforum.'.$phpEx); // Topic review -if ($mode == 'reply') +if ($mode == 'reply' || $mode == 'quote') { -// require($phpbb_root_path . 'includes/topic_review.'.$phpEx); -// topic_review(intval($topic_id), true); - -// $template->assign_var_from_handle('TOPIC_REVIEW_BOX', 'reviewbody'); + topic_review(intval($topic_id), true); } include($phpbb_root_path . 'includes/page_tail.'.$phpEx); +// --------- +// FUNCTIONS +function topic_review($topic_id, $is_inline_review = false) +{ + global $SID, $db, $config, $template, $user, $auth; + global $orig_word, $replacement_word; + global $phpEx, $phpbb_root_path, $starttime; + + // Define censored word matches + if (empty($orig_word) && empty($replacement_word)) + { + $orig_word = $replacement_word = array(); + obtain_word_list($orig_word, $replacement_word); + } + + if (!$is_inline_review) + { + // Get topic info ... + $sql = "SELECT t.topic_title, f.forum_id + FROM " . TOPICS_TABLE . " t, " . FORUMS_TABLE . " f + WHERE t.topic_id = $topic_id + AND f.forum_id = t.forum_id"; + $result = $db->sql_query($sql); + + if (!($row = $db->sql_fetchrow($result))) + { + trigger_error($user->lang['Topic_post_not_exist']); + } + + $forum_id = intval($row['forum_id']); + $topic_title = $row['topic_title']; + + if (!$auth->acl_gets('f_read', 'm_', 'a_', $forum_id)) + { + trigger_error($user->lang['Sorry_auth_read']); + } + + if (count($orig_word)) + { + $topic_title = preg_replace($orig_word, $replacement_word, $topic_title); + } + } + else + { + $template->assign_vars(array( + 'S_DISPLAY_INLINE' => true) + ); + } + + // Go ahead and pull all data for this topic + $sql = "SELECT u.username, u.user_id, p.*, pt.post_text, pt.post_subject, pt.bbcode_uid + FROM " . POSTS_TABLE . " p, " . USERS_TABLE . " u, " . POSTS_TEXT_TABLE . " pt + WHERE p.topic_id = $topic_id + AND p.poster_id = u.user_id + AND p.post_id = pt.post_id + ORDER BY p.post_time DESC + LIMIT " . $config['posts_per_page']; + $result = $db->sql_query($sql); + + // Okay, let's do the loop, yeah come on baby let's do the loop + // and it goes like this ... + if ($row = $db->sql_fetchrow($result)) + { + $i = 0; + do + { + $poster_id = $row['user_id']; + $poster = $row['username']; + + // Handle anon users posting with usernames + if($poster_id == ANONYMOUS && $row['post_username'] != '') + { + $poster = $row['post_username']; + $poster_rank = $user->lang['Guest']; + } + + $post_subject = ($row['post_subject'] != '') ? $row['post_subject'] : ''; + + $message = $row['post_text']; + + if ($row['enable_smilies']) + { + $message = str_replace('<img src="{SMILE_PATH}', '<img src="' . $config['smilies_path'], $message); + } + + if (count($orig_word)) + { + $post_subject = preg_replace($orig_word, $replacement_word, $post_subject); + $message = preg_replace($orig_word, $replacement_word, $message); + } + + $template->assign_block_vars('postrow', array( + 'MINI_POST_IMG' => $user->img('goto_post', $user->lang['Post']), + 'POSTER_NAME' => $poster, + 'POST_DATE' => $user->format_date($row['post_time']), + 'POST_SUBJECT' => $post_subject, + 'MESSAGE' => nl2br($message), + + 'S_ROW_COUNT' => $i++) + ); + } + while ($row = $db->sql_fetchrow($result)); + } + else + { + trigger_error($user->lang['Topic_post_not_exist']); + } + $db->sql_freeresult($result); + + $template->assign_vars(array( + 'L_MESSAGE' => $user->lang['Message'], + 'L_POSTED' => $user->lang['Posted'], + 'L_POST_SUBJECT'=> $user->lang['Post_subject'], + 'L_TOPIC_REVIEW'=> $user->lang['Topic_review']) + ); + + if (!$is_inline_review) + { + $page_title = $user->lang['Topic_review'] . ' - ' . $topic_title; + include($phpbb_root_path . 'includes/page_header.'.$phpEx); + + $template->set_filenames(array( + 'body' => 'posting_topic_review.html') + ); + + include($phpbb_root_path . 'includes/page_tail.'.$phpEx); + } +} + ?>
\ No newline at end of file diff --git a/phpBB/templates/subSilver/posting_body.html b/phpBB/templates/subSilver/posting_body.html index 688faedbb6..a593a103c3 100644 --- a/phpBB/templates/subSilver/posting_body.html +++ b/phpBB/templates/subSilver/posting_body.html @@ -293,6 +293,6 @@ function checkForm() </tr> </table> -{TOPIC_REVIEW_BOX} +<!-- IF S_DISPLAY_REVIEW --><!-- INCLUDE posting_topic_review.html --><!-- ENDIF --> <!-- INCLUDE overall_footer.html -->
\ No newline at end of file diff --git a/phpBB/templates/subSilver/posting_topic_review.html b/phpBB/templates/subSilver/posting_topic_review.html index 026fc9e904..e3bba7c276 100644 --- a/phpBB/templates/subSilver/posting_topic_review.html +++ b/phpBB/templates/subSilver/posting_topic_review.html @@ -6,6 +6,11 @@ </tr> <tr> <td class="row1"><iframe width="100%" height="300" src="{U_REVIEW_TOPIC}"> + +<!-- ELSE --> + +<!-- INCLUDE simple_header.html --> + <!-- ENDIF --> <table border="0" cellpadding="3" cellspacing="1" width="100%" class="forumline"> @@ -14,11 +19,15 @@ <th class="thCornerR">{L_MESSAGE}</th> </tr> <!-- BEGIN postrow --> - <tr> - <td width="22%" align="left" valign="top" class="{postrow.ROW_CLASS}"><span class="name"><a name="{postrow.U_POST_ID}"></a><b>{postrow.POSTER_NAME}</b></span></td> - <td class="{postrow.ROW_CLASS}" height="28" valign="top"><table width="100%" border="0" cellspacing="0" cellpadding="0"> + <!-- IF postrow.S_ROW_COUNT is even --> + <tr class="row1"> + <!-- ELSE --> + <tr class="row2"> + <!-- ENDIF --> + <td width="22%" align="left" valign="top"><span class="name"><a name="{postrow.U_POST_ID}"></a><b>{postrow.POSTER_NAME}</b></span></td> + <td height="28" valign="top"><table width="100%" border="0" cellspacing="0" cellpadding="0"> <tr> - <td width="100%"><img src="{postrow.MINI_POST_IMG}" width="12" height="9" alt="{postrow.L_MINI_POST_ALT}" title="{postrow.L_MINI_POST_ALT}" border="0" /><span class="postdetails">{L_POSTED}: {postrow.POST_DATE}<span class="gen"> </span> {L_POST_SUBJECT}: {postrow.POST_SUBJECT}</span></td> + <td width="100%">{postrow.MINI_POST_IMG}<span class="postdetails">{L_POSTED}: {postrow.POST_DATE}<span class="gen"> </span> {L_POST_SUBJECT}: {postrow.POST_SUBJECT}</span></td> </tr> <tr> <td colspan="2"><hr /></td> @@ -38,4 +47,8 @@ </iframe></td> </tr> </table> -<!-- ENDIF -->
\ No newline at end of file +<!-- ELSE --> + +<!-- INCLUDE simple_footer.html --> + +<!-- ENDIF --> |