@@ -44,54 +44,54 @@ discard block |
||
| 44 | 44 | $query_vars = ['post_id', 'topic_id', 'status', 'order', 'start', 'move', 'mode']; |
| 45 | 45 | $query_array = []; |
| 46 | 46 | foreach ($query_vars as $var) { |
| 47 | - if (Request::getString($var, '', 'GET')) { |
|
| 48 | - $query_array[$var] = "{$var}=" . Request::getString($var, '', 'GET'); |
|
| 49 | - } |
|
| 47 | + if (Request::getString($var, '', 'GET')) { |
|
| 48 | + $query_array[$var] = "{$var}=" . Request::getString($var, '', 'GET'); |
|
| 49 | + } |
|
| 50 | 50 | } |
| 51 | 51 | $page_query = htmlspecialchars(implode('&', array_values($query_array)), ENT_QUOTES | ENT_HTML5); |
| 52 | 52 | unset($query_array); |
| 53 | 53 | |
| 54 | 54 | $forum_id = Request::getInt('forum', 0, 'GET'); |
| 55 | 55 | $read = (Request::getString('read', '', 'GET') |
| 56 | - && 'new' === Request::getString('read', '', 'GET')) ? Request::getString('read', '', 'GET') : ''; |
|
| 56 | + && 'new' === Request::getString('read', '', 'GET')) ? Request::getString('read', '', 'GET') : ''; |
|
| 57 | 57 | $topic_id = Request::getInt('topic_id', 0, 'GET'); // isset($_GET['topic_id']) ? (int)($_GET['topic_id']) : 0; |
| 58 | 58 | $post_id = Request::getInt('post_id', 0, 'GET'); // !empty($_GET['post_id']) ? (int)($_GET['post_id']) : 0; |
| 59 | 59 | $move = strtolower(Request::getString('move', '', 'GET')); // isset($_GET['move']) ? strtolower($_GET['move']) : ''; |
| 60 | 60 | $start = Request::getInt('start', 0, 'GET'); // !empty($_GET['start']) ? (int)($_GET['start']) : 0; |
| 61 | 61 | $status = (Request::getString('status', '', 'GET') |
| 62 | - && in_array(Request::getString('status', '', 'GET'), ['active', 'pending', 'deleted'], true)) ? Request::getString('status', '', 'GET') : ''; |
|
| 62 | + && in_array(Request::getString('status', '', 'GET'), ['active', 'pending', 'deleted'], true)) ? Request::getString('status', '', 'GET') : ''; |
|
| 63 | 63 | $mode = Request::getInt('mode', (!empty($status) ? 2 : 0), 'GET'); // !empty($_GET['mode']) ? (int)($_GET['mode']) : (!empty($status) ? 2 : 0); |
| 64 | 64 | $order = (Request::getString('order', '', 'GET') |
| 65 | - && in_array(Request::getString('order', '', 'GET'), ['ASC', 'DESC'], true)) ? Request::getString('order', '', 'GET') : ''; |
|
| 65 | + && in_array(Request::getString('order', '', 'GET'), ['ASC', 'DESC'], true)) ? Request::getString('order', '', 'GET') : ''; |
|
| 66 | 66 | |
| 67 | 67 | if ('' === $order) { |
| 68 | - if (is_object($GLOBALS['xoopsUser']) && $GLOBALS['xoopsUser']->isActive()) { |
|
| 69 | - $order = (1 == $GLOBALS['xoopsUser']->getVar('uorder')) ? 'DESC' : 'ASC'; |
|
| 70 | - } else { |
|
| 71 | - $order = (1 == $GLOBALS['xoopsConfig']['com_order']) ? 'DESC' : 'ASC'; |
|
| 72 | - } |
|
| 68 | + if (is_object($GLOBALS['xoopsUser']) && $GLOBALS['xoopsUser']->isActive()) { |
|
| 69 | + $order = (1 == $GLOBALS['xoopsUser']->getVar('uorder')) ? 'DESC' : 'ASC'; |
|
| 70 | + } else { |
|
| 71 | + $order = (1 == $GLOBALS['xoopsConfig']['com_order']) ? 'DESC' : 'ASC'; |
|
| 72 | + } |
|
| 73 | 73 | } |
| 74 | 74 | |
| 75 | 75 | if (!$topic_id && !$post_id) { |
| 76 | - $redirect = empty($forum_id) ? XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/index.php' : XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/viewforum.php?forum={$forum_id}"; |
|
| 77 | - redirect_header($redirect, 2, _MD_NEWBB_ERRORTOPIC); |
|
| 76 | + $redirect = empty($forum_id) ? XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/index.php' : XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/viewforum.php?forum={$forum_id}"; |
|
| 77 | + redirect_header($redirect, 2, _MD_NEWBB_ERRORTOPIC); |
|
| 78 | 78 | } |
| 79 | 79 | |
| 80 | 80 | ///** @var Newbb\TopicHandler $topicHandler */ |
| 81 | 81 | //$topicHandler = Newbb\Helper::getInstance()->getHandler('Topic'); |
| 82 | 82 | if (!empty($post_id)) { |
| 83 | - $topicObject = $topicHandler->getByPost($post_id); |
|
| 84 | - $topic_id = $topicObject->getVar('topic_id'); |
|
| 83 | + $topicObject = $topicHandler->getByPost($post_id); |
|
| 84 | + $topic_id = $topicObject->getVar('topic_id'); |
|
| 85 | 85 | } elseif (!empty($move)) { |
| 86 | - $topicObject = $topicHandler->getByMove($topic_id, ('prev' === $move) ? -1 : 1, $forum_id); |
|
| 87 | - $topic_id = $topicObject->getVar('topic_id'); |
|
| 86 | + $topicObject = $topicHandler->getByMove($topic_id, ('prev' === $move) ? -1 : 1, $forum_id); |
|
| 87 | + $topic_id = $topicObject->getVar('topic_id'); |
|
| 88 | 88 | } else { |
| 89 | - $topicObject = $topicHandler->get($topic_id); |
|
| 89 | + $topicObject = $topicHandler->get($topic_id); |
|
| 90 | 90 | } |
| 91 | 91 | |
| 92 | 92 | if (!is_object($topicObject) || !$topic_id = $topicObject->getVar('topic_id')) { |
| 93 | - $redirect = empty($forum_id) ? XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/index.php' : XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/viewforum.php?forum={$forum_id}"; |
|
| 94 | - redirect_header($redirect, 2, _MD_NEWBB_ERRORTOPIC); |
|
| 93 | + $redirect = empty($forum_id) ? XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/index.php' : XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/viewforum.php?forum={$forum_id}"; |
|
| 94 | + redirect_header($redirect, 2, _MD_NEWBB_ERRORTOPIC); |
|
| 95 | 95 | } |
| 96 | 96 | $forum_id = $topicObject->getVar('forum_id'); |
| 97 | 97 | ///** @var Newbb\ForumHandler $forumHandler */ |
@@ -101,8 +101,8 @@ discard block |
||
| 101 | 101 | $isAdmin = newbbIsAdmin($forumObject); |
| 102 | 102 | |
| 103 | 103 | if ((!$isAdmin && $topicObject->getVar('approved') < 0) || (!$forumHandler->getPermission($forumObject)) |
| 104 | - || (!$topicHandler->getPermission($forumObject, $topicObject->getVar('topic_status'), 'view'))) { |
|
| 105 | - redirect_header(XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/viewforum.php?forum=' . $forum_id, 2, _MD_NEWBB_NORIGHTTOVIEW); |
|
| 104 | + || (!$topicHandler->getPermission($forumObject, $topicObject->getVar('topic_status'), 'view'))) { |
|
| 105 | + redirect_header(XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/viewforum.php?forum=' . $forum_id, 2, _MD_NEWBB_NORIGHTTOVIEW); |
|
| 106 | 106 | } |
| 107 | 107 | |
| 108 | 108 | // START irmtfan - find if topic is read or unread - for all users (member and anon) |
@@ -118,32 +118,32 @@ discard block |
||
| 118 | 118 | */ |
| 119 | 119 | $topic_last_post_time_or_id_read = newbbGetRead('topic', $topic_id); |
| 120 | 120 | if (!empty($topic_last_post_time_or_id_read)) { |
| 121 | - if (1 == $GLOBALS['xoopsModuleConfig']['read_mode']) { |
|
| 122 | - // $postHandler = Newbb\Helper::getInstance()->getHandler('Post'); |
|
| 123 | - $postObject = $postHandler->get($topicObject->getVar('topic_last_post_id')); |
|
| 124 | - $topic_is_unread = ($topic_last_post_time_or_id_read < $postObject->getVar('post_time')); |
|
| 125 | - } |
|
| 126 | - if (2 == $GLOBALS['xoopsModuleConfig']['read_mode']) { |
|
| 127 | - $topic_is_unread = ($topic_last_post_time_or_id_read < $topicObject->getVar('topic_last_post_id')); |
|
| 128 | - // hack jump to last post read if post_id is empty - is there any better way? |
|
| 129 | - if (empty($post_id) && $topic_is_unread |
|
| 130 | - && !empty($GLOBALS['xoopsModuleConfig']['jump_to_topic_last_post_read_enabled'])) { |
|
| 131 | - header('Location: ' . Request::getString('REQUEST_URI', '', 'SERVER') . '&post_id=' . $topic_last_post_time_or_id_read); |
|
| 132 | - } |
|
| 133 | - } |
|
| 121 | + if (1 == $GLOBALS['xoopsModuleConfig']['read_mode']) { |
|
| 122 | + // $postHandler = Newbb\Helper::getInstance()->getHandler('Post'); |
|
| 123 | + $postObject = $postHandler->get($topicObject->getVar('topic_last_post_id')); |
|
| 124 | + $topic_is_unread = ($topic_last_post_time_or_id_read < $postObject->getVar('post_time')); |
|
| 125 | + } |
|
| 126 | + if (2 == $GLOBALS['xoopsModuleConfig']['read_mode']) { |
|
| 127 | + $topic_is_unread = ($topic_last_post_time_or_id_read < $topicObject->getVar('topic_last_post_id')); |
|
| 128 | + // hack jump to last post read if post_id is empty - is there any better way? |
|
| 129 | + if (empty($post_id) && $topic_is_unread |
|
| 130 | + && !empty($GLOBALS['xoopsModuleConfig']['jump_to_topic_last_post_read_enabled'])) { |
|
| 131 | + header('Location: ' . Request::getString('REQUEST_URI', '', 'SERVER') . '&post_id=' . $topic_last_post_time_or_id_read); |
|
| 132 | + } |
|
| 133 | + } |
|
| 134 | 134 | } |
| 135 | 135 | // END irmtfan - find if topic is read or unread - for all users (member and anon) |
| 136 | 136 | |
| 137 | 137 | /* Only admin has access to admin mode */ |
| 138 | 138 | if (!$isAdmin) { |
| 139 | - $status = ''; |
|
| 140 | - $mode = 0; |
|
| 139 | + $status = ''; |
|
| 140 | + $mode = 0; |
|
| 141 | 141 | } |
| 142 | 142 | |
| 143 | 143 | if (!empty($GLOBALS['xoopsModuleConfig']['enable_karma'])) { |
| 144 | - // /** @var Newbb\KarmaHandler $karmaHandler */ |
|
| 145 | - // $karmaHandler = Newbb\Helper::getInstance()->getHandler('Karma'); |
|
| 146 | - $user_karma = $karmaHandler->getUserKarma(); |
|
| 144 | + // /** @var Newbb\KarmaHandler $karmaHandler */ |
|
| 145 | + // $karmaHandler = Newbb\Helper::getInstance()->getHandler('Karma'); |
|
| 146 | + $user_karma = $karmaHandler->getUserKarma(); |
|
| 147 | 147 | } |
| 148 | 148 | |
| 149 | 149 | //$viewmode = "flat"; |
@@ -154,7 +154,7 @@ discard block |
||
| 154 | 154 | |
| 155 | 155 | //irmtfan - increment topic_views only if the topic is unread |
| 156 | 156 | if ($topic_is_unread) { |
| 157 | - $topicObject->incrementCounter(); |
|
| 157 | + $topicObject->incrementCounter(); |
|
| 158 | 158 | } |
| 159 | 159 | newbbSetRead('topic', $topic_id, $topicObject->getVar('topic_last_post_id')); |
| 160 | 160 | |
@@ -166,16 +166,16 @@ discard block |
||
| 166 | 166 | //$xoopsTpl->assign('xoops_module_header', $xoops_module_header); |
| 167 | 167 | // irmtfan new method |
| 168 | 168 | if (!empty($GLOBALS['xoopsModuleConfig']['rss_enable'])) { |
| 169 | - $xoopsTpl->assign('xoops_module_header', ' |
|
| 169 | + $xoopsTpl->assign('xoops_module_header', ' |
|
| 170 | 170 | <link rel="alternate" type="application/rss+xml" title="' . $xoopsModule->getVar('name') . '-' . $forumObject->getVar('forum_name') . '" href="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/rss.php?f=' . $forumObject->getVar('forum_id') . '" /> |
| 171 | 171 | ' . @$xoopsTpl->get_template_vars('xoops_module_header')); |
| 172 | 172 | } |
| 173 | 173 | |
| 174 | 174 | if ($GLOBALS['xoopsModuleConfig']['wol_enabled']) { |
| 175 | - /** @var Newbb\OnlineHandler $onlineHandler */ |
|
| 176 | - $onlineHandler = Newbb\Helper::getInstance()->getHandler('Online'); |
|
| 177 | - $onlineHandler->init($forumObject, $topicObject); |
|
| 178 | - $xoopsTpl->assign('online', $onlineHandler->showOnline()); |
|
| 175 | + /** @var Newbb\OnlineHandler $onlineHandler */ |
|
| 176 | + $onlineHandler = Newbb\Helper::getInstance()->getHandler('Online'); |
|
| 177 | + $onlineHandler->init($forumObject, $topicObject); |
|
| 178 | + $xoopsTpl->assign('online', $onlineHandler->showOnline()); |
|
| 179 | 179 | } |
| 180 | 180 | $xoopsTpl->assign('parentforum', $forumHandler->getParents($forumObject)); |
| 181 | 181 | // irmtfan - remove icon_path and use newbbDisplayImage |
@@ -189,32 +189,32 @@ discard block |
||
| 189 | 189 | $iconHandler = newbbGetIconHandler(); // can be use in the follwing codes in this file |
| 190 | 190 | |
| 191 | 191 | if ($infobox['show'] > 0) { |
| 192 | - // irmtfan - remove icon_path and use newbbDisplayImage |
|
| 193 | - $infobox['icon'] = [ |
|
| 194 | - 'expand' => $iconHandler->getImageSource('less'), |
|
| 195 | - 'collapse' => $iconHandler->getImageSource('more') |
|
| 196 | - ]; |
|
| 197 | - if (1 == $infobox['show']) { |
|
| 198 | - $infobox['style'] = 'none'; //irmtfan move semicolon |
|
| 199 | - $infobox['alt'] = _MD_NEWBB_SEEUSERDATA; |
|
| 200 | - $infobox['src'] = 'more'; |
|
| 201 | - } else { |
|
| 202 | - $infobox['style'] = 'block'; //irmtfan move semicolon |
|
| 203 | - $infobox['alt'] = _MD_NEWBB_HIDEUSERDATA; |
|
| 204 | - $infobox['src'] = 'less'; |
|
| 205 | - } |
|
| 206 | - $infobox['displayImage'] = newbbDisplayImage($infobox['src'], $infobox['alt']); |
|
| 192 | + // irmtfan - remove icon_path and use newbbDisplayImage |
|
| 193 | + $infobox['icon'] = [ |
|
| 194 | + 'expand' => $iconHandler->getImageSource('less'), |
|
| 195 | + 'collapse' => $iconHandler->getImageSource('more') |
|
| 196 | + ]; |
|
| 197 | + if (1 == $infobox['show']) { |
|
| 198 | + $infobox['style'] = 'none'; //irmtfan move semicolon |
|
| 199 | + $infobox['alt'] = _MD_NEWBB_SEEUSERDATA; |
|
| 200 | + $infobox['src'] = 'more'; |
|
| 201 | + } else { |
|
| 202 | + $infobox['style'] = 'block'; //irmtfan move semicolon |
|
| 203 | + $infobox['alt'] = _MD_NEWBB_HIDEUSERDATA; |
|
| 204 | + $infobox['src'] = 'less'; |
|
| 205 | + } |
|
| 206 | + $infobox['displayImage'] = newbbDisplayImage($infobox['src'], $infobox['alt']); |
|
| 207 | 207 | } |
| 208 | 208 | $xoopsTpl->assign('infobox', $infobox); |
| 209 | 209 | // END irmtfan improve infobox |
| 210 | 210 | |
| 211 | 211 | $xoopsTpl->assign([ |
| 212 | - 'topic_title' => '<a href="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/viewtopic.php?topic_id=' . $topic_id . '">' . $topicObject->getFullTitle() . '</a>', |
|
| 213 | - 'forum_name' => $forumObject->getVar('forum_name'), |
|
| 214 | - 'lang_nexttopic' => _MD_NEWBB_NEXTTOPIC, |
|
| 215 | - 'lang_prevtopic' => _MD_NEWBB_PREVTOPIC, |
|
| 216 | - 'topic_status' => $topicObject->getVar('topic_status') |
|
| 217 | - ]); |
|
| 212 | + 'topic_title' => '<a href="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/viewtopic.php?topic_id=' . $topic_id . '">' . $topicObject->getFullTitle() . '</a>', |
|
| 213 | + 'forum_name' => $forumObject->getVar('forum_name'), |
|
| 214 | + 'lang_nexttopic' => _MD_NEWBB_NEXTTOPIC, |
|
| 215 | + 'lang_prevtopic' => _MD_NEWBB_PREVTOPIC, |
|
| 216 | + 'topic_status' => $topicObject->getVar('topic_status') |
|
| 217 | + ]); |
|
| 218 | 218 | |
| 219 | 219 | //$categoryHandler = Newbb\Helper::getInstance()->getHandler('Category'); |
| 220 | 220 | $categoryObject = $categoryHandler->get($forumObject->getVar('cat_id'), ['cat_title']); |
@@ -231,149 +231,149 @@ discard block |
||
| 231 | 231 | $t_reply = newbbDisplayImage('t_reply', _MD_NEWBB_REPLY); |
| 232 | 232 | // irmtfan show topic status if show reg is 0 and revise forum_post_or_register |
| 233 | 233 | if ($topicHandler->getPermission($forumObject, $topicObject->getVar('topic_status'), 'post')) { |
| 234 | - $xoopsTpl->assign('forum_post', '<a href="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/newtopic.php?forum=' . $forum_id . '"> ' . $t_new . '</a>'); |
|
| 234 | + $xoopsTpl->assign('forum_post', '<a href="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/newtopic.php?forum=' . $forum_id . '"> ' . $t_new . '</a>'); |
|
| 235 | 235 | } else { |
| 236 | - if ($topicObject->getVar('topic_status')) { |
|
| 237 | - $xoopsTpl->assign('topic_lock', _MD_NEWBB_TOPICLOCKED); |
|
| 238 | - } |
|
| 239 | - if (!is_object($GLOBALS['xoopsUser']) && !empty($GLOBALS['xoopsModuleConfig']['show_reg'])) { |
|
| 240 | - $xoopsTpl->assign('forum_register', '<a href="' . XOOPS_URL . '/user.php?xoops_redirect=' . htmlspecialchars($xoopsRequestUri, ENT_QUOTES | ENT_HTML5) . '">' . _MD_NEWBB_REGTOPOST . '</a>'); |
|
| 241 | - } |
|
| 236 | + if ($topicObject->getVar('topic_status')) { |
|
| 237 | + $xoopsTpl->assign('topic_lock', _MD_NEWBB_TOPICLOCKED); |
|
| 238 | + } |
|
| 239 | + if (!is_object($GLOBALS['xoopsUser']) && !empty($GLOBALS['xoopsModuleConfig']['show_reg'])) { |
|
| 240 | + $xoopsTpl->assign('forum_register', '<a href="' . XOOPS_URL . '/user.php?xoops_redirect=' . htmlspecialchars($xoopsRequestUri, ENT_QUOTES | ENT_HTML5) . '">' . _MD_NEWBB_REGTOPOST . '</a>'); |
|
| 241 | + } |
|
| 242 | 242 | } |
| 243 | 243 | // irmtfan for backward compatibility assign forum_post_or_register smarty again. |
| 244 | 244 | $xoopsTpl->assign('forum_post_or_register', @$xoopsTpl->get_template_vars('forum_post') . @$xoopsTpl->get_template_vars('forum_register') . @$xoopsTpl->get_template_vars('topic_lock')); |
| 245 | 245 | |
| 246 | 246 | if ($topicHandler->getPermission($forumObject, $topicObject->getVar('topic_status'), 'reply')) { |
| 247 | - $xoopsTpl->assign('forum_reply', '<a href="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/reply.php?topic_id=' . $topic_id . '"> ' . $t_reply . '</a>'); |
|
| 247 | + $xoopsTpl->assign('forum_reply', '<a href="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/reply.php?topic_id=' . $topic_id . '"> ' . $t_reply . '</a>'); |
|
| 248 | 248 | } |
| 249 | 249 | |
| 250 | 250 | $poster_array = []; |
| 251 | 251 | $require_reply = false; |
| 252 | 252 | /** @var Post $eachpost */ |
| 253 | 253 | foreach ($postsArray as $eachpost) { |
| 254 | - if ($eachpost->getVar('uid') > 0) { |
|
| 255 | - $poster_array[$eachpost->getVar('uid')] = 1; |
|
| 256 | - } |
|
| 257 | - if ($eachpost->getVar('require_reply') > 0) { |
|
| 258 | - $require_reply = true; |
|
| 259 | - } |
|
| 254 | + if ($eachpost->getVar('uid') > 0) { |
|
| 255 | + $poster_array[$eachpost->getVar('uid')] = 1; |
|
| 256 | + } |
|
| 257 | + if ($eachpost->getVar('require_reply') > 0) { |
|
| 258 | + $require_reply = true; |
|
| 259 | + } |
|
| 260 | 260 | } |
| 261 | 261 | |
| 262 | 262 | $userid_array = []; |
| 263 | 263 | $online = []; |
| 264 | 264 | if (is_array($poster_array) && count($poster_array) > 0) { |
| 265 | - /** @var \XoopsMemberHandler $memberHandler */ |
|
| 266 | - $memberHandler = xoops_getHandler('member'); |
|
| 267 | - $userid_array = array_keys($poster_array); |
|
| 268 | - $user_criteria = '(' . implode(',', $userid_array) . ')'; |
|
| 269 | - $users = $memberHandler->getUsers(new \Criteria('uid', $user_criteria, 'IN'), true); |
|
| 265 | + /** @var \XoopsMemberHandler $memberHandler */ |
|
| 266 | + $memberHandler = xoops_getHandler('member'); |
|
| 267 | + $userid_array = array_keys($poster_array); |
|
| 268 | + $user_criteria = '(' . implode(',', $userid_array) . ')'; |
|
| 269 | + $users = $memberHandler->getUsers(new \Criteria('uid', $user_criteria, 'IN'), true); |
|
| 270 | 270 | } else { |
| 271 | - $users = []; |
|
| 271 | + $users = []; |
|
| 272 | 272 | } |
| 273 | 273 | |
| 274 | 274 | $viewtopic_users = []; |
| 275 | 275 | if (is_array($userid_array) && count($userid_array) > 0) { |
| 276 | 276 | // require_once $GLOBALS['xoops']->path('modules/' . $xoopsModule->getVar('dirname', 'n') . '/class/user.php'); |
| 277 | - $userHandler = new Newbb\UserHandler($GLOBALS['xoopsModuleConfig']['groupbar_enabled'], $GLOBALS['xoopsModuleConfig']['wol_enabled']); |
|
| 278 | - $userHandler->users = $users; |
|
| 279 | - $userHandler->online = $online; |
|
| 280 | - $viewtopic_users = $userHandler->getUsers(); |
|
| 277 | + $userHandler = new Newbb\UserHandler($GLOBALS['xoopsModuleConfig']['groupbar_enabled'], $GLOBALS['xoopsModuleConfig']['wol_enabled']); |
|
| 278 | + $userHandler->users = $users; |
|
| 279 | + $userHandler->online = $online; |
|
| 280 | + $viewtopic_users = $userHandler->getUsers(); |
|
| 281 | 281 | } |
| 282 | 282 | unset($users); |
| 283 | 283 | |
| 284 | 284 | if ($GLOBALS['xoopsModuleConfig']['allow_require_reply'] && $require_reply) { |
| 285 | - if (!empty($GLOBALS['xoopsModuleConfig']['cache_enabled'])) { |
|
| 286 | - $viewtopic_posters = newbbGetSession('t' . $topic_id, true); |
|
| 287 | - if (!is_array($viewtopic_posters) || 0 === count($viewtopic_posters)) { |
|
| 288 | - $viewtopic_posters = $topicHandler->getAllPosters($topicObject); |
|
| 289 | - newbbSetSession('t' . $topic_id, $viewtopic_posters); |
|
| 290 | - } |
|
| 291 | - } else { |
|
| 292 | - $viewtopic_posters = $topicHandler->getAllPosters($topicObject); |
|
| 293 | - } |
|
| 285 | + if (!empty($GLOBALS['xoopsModuleConfig']['cache_enabled'])) { |
|
| 286 | + $viewtopic_posters = newbbGetSession('t' . $topic_id, true); |
|
| 287 | + if (!is_array($viewtopic_posters) || 0 === count($viewtopic_posters)) { |
|
| 288 | + $viewtopic_posters = $topicHandler->getAllPosters($topicObject); |
|
| 289 | + newbbSetSession('t' . $topic_id, $viewtopic_posters); |
|
| 290 | + } |
|
| 291 | + } else { |
|
| 292 | + $viewtopic_posters = $topicHandler->getAllPosters($topicObject); |
|
| 293 | + } |
|
| 294 | 294 | } else { |
| 295 | - $viewtopic_posters = []; |
|
| 295 | + $viewtopic_posters = []; |
|
| 296 | 296 | } |
| 297 | 297 | |
| 298 | 298 | if ($GLOBALS['xoopsModuleConfig']['show_advertising']) { |
| 299 | - $post_werbung = [ |
|
| 300 | - 'post_id' => 0, |
|
| 301 | - 'post_parent_id' => 0, |
|
| 302 | - 'post_date' => 0, |
|
| 303 | - 'post_image' => '', |
|
| 304 | - 'post_title' => '', |
|
| 305 | - 'post_text' => '<div style="text-align: center;vertical-align: middle;"><br>' . xoops_getbanner() . '</div>', |
|
| 306 | - 'post_attachment' => '', |
|
| 307 | - 'post_edit' => 0, |
|
| 308 | - 'post_no' => 0, |
|
| 309 | - 'post_signature' => _MD_NEWBB_ADVERTISING_BLOCK, |
|
| 310 | - 'poster_ip' => '', |
|
| 311 | - 'thread_action' => '', |
|
| 312 | - 'thread_buttons' => '', |
|
| 313 | - 'mod_buttons' => '', |
|
| 314 | - 'poster' => [ |
|
| 315 | - 'uid' => -1, |
|
| 316 | - 'link' => _MD_NEWBB_ADVERTISING_USER, |
|
| 317 | - 'avatar' => 'avatars/blank.gif', |
|
| 318 | - 'regdate' => 0, |
|
| 319 | - 'last_login' => 0, |
|
| 320 | - 'rank' => ['title' => ''] |
|
| 321 | - ], |
|
| 322 | - // irmtfan add last_login |
|
| 323 | - 'post_permalink' => '' |
|
| 324 | - ]; |
|
| 299 | + $post_werbung = [ |
|
| 300 | + 'post_id' => 0, |
|
| 301 | + 'post_parent_id' => 0, |
|
| 302 | + 'post_date' => 0, |
|
| 303 | + 'post_image' => '', |
|
| 304 | + 'post_title' => '', |
|
| 305 | + 'post_text' => '<div style="text-align: center;vertical-align: middle;"><br>' . xoops_getbanner() . '</div>', |
|
| 306 | + 'post_attachment' => '', |
|
| 307 | + 'post_edit' => 0, |
|
| 308 | + 'post_no' => 0, |
|
| 309 | + 'post_signature' => _MD_NEWBB_ADVERTISING_BLOCK, |
|
| 310 | + 'poster_ip' => '', |
|
| 311 | + 'thread_action' => '', |
|
| 312 | + 'thread_buttons' => '', |
|
| 313 | + 'mod_buttons' => '', |
|
| 314 | + 'poster' => [ |
|
| 315 | + 'uid' => -1, |
|
| 316 | + 'link' => _MD_NEWBB_ADVERTISING_USER, |
|
| 317 | + 'avatar' => 'avatars/blank.gif', |
|
| 318 | + 'regdate' => 0, |
|
| 319 | + 'last_login' => 0, |
|
| 320 | + 'rank' => ['title' => ''] |
|
| 321 | + ], |
|
| 322 | + // irmtfan add last_login |
|
| 323 | + 'post_permalink' => '' |
|
| 324 | + ]; |
|
| 325 | 325 | } |
| 326 | 326 | |
| 327 | 327 | $i = 0; |
| 328 | 328 | /** @var Post $eachpost */ |
| 329 | 329 | foreach ($postsArray as $eachpost) { |
| 330 | - if ($GLOBALS['xoopsModuleConfig']['show_advertising']) { |
|
| 331 | - if (2 === $i) { |
|
| 332 | - $xoopsTpl->append('topic_posts', $post_werbung); |
|
| 333 | - } |
|
| 334 | - ++$i; |
|
| 335 | - } |
|
| 336 | - $xoopsTpl->append('topic_posts', $eachpost->showPost($isAdmin)); |
|
| 330 | + if ($GLOBALS['xoopsModuleConfig']['show_advertising']) { |
|
| 331 | + if (2 === $i) { |
|
| 332 | + $xoopsTpl->append('topic_posts', $post_werbung); |
|
| 333 | + } |
|
| 334 | + ++$i; |
|
| 335 | + } |
|
| 336 | + $xoopsTpl->append('topic_posts', $eachpost->showPost($isAdmin)); |
|
| 337 | 337 | } |
| 338 | 338 | |
| 339 | 339 | if ($total_posts > $GLOBALS['xoopsModuleConfig']['posts_per_page']) { |
| 340 | - require_once $GLOBALS['xoops']->path('class/pagenav.php'); |
|
| 341 | - |
|
| 342 | - $nav = new \XoopsPageNav($total_posts, $GLOBALS['xoopsModuleConfig']['posts_per_page'], $start, 'start', 'topic_id=' . $topic_id . '&order=' . $order . '&status=' . $status . '&mode=' . $mode); |
|
| 343 | - //if (isset($GLOBALS['xoopsModuleConfig']['do_rewrite']) && $GLOBALS['xoopsModuleConfig']['do_rewrite'] === 1) $nav->url = XOOPS_URL . $nav->url; |
|
| 344 | - if ('select' === $GLOBALS['xoopsModuleConfig']['pagenav_display']) { |
|
| 345 | - $navi = $nav->renderSelect(); |
|
| 346 | - } elseif ('image' === $GLOBALS['xoopsModuleConfig']['pagenav_display']) { |
|
| 347 | - $navi = $nav->renderImageNav(4); |
|
| 348 | - } else { |
|
| 349 | - $navi = $nav->renderNav(4); |
|
| 350 | - } |
|
| 351 | - $xoopsTpl->assign('forum_page_nav', $navi); |
|
| 340 | + require_once $GLOBALS['xoops']->path('class/pagenav.php'); |
|
| 341 | + |
|
| 342 | + $nav = new \XoopsPageNav($total_posts, $GLOBALS['xoopsModuleConfig']['posts_per_page'], $start, 'start', 'topic_id=' . $topic_id . '&order=' . $order . '&status=' . $status . '&mode=' . $mode); |
|
| 343 | + //if (isset($GLOBALS['xoopsModuleConfig']['do_rewrite']) && $GLOBALS['xoopsModuleConfig']['do_rewrite'] === 1) $nav->url = XOOPS_URL . $nav->url; |
|
| 344 | + if ('select' === $GLOBALS['xoopsModuleConfig']['pagenav_display']) { |
|
| 345 | + $navi = $nav->renderSelect(); |
|
| 346 | + } elseif ('image' === $GLOBALS['xoopsModuleConfig']['pagenav_display']) { |
|
| 347 | + $navi = $nav->renderImageNav(4); |
|
| 348 | + } else { |
|
| 349 | + $navi = $nav->renderNav(4); |
|
| 350 | + } |
|
| 351 | + $xoopsTpl->assign('forum_page_nav', $navi); |
|
| 352 | 352 | } else { |
| 353 | - $xoopsTpl->assign('forum_page_nav', ''); |
|
| 353 | + $xoopsTpl->assign('forum_page_nav', ''); |
|
| 354 | 354 | } |
| 355 | 355 | |
| 356 | 356 | if (empty($post_id)) { |
| 357 | - $first = array_keys($postsArray); |
|
| 358 | - $post_id = !empty($first[0]) ? $first[0] : 0; |
|
| 357 | + $first = array_keys($postsArray); |
|
| 358 | + $post_id = !empty($first[0]) ? $first[0] : 0; |
|
| 359 | 359 | } |
| 360 | 360 | |
| 361 | 361 | if (!empty($postsArray[$post_id])) { |
| 362 | - $xoops_pagetitle = $postsArray[$post_id]->getVar('subject') . ' [' . $forumObject->getVar('forum_name') . ']'; |
|
| 363 | - $xoopsTpl->assign('xoops_pagetitle', $xoops_pagetitle); |
|
| 364 | - $xoopsOption['xoops_pagetitle'] = $xoops_pagetitle; |
|
| 365 | - $kw = array_unique(explode(' ', strip_tags($postsArray[$post_id]->getVar('post_text')), 150)); |
|
| 366 | - asort($kw); |
|
| 367 | - $kwort = ''; |
|
| 368 | - $z = 0; |
|
| 369 | - foreach ($kw as $k) { |
|
| 370 | - if ($z < 30 && strlen(trim($k)) > 5) { |
|
| 371 | - $kwort .= trim($k) . ' '; |
|
| 372 | - ++$z; |
|
| 373 | - } |
|
| 374 | - } |
|
| 375 | - $xoTheme->addMeta('meta', 'keywords', $kwort); |
|
| 376 | - $xoTheme->addMeta('meta', 'description', substr(strip_tags($postsArray[$post_id]->getVar('post_text')), 0, 120)); |
|
| 362 | + $xoops_pagetitle = $postsArray[$post_id]->getVar('subject') . ' [' . $forumObject->getVar('forum_name') . ']'; |
|
| 363 | + $xoopsTpl->assign('xoops_pagetitle', $xoops_pagetitle); |
|
| 364 | + $xoopsOption['xoops_pagetitle'] = $xoops_pagetitle; |
|
| 365 | + $kw = array_unique(explode(' ', strip_tags($postsArray[$post_id]->getVar('post_text')), 150)); |
|
| 366 | + asort($kw); |
|
| 367 | + $kwort = ''; |
|
| 368 | + $z = 0; |
|
| 369 | + foreach ($kw as $k) { |
|
| 370 | + if ($z < 30 && strlen(trim($k)) > 5) { |
|
| 371 | + $kwort .= trim($k) . ' '; |
|
| 372 | + ++$z; |
|
| 373 | + } |
|
| 374 | + } |
|
| 375 | + $xoTheme->addMeta('meta', 'keywords', $kwort); |
|
| 376 | + $xoTheme->addMeta('meta', 'description', substr(strip_tags($postsArray[$post_id]->getVar('post_text')), 0, 120)); |
|
| 377 | 377 | } |
| 378 | 378 | unset($postsArray); |
| 379 | 379 | |
@@ -395,67 +395,67 @@ discard block |
||
| 395 | 395 | // START irmtfan add restore to viewtopic |
| 396 | 396 | // if the topic is active |
| 397 | 397 | if ($topicObject->getVar('approved') > 0) { |
| 398 | - $admin_actions['merge'] = [ |
|
| 399 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=merge&topic_id=' . $topic_id, |
|
| 400 | - 'name' => _MD_NEWBB_MERGETOPIC, |
|
| 401 | - 'image' => $ad_merge |
|
| 402 | - ]; |
|
| 403 | - $admin_actions['move'] = [ |
|
| 404 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=move&topic_id=' . $topic_id, |
|
| 405 | - 'name' => _MD_NEWBB_MOVETOPIC, |
|
| 406 | - 'image' => $ad_move |
|
| 407 | - ]; |
|
| 408 | - $admin_actions['delete'] = [ |
|
| 409 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=delete&topic_id=' . $topic_id, |
|
| 410 | - 'name' => _MD_NEWBB_DELETETOPIC, |
|
| 411 | - 'image' => $ad_delete |
|
| 412 | - ]; |
|
| 413 | - if (!$topicObject->getVar('topic_status')) { |
|
| 414 | - $admin_actions['lock'] = [ |
|
| 415 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=lock&topic_id=' . $topic_id, |
|
| 416 | - 'image' => $ad_lock, |
|
| 417 | - 'name' => _MD_NEWBB_LOCKTOPIC |
|
| 418 | - ]; |
|
| 419 | - } else { |
|
| 420 | - $admin_actions['unlock'] = [ |
|
| 421 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=unlock&topic_id=' . $topic_id, |
|
| 422 | - 'image' => $ad_unlock, |
|
| 423 | - 'name' => _MD_NEWBB_UNLOCKTOPIC |
|
| 424 | - ]; |
|
| 425 | - } |
|
| 426 | - if (!$topicObject->getVar('topic_sticky')) { |
|
| 427 | - $admin_actions['sticky'] = [ |
|
| 428 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=sticky&topic_id=' . $topic_id, |
|
| 429 | - 'image' => $ad_sticky, |
|
| 430 | - 'name' => _MD_NEWBB_STICKYTOPIC |
|
| 431 | - ]; |
|
| 432 | - } else { |
|
| 433 | - $admin_actions['unsticky'] = [ |
|
| 434 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=unsticky&topic_id=' . $topic_id, |
|
| 435 | - 'image' => $ad_unsticky, |
|
| 436 | - 'name' => _MD_NEWBB_UNSTICKYTOPIC |
|
| 437 | - ]; |
|
| 438 | - } |
|
| 439 | - if (!$topicObject->getVar('topic_digest')) { |
|
| 440 | - $admin_actions['digest'] = [ |
|
| 441 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=digest&topic_id=' . $topic_id, |
|
| 442 | - 'image' => $ad_digest, |
|
| 443 | - 'name' => _MD_NEWBB_DIGESTTOPIC |
|
| 444 | - ]; |
|
| 445 | - } else { |
|
| 446 | - $admin_actions['undigest'] = [ |
|
| 447 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=undigest&topic_id=' . $topic_id, |
|
| 448 | - 'image' => $ad_undigest, |
|
| 449 | - 'name' => _MD_NEWBB_UNDIGESTTOPIC |
|
| 450 | - ]; |
|
| 451 | - } |
|
| 452 | - // if the topic is pending/deleted then restore/approve |
|
| 398 | + $admin_actions['merge'] = [ |
|
| 399 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=merge&topic_id=' . $topic_id, |
|
| 400 | + 'name' => _MD_NEWBB_MERGETOPIC, |
|
| 401 | + 'image' => $ad_merge |
|
| 402 | + ]; |
|
| 403 | + $admin_actions['move'] = [ |
|
| 404 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=move&topic_id=' . $topic_id, |
|
| 405 | + 'name' => _MD_NEWBB_MOVETOPIC, |
|
| 406 | + 'image' => $ad_move |
|
| 407 | + ]; |
|
| 408 | + $admin_actions['delete'] = [ |
|
| 409 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=delete&topic_id=' . $topic_id, |
|
| 410 | + 'name' => _MD_NEWBB_DELETETOPIC, |
|
| 411 | + 'image' => $ad_delete |
|
| 412 | + ]; |
|
| 413 | + if (!$topicObject->getVar('topic_status')) { |
|
| 414 | + $admin_actions['lock'] = [ |
|
| 415 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=lock&topic_id=' . $topic_id, |
|
| 416 | + 'image' => $ad_lock, |
|
| 417 | + 'name' => _MD_NEWBB_LOCKTOPIC |
|
| 418 | + ]; |
|
| 419 | + } else { |
|
| 420 | + $admin_actions['unlock'] = [ |
|
| 421 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=unlock&topic_id=' . $topic_id, |
|
| 422 | + 'image' => $ad_unlock, |
|
| 423 | + 'name' => _MD_NEWBB_UNLOCKTOPIC |
|
| 424 | + ]; |
|
| 425 | + } |
|
| 426 | + if (!$topicObject->getVar('topic_sticky')) { |
|
| 427 | + $admin_actions['sticky'] = [ |
|
| 428 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=sticky&topic_id=' . $topic_id, |
|
| 429 | + 'image' => $ad_sticky, |
|
| 430 | + 'name' => _MD_NEWBB_STICKYTOPIC |
|
| 431 | + ]; |
|
| 432 | + } else { |
|
| 433 | + $admin_actions['unsticky'] = [ |
|
| 434 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=unsticky&topic_id=' . $topic_id, |
|
| 435 | + 'image' => $ad_unsticky, |
|
| 436 | + 'name' => _MD_NEWBB_UNSTICKYTOPIC |
|
| 437 | + ]; |
|
| 438 | + } |
|
| 439 | + if (!$topicObject->getVar('topic_digest')) { |
|
| 440 | + $admin_actions['digest'] = [ |
|
| 441 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=digest&topic_id=' . $topic_id, |
|
| 442 | + 'image' => $ad_digest, |
|
| 443 | + 'name' => _MD_NEWBB_DIGESTTOPIC |
|
| 444 | + ]; |
|
| 445 | + } else { |
|
| 446 | + $admin_actions['undigest'] = [ |
|
| 447 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=undigest&topic_id=' . $topic_id, |
|
| 448 | + 'image' => $ad_undigest, |
|
| 449 | + 'name' => _MD_NEWBB_UNDIGESTTOPIC |
|
| 450 | + ]; |
|
| 451 | + } |
|
| 452 | + // if the topic is pending/deleted then restore/approve |
|
| 453 | 453 | } else { |
| 454 | - $admin_actions['restore'] = [ |
|
| 455 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=restore&topic_id=' . $topic_id, |
|
| 456 | - 'name' => _MD_NEWBB_RESTORETOPIC, |
|
| 457 | - 'image' => $ad_restore |
|
| 458 | - ]; |
|
| 454 | + $admin_actions['restore'] = [ |
|
| 455 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/topicmanager.php?mode=restore&topic_id=' . $topic_id, |
|
| 456 | + 'name' => _MD_NEWBB_RESTORETOPIC, |
|
| 457 | + 'image' => $ad_restore |
|
| 458 | + ]; |
|
| 459 | 459 | } |
| 460 | 460 | // END irmtfan add restore to viewtopic |
| 461 | 461 | |
@@ -463,10 +463,10 @@ discard block |
||
| 463 | 463 | $xoopsTpl->assign('viewer_level', (int)($isAdmin ? 2 : is_object($GLOBALS['xoopsUser']))); |
| 464 | 464 | |
| 465 | 465 | if ($GLOBALS['xoopsModuleConfig']['show_permissiontable']) { |
| 466 | - // /** var Newbb\PermissionHandler $permHandler */ |
|
| 467 | - // $permHandler = Newbb\Helper::getInstance()->getHandler('Permission'); |
|
| 468 | - $permission_table = $permHandler->getPermissionTable($forumObject, $topicObject->getVar('topic_status'), $isAdmin); |
|
| 469 | - $xoopsTpl->assign_by_ref('permission_table', $permission_table); |
|
| 466 | + // /** var Newbb\PermissionHandler $permHandler */ |
|
| 467 | + // $permHandler = Newbb\Helper::getInstance()->getHandler('Permission'); |
|
| 468 | + $permission_table = $permHandler->getPermissionTable($forumObject, $topicObject->getVar('topic_status'), $isAdmin); |
|
| 469 | + $xoopsTpl->assign_by_ref('permission_table', $permission_table); |
|
| 470 | 470 | } |
| 471 | 471 | |
| 472 | 472 | /////////////////////////////// |
@@ -489,167 +489,167 @@ discard block |
||
| 489 | 489 | //irmtfan remove |
| 490 | 490 | $pollModuleHandler = $moduleHandler->getByDirname($GLOBALS['xoopsModuleConfig']['poll_module']); |
| 491 | 491 | if (is_object($pollModuleHandler) && $pollModuleHandler->getVar('isactive')) { |
| 492 | - $poll_id = $topicObject->getVar('poll_id'); |
|
| 493 | - // can vote in poll |
|
| 494 | - $pollVote = ($topicObject->getVar('topic_haspoll') && $poll_id > 0 |
|
| 495 | - && $topicHandler->getPermission($forumObject, $topicObject->getVar('topic_status'), 'vote')); |
|
| 496 | - // can add poll |
|
| 497 | - $pollAdd = $topicHandler->getPermission($forumObject, $topicObject->getVar('topic_status'), 'addpoll'); |
|
| 498 | - if ($pollVote || $pollAdd) { |
|
| 499 | - $pollModuleHandler = $moduleHandler->getByDirname($GLOBALS['xoopsModuleConfig']['poll_module']); |
|
| 500 | - // new xoopspoll module |
|
| 501 | - if ($pollModuleHandler->getVar('version') >= 140) { |
|
| 492 | + $poll_id = $topicObject->getVar('poll_id'); |
|
| 493 | + // can vote in poll |
|
| 494 | + $pollVote = ($topicObject->getVar('topic_haspoll') && $poll_id > 0 |
|
| 495 | + && $topicHandler->getPermission($forumObject, $topicObject->getVar('topic_status'), 'vote')); |
|
| 496 | + // can add poll |
|
| 497 | + $pollAdd = $topicHandler->getPermission($forumObject, $topicObject->getVar('topic_status'), 'addpoll'); |
|
| 498 | + if ($pollVote || $pollAdd) { |
|
| 499 | + $pollModuleHandler = $moduleHandler->getByDirname($GLOBALS['xoopsModuleConfig']['poll_module']); |
|
| 500 | + // new xoopspoll module |
|
| 501 | + if ($pollModuleHandler->getVar('version') >= 140) { |
|
| 502 | 502 | // xoops_load('renderer', $GLOBALS['xoopsModuleConfig']['poll_module']); |
| 503 | - xoops_loadLanguage('main', $GLOBALS['xoopsModuleConfig']['poll_module']); |
|
| 504 | - // old xoopspoll or umfrage or any clone from them |
|
| 505 | - } else { |
|
| 506 | - $classPoll = $topicObject->loadOldPoll(); |
|
| 507 | - } |
|
| 508 | - } |
|
| 509 | - // START can vote in poll |
|
| 510 | - if ($pollVote) { |
|
| 511 | - $xoopsTpl->assign('topic_poll', 1); |
|
| 512 | - $uid = is_object($GLOBALS['xoopsUser']) ? $GLOBALS['xoopsUser']->getVar('uid') : 0; |
|
| 513 | - // new xoopspoll module |
|
| 514 | - if ($pollModuleHandler->getVar('version') >= 140) { |
|
| 515 | - $xpollHandler = \XoopsModules\Xoopspoll\Helper::getInstance()->getHandler('Poll'); |
|
| 516 | - /** @var \XoopsPoll $pollObject */ |
|
| 517 | - $pollObject = $xpollHandler->get($poll_id); |
|
| 518 | - if (is_object($pollObject)) { |
|
| 519 | - |
|
| 520 | - /* check to see if user has rights to view the results */ |
|
| 521 | - $vis_return = $pollObject->isResultVisible(); |
|
| 522 | - $isVisible = $vis_return; |
|
| 523 | - $visibleMsg = $isVisible ? '' : $vis_return; |
|
| 524 | - |
|
| 525 | - /* setup the module config handler */ |
|
| 526 | - /** @var \XoopsConfigHandler $configHandler */ |
|
| 527 | - $configHandler = xoops_getHandler('config'); |
|
| 528 | - $xp_config = $configHandler->getConfigsByCat(0, $pollModuleHandler->getVar('mid')); |
|
| 529 | - |
|
| 530 | - $GLOBALS['xoopsTpl']->assign([ |
|
| 531 | - 'is_visible' => $isVisible, |
|
| 532 | - 'visible_message' => $visibleMsg, |
|
| 533 | - 'disp_votes' => $xp_config['disp_vote_nums'], |
|
| 534 | - 'lang_vote' => constant('_MD_' . strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . '_VOTE'), |
|
| 535 | - 'lang_results' => constant('_MD_' . strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . '_RESULTS'), |
|
| 536 | - 'back_link' => '' |
|
| 537 | - ]); |
|
| 538 | - $classRenderer = ucfirst($GLOBALS['xoopsModuleConfig']['poll_module']) . 'Renderer'; |
|
| 539 | - /** @var \XoopsModules\Xoopspoll\Renderer $renderer */ |
|
| 540 | - $renderer = new $classRenderer($pollObject); |
|
| 541 | - // check to see if user has voted, show form if not, otherwise get results for form |
|
| 542 | - |
|
| 543 | - /** @var \XoopsModules\Xoopspoll\LogHandler $logHandler */ |
|
| 544 | - $logHandler = \XoopsModules\Xoopspoll\Helper::getInstance()->getHandler('Log'); |
|
| 545 | - if ($pollObject->isAllowedToVote() |
|
| 546 | - && (!$logHandler->hasVoted($poll_id, xoops_getenv('REMOTE_ADDR'), $uid))) { |
|
| 547 | - $myTpl = new \XoopsTpl(); |
|
| 548 | - $renderer->assignForm($myTpl); |
|
| 549 | - $myTpl->assign('action', $GLOBALS['xoops']->url("modules/newbb/votepolls.php?topic_id={$topic_id}&poll_id={$poll_id}")); |
|
| 550 | - $topic_pollform = $myTpl->fetch($GLOBALS['xoops']->path('modules/' . $GLOBALS['xoopsModuleConfig']['poll_module'] . '/templates/' . $GLOBALS['xoopsModuleConfig']['poll_module'] . '_view.tpl')); |
|
| 551 | - $GLOBALS['xoopsTpl']->assign('topic_pollform', $topic_pollform); |
|
| 552 | - } else { |
|
| 553 | - $GLOBALS['xoopsTpl']->assign('can_vote', false); |
|
| 554 | - $xoopsTpl->assign('topic_pollresult', 1); |
|
| 555 | - $GLOBALS['xoopsTpl']->assign('topic_resultform', $renderer->renderResults()); |
|
| 556 | - } |
|
| 557 | - } |
|
| 558 | - // old xoopspoll or umfrage or any clone from them |
|
| 559 | - } else { |
|
| 560 | - $pollObject = new $classPoll($poll_id); |
|
| 561 | - $classRenderer = $classPoll . 'Renderer'; |
|
| 562 | - $renderer = new $classRenderer($pollObject); |
|
| 563 | - $xoopsTpl->assign('lang_alreadyvoted2', _PL_ALREADYVOTED2); |
|
| 564 | - $xoopsTpl->assign('has_ended', $pollObject->getVar('end_time') < time() ? 1 : 0); |
|
| 565 | - // umfrage has polltype |
|
| 566 | - $polltype = $pollObject->getVar('polltype'); |
|
| 567 | - if (!empty($polltype)) { |
|
| 568 | - $xoopsTpl->assign('polltype', $polltype); |
|
| 569 | - switch ($polltype) { |
|
| 570 | - case 1: |
|
| 571 | - $xoopsTpl->assign('polltypecomment', ''); |
|
| 572 | - break; |
|
| 573 | - case 2: |
|
| 574 | - $xoopsTpl->assign('polltypecomment', _PL_FULLBLIND); |
|
| 575 | - break; |
|
| 576 | - case 3: |
|
| 577 | - $xoopsTpl->assign('polltypecomment', _PL_HALFBLIND); |
|
| 578 | - break; |
|
| 579 | - |
|
| 580 | - } |
|
| 581 | - } |
|
| 582 | - $classLog = $classPoll . 'Log'; |
|
| 583 | - $hasvoted = 0; |
|
| 584 | - if ($GLOBALS['xoopsUser']) { |
|
| 585 | - if ($classLog::hasVoted($poll_id, Request::getString('REMOTE_ADDR', '', 'SERVER'), $uid)) { |
|
| 586 | - $hasvoted = 1; |
|
| 587 | - } |
|
| 588 | - } else { |
|
| 589 | - $hasvoted = 1; |
|
| 590 | - } |
|
| 591 | - $xoopsTpl->assign('hasVoted', $hasvoted); |
|
| 592 | - $xoopsTpl->assign('lang_vote', _PL_VOTE); |
|
| 593 | - $xoopsTpl->assign('lang_results', $pollObject->getVar('end_time') < time() ? _PL_RESULTS : _PL_STANDINGS); |
|
| 594 | - // irmtfan - if the poll is expired show the result |
|
| 595 | - if ($hasvoted || $pollObject->hasExpired()) { |
|
| 596 | - $renderer->assignResults($xoopsTpl); |
|
| 597 | - $xoopsTpl->assign('topic_pollresult', 1); |
|
| 598 | - setcookie('newbb_polls[' . $poll_id . ']', 1); |
|
| 599 | - } else { |
|
| 600 | - $renderer->assignForm($xoopsTpl); |
|
| 601 | - $xoopsTpl->assign('lang_vote', _PL_VOTE); |
|
| 602 | - $xoopsTpl->assign('lang_results', _PL_RESULTS); |
|
| 603 | - setcookie('newbb_polls[' . $poll_id . ']', 1); |
|
| 604 | - } |
|
| 605 | - } |
|
| 606 | - } |
|
| 607 | - // END can vote in poll |
|
| 608 | - // START can add poll |
|
| 609 | - if ($pollAdd) { |
|
| 610 | - if (!$topicObject->getVar('topic_haspoll')) { |
|
| 611 | - if (is_object($GLOBALS['xoopsUser']) |
|
| 612 | - && $GLOBALS['xoopsUser']->getVar('uid') == $topicObject->getVar('topic_poster')) { |
|
| 613 | - $t_poll = newbbDisplayImage('t_poll', _MD_NEWBB_ADDPOLL); |
|
| 614 | - $xoopsTpl->assign('forum_addpoll', '<a href=\'' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/polls.php?op=add&topic_id=' . $topic_id . '\'>' . $t_poll . '</a>'); |
|
| 615 | - } |
|
| 616 | - } elseif ($isAdmin |
|
| 617 | - || (is_object($pollObject) && is_object($GLOBALS['xoopsUser']) |
|
| 618 | - && $GLOBALS['xoopsUser']->getVar('uid') == $pollObject->getVar('user_id'))) { |
|
| 619 | - $poll_edit = ''; |
|
| 620 | - $poll_delete = ''; |
|
| 621 | - $poll_restart = ''; |
|
| 622 | - $poll_log = ''; |
|
| 623 | - |
|
| 624 | - $adminpoll_actions = []; |
|
| 625 | - $adminpoll_actions['editpoll'] = [ |
|
| 626 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/polls.php?op=edit&poll_id=' . $topicObject->getVar('poll_id') . '&topic_id=' . $topic_id, |
|
| 627 | - 'image' => $poll_edit, |
|
| 628 | - 'name' => _MD_NEWBB_EDITPOLL |
|
| 629 | - ]; |
|
| 630 | - $adminpoll_actions['deletepoll'] = [ |
|
| 631 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/polls.php?op=delete&poll_id=' . $topicObject->getVar('poll_id') . '&topic_id=' . $topic_id, |
|
| 632 | - 'image' => $poll_delete, |
|
| 633 | - 'name' => _MD_NEWBB_DELETEPOLL |
|
| 634 | - ]; |
|
| 635 | - $adminpoll_actions['restartpoll'] = [ |
|
| 636 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/polls.php?op=restart&poll_id=' . $topicObject->getVar('poll_id') . '&topic_id=' . $topic_id . '&forum=' . $forum_id, |
|
| 637 | - 'image' => $poll_restart, |
|
| 638 | - 'name' => _MD_NEWBB_RESTARTPOLL |
|
| 639 | - ]; |
|
| 640 | - $adminpoll_actions['logpoll'] = [ |
|
| 641 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/polls.php?op=log&poll_id=' . $topicObject->getVar('poll_id') . '&topic_id=' . $topic_id . '&forum=' . $forum_id, |
|
| 642 | - 'image' => $poll_log, |
|
| 643 | - 'name' => _MD_NEWBB_POLL_VIEWLOG |
|
| 644 | - ]; |
|
| 645 | - |
|
| 646 | - $xoopsTpl->assign_by_ref('adminpoll_actions', $adminpoll_actions); |
|
| 647 | - } |
|
| 648 | - } |
|
| 649 | - // END can add poll |
|
| 503 | + xoops_loadLanguage('main', $GLOBALS['xoopsModuleConfig']['poll_module']); |
|
| 504 | + // old xoopspoll or umfrage or any clone from them |
|
| 505 | + } else { |
|
| 506 | + $classPoll = $topicObject->loadOldPoll(); |
|
| 507 | + } |
|
| 508 | + } |
|
| 509 | + // START can vote in poll |
|
| 510 | + if ($pollVote) { |
|
| 511 | + $xoopsTpl->assign('topic_poll', 1); |
|
| 512 | + $uid = is_object($GLOBALS['xoopsUser']) ? $GLOBALS['xoopsUser']->getVar('uid') : 0; |
|
| 513 | + // new xoopspoll module |
|
| 514 | + if ($pollModuleHandler->getVar('version') >= 140) { |
|
| 515 | + $xpollHandler = \XoopsModules\Xoopspoll\Helper::getInstance()->getHandler('Poll'); |
|
| 516 | + /** @var \XoopsPoll $pollObject */ |
|
| 517 | + $pollObject = $xpollHandler->get($poll_id); |
|
| 518 | + if (is_object($pollObject)) { |
|
| 519 | + |
|
| 520 | + /* check to see if user has rights to view the results */ |
|
| 521 | + $vis_return = $pollObject->isResultVisible(); |
|
| 522 | + $isVisible = $vis_return; |
|
| 523 | + $visibleMsg = $isVisible ? '' : $vis_return; |
|
| 524 | + |
|
| 525 | + /* setup the module config handler */ |
|
| 526 | + /** @var \XoopsConfigHandler $configHandler */ |
|
| 527 | + $configHandler = xoops_getHandler('config'); |
|
| 528 | + $xp_config = $configHandler->getConfigsByCat(0, $pollModuleHandler->getVar('mid')); |
|
| 529 | + |
|
| 530 | + $GLOBALS['xoopsTpl']->assign([ |
|
| 531 | + 'is_visible' => $isVisible, |
|
| 532 | + 'visible_message' => $visibleMsg, |
|
| 533 | + 'disp_votes' => $xp_config['disp_vote_nums'], |
|
| 534 | + 'lang_vote' => constant('_MD_' . strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . '_VOTE'), |
|
| 535 | + 'lang_results' => constant('_MD_' . strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . '_RESULTS'), |
|
| 536 | + 'back_link' => '' |
|
| 537 | + ]); |
|
| 538 | + $classRenderer = ucfirst($GLOBALS['xoopsModuleConfig']['poll_module']) . 'Renderer'; |
|
| 539 | + /** @var \XoopsModules\Xoopspoll\Renderer $renderer */ |
|
| 540 | + $renderer = new $classRenderer($pollObject); |
|
| 541 | + // check to see if user has voted, show form if not, otherwise get results for form |
|
| 542 | + |
|
| 543 | + /** @var \XoopsModules\Xoopspoll\LogHandler $logHandler */ |
|
| 544 | + $logHandler = \XoopsModules\Xoopspoll\Helper::getInstance()->getHandler('Log'); |
|
| 545 | + if ($pollObject->isAllowedToVote() |
|
| 546 | + && (!$logHandler->hasVoted($poll_id, xoops_getenv('REMOTE_ADDR'), $uid))) { |
|
| 547 | + $myTpl = new \XoopsTpl(); |
|
| 548 | + $renderer->assignForm($myTpl); |
|
| 549 | + $myTpl->assign('action', $GLOBALS['xoops']->url("modules/newbb/votepolls.php?topic_id={$topic_id}&poll_id={$poll_id}")); |
|
| 550 | + $topic_pollform = $myTpl->fetch($GLOBALS['xoops']->path('modules/' . $GLOBALS['xoopsModuleConfig']['poll_module'] . '/templates/' . $GLOBALS['xoopsModuleConfig']['poll_module'] . '_view.tpl')); |
|
| 551 | + $GLOBALS['xoopsTpl']->assign('topic_pollform', $topic_pollform); |
|
| 552 | + } else { |
|
| 553 | + $GLOBALS['xoopsTpl']->assign('can_vote', false); |
|
| 554 | + $xoopsTpl->assign('topic_pollresult', 1); |
|
| 555 | + $GLOBALS['xoopsTpl']->assign('topic_resultform', $renderer->renderResults()); |
|
| 556 | + } |
|
| 557 | + } |
|
| 558 | + // old xoopspoll or umfrage or any clone from them |
|
| 559 | + } else { |
|
| 560 | + $pollObject = new $classPoll($poll_id); |
|
| 561 | + $classRenderer = $classPoll . 'Renderer'; |
|
| 562 | + $renderer = new $classRenderer($pollObject); |
|
| 563 | + $xoopsTpl->assign('lang_alreadyvoted2', _PL_ALREADYVOTED2); |
|
| 564 | + $xoopsTpl->assign('has_ended', $pollObject->getVar('end_time') < time() ? 1 : 0); |
|
| 565 | + // umfrage has polltype |
|
| 566 | + $polltype = $pollObject->getVar('polltype'); |
|
| 567 | + if (!empty($polltype)) { |
|
| 568 | + $xoopsTpl->assign('polltype', $polltype); |
|
| 569 | + switch ($polltype) { |
|
| 570 | + case 1: |
|
| 571 | + $xoopsTpl->assign('polltypecomment', ''); |
|
| 572 | + break; |
|
| 573 | + case 2: |
|
| 574 | + $xoopsTpl->assign('polltypecomment', _PL_FULLBLIND); |
|
| 575 | + break; |
|
| 576 | + case 3: |
|
| 577 | + $xoopsTpl->assign('polltypecomment', _PL_HALFBLIND); |
|
| 578 | + break; |
|
| 579 | + |
|
| 580 | + } |
|
| 581 | + } |
|
| 582 | + $classLog = $classPoll . 'Log'; |
|
| 583 | + $hasvoted = 0; |
|
| 584 | + if ($GLOBALS['xoopsUser']) { |
|
| 585 | + if ($classLog::hasVoted($poll_id, Request::getString('REMOTE_ADDR', '', 'SERVER'), $uid)) { |
|
| 586 | + $hasvoted = 1; |
|
| 587 | + } |
|
| 588 | + } else { |
|
| 589 | + $hasvoted = 1; |
|
| 590 | + } |
|
| 591 | + $xoopsTpl->assign('hasVoted', $hasvoted); |
|
| 592 | + $xoopsTpl->assign('lang_vote', _PL_VOTE); |
|
| 593 | + $xoopsTpl->assign('lang_results', $pollObject->getVar('end_time') < time() ? _PL_RESULTS : _PL_STANDINGS); |
|
| 594 | + // irmtfan - if the poll is expired show the result |
|
| 595 | + if ($hasvoted || $pollObject->hasExpired()) { |
|
| 596 | + $renderer->assignResults($xoopsTpl); |
|
| 597 | + $xoopsTpl->assign('topic_pollresult', 1); |
|
| 598 | + setcookie('newbb_polls[' . $poll_id . ']', 1); |
|
| 599 | + } else { |
|
| 600 | + $renderer->assignForm($xoopsTpl); |
|
| 601 | + $xoopsTpl->assign('lang_vote', _PL_VOTE); |
|
| 602 | + $xoopsTpl->assign('lang_results', _PL_RESULTS); |
|
| 603 | + setcookie('newbb_polls[' . $poll_id . ']', 1); |
|
| 604 | + } |
|
| 605 | + } |
|
| 606 | + } |
|
| 607 | + // END can vote in poll |
|
| 608 | + // START can add poll |
|
| 609 | + if ($pollAdd) { |
|
| 610 | + if (!$topicObject->getVar('topic_haspoll')) { |
|
| 611 | + if (is_object($GLOBALS['xoopsUser']) |
|
| 612 | + && $GLOBALS['xoopsUser']->getVar('uid') == $topicObject->getVar('topic_poster')) { |
|
| 613 | + $t_poll = newbbDisplayImage('t_poll', _MD_NEWBB_ADDPOLL); |
|
| 614 | + $xoopsTpl->assign('forum_addpoll', '<a href=\'' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/polls.php?op=add&topic_id=' . $topic_id . '\'>' . $t_poll . '</a>'); |
|
| 615 | + } |
|
| 616 | + } elseif ($isAdmin |
|
| 617 | + || (is_object($pollObject) && is_object($GLOBALS['xoopsUser']) |
|
| 618 | + && $GLOBALS['xoopsUser']->getVar('uid') == $pollObject->getVar('user_id'))) { |
|
| 619 | + $poll_edit = ''; |
|
| 620 | + $poll_delete = ''; |
|
| 621 | + $poll_restart = ''; |
|
| 622 | + $poll_log = ''; |
|
| 623 | + |
|
| 624 | + $adminpoll_actions = []; |
|
| 625 | + $adminpoll_actions['editpoll'] = [ |
|
| 626 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/polls.php?op=edit&poll_id=' . $topicObject->getVar('poll_id') . '&topic_id=' . $topic_id, |
|
| 627 | + 'image' => $poll_edit, |
|
| 628 | + 'name' => _MD_NEWBB_EDITPOLL |
|
| 629 | + ]; |
|
| 630 | + $adminpoll_actions['deletepoll'] = [ |
|
| 631 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/polls.php?op=delete&poll_id=' . $topicObject->getVar('poll_id') . '&topic_id=' . $topic_id, |
|
| 632 | + 'image' => $poll_delete, |
|
| 633 | + 'name' => _MD_NEWBB_DELETEPOLL |
|
| 634 | + ]; |
|
| 635 | + $adminpoll_actions['restartpoll'] = [ |
|
| 636 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/polls.php?op=restart&poll_id=' . $topicObject->getVar('poll_id') . '&topic_id=' . $topic_id . '&forum=' . $forum_id, |
|
| 637 | + 'image' => $poll_restart, |
|
| 638 | + 'name' => _MD_NEWBB_RESTARTPOLL |
|
| 639 | + ]; |
|
| 640 | + $adminpoll_actions['logpoll'] = [ |
|
| 641 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/polls.php?op=log&poll_id=' . $topicObject->getVar('poll_id') . '&topic_id=' . $topic_id . '&forum=' . $forum_id, |
|
| 642 | + 'image' => $poll_log, |
|
| 643 | + 'name' => _MD_NEWBB_POLL_VIEWLOG |
|
| 644 | + ]; |
|
| 645 | + |
|
| 646 | + $xoopsTpl->assign_by_ref('adminpoll_actions', $adminpoll_actions); |
|
| 647 | + } |
|
| 648 | + } |
|
| 649 | + // END can add poll |
|
| 650 | 650 | } |
| 651 | 651 | if (isset($pollObject)) { |
| 652 | - unset($pollObject); |
|
| 652 | + unset($pollObject); |
|
| 653 | 653 | } |
| 654 | 654 | // END irmtfan poll_module |
| 655 | 655 | |
@@ -664,68 +664,68 @@ discard block |
||
| 664 | 664 | $xoopsTpl->assign('post_content', newbbDisplayImage('post')); |
| 665 | 665 | |
| 666 | 666 | if (!empty($GLOBALS['xoopsModuleConfig']['rating_enabled'])) { |
| 667 | - $xoopsTpl->assign('votes', $topicObject->getVar('votes')); |
|
| 668 | - $rating = number_format($topicObject->getVar('rating') / 2, 0); |
|
| 669 | - if ($rating < 1) { |
|
| 670 | - $rating_img = newbbDisplayImage('blank'); |
|
| 671 | - } else { |
|
| 672 | - // irmtfan - add alt key for rating |
|
| 673 | - $rating_img = newbbDisplayImage('rate' . $rating, constant('_MD_NEWBB_RATE' . $rating)); |
|
| 674 | - } |
|
| 675 | - $xoopsTpl->assign('rating_img', $rating_img); |
|
| 676 | - $xoopsTpl->assign('rate1', newbbDisplayImage('rate1', _MD_NEWBB_RATE1)); |
|
| 677 | - $xoopsTpl->assign('rate2', newbbDisplayImage('rate2', _MD_NEWBB_RATE2)); |
|
| 678 | - $xoopsTpl->assign('rate3', newbbDisplayImage('rate3', _MD_NEWBB_RATE3)); |
|
| 679 | - $xoopsTpl->assign('rate4', newbbDisplayImage('rate4', _MD_NEWBB_RATE4)); |
|
| 680 | - $xoopsTpl->assign('rate5', newbbDisplayImage('rate5', _MD_NEWBB_RATE5)); |
|
| 667 | + $xoopsTpl->assign('votes', $topicObject->getVar('votes')); |
|
| 668 | + $rating = number_format($topicObject->getVar('rating') / 2, 0); |
|
| 669 | + if ($rating < 1) { |
|
| 670 | + $rating_img = newbbDisplayImage('blank'); |
|
| 671 | + } else { |
|
| 672 | + // irmtfan - add alt key for rating |
|
| 673 | + $rating_img = newbbDisplayImage('rate' . $rating, constant('_MD_NEWBB_RATE' . $rating)); |
|
| 674 | + } |
|
| 675 | + $xoopsTpl->assign('rating_img', $rating_img); |
|
| 676 | + $xoopsTpl->assign('rate1', newbbDisplayImage('rate1', _MD_NEWBB_RATE1)); |
|
| 677 | + $xoopsTpl->assign('rate2', newbbDisplayImage('rate2', _MD_NEWBB_RATE2)); |
|
| 678 | + $xoopsTpl->assign('rate3', newbbDisplayImage('rate3', _MD_NEWBB_RATE3)); |
|
| 679 | + $xoopsTpl->assign('rate4', newbbDisplayImage('rate4', _MD_NEWBB_RATE4)); |
|
| 680 | + $xoopsTpl->assign('rate5', newbbDisplayImage('rate5', _MD_NEWBB_RATE5)); |
|
| 681 | 681 | } |
| 682 | 682 | |
| 683 | 683 | // create jump box |
| 684 | 684 | if (!empty($GLOBALS['xoopsModuleConfig']['show_jump'])) { |
| 685 | - require_once __DIR__ . '/include/functions.forum.php'; |
|
| 686 | - $xoopsTpl->assign('forum_jumpbox', newbbMakeJumpbox($forum_id)); |
|
| 685 | + require_once __DIR__ . '/include/functions.forum.php'; |
|
| 686 | + $xoopsTpl->assign('forum_jumpbox', newbbMakeJumpbox($forum_id)); |
|
| 687 | 687 | } |
| 688 | 688 | |
| 689 | 689 | $xoopsTpl->assign([ |
| 690 | - 'lang_forum_index' => sprintf(_MD_NEWBB_FORUMINDEX, htmlspecialchars($GLOBALS['xoopsConfig']['sitename'], ENT_QUOTES)), |
|
| 691 | - 'lang_from' => _MD_NEWBB_FROM, |
|
| 692 | - 'lang_joined' => _MD_NEWBB_JOINED, |
|
| 693 | - 'lang_posts' => _MD_NEWBB_POSTS, |
|
| 694 | - 'lang_poster' => _MD_NEWBB_POSTER, |
|
| 695 | - 'lang_thread' => _MD_NEWBB_THREAD, |
|
| 696 | - 'lang_edit' => _EDIT, |
|
| 697 | - 'lang_delete' => _DELETE, |
|
| 698 | - 'lang_reply' => _REPLY, |
|
| 699 | - 'lang_postedon' => _MD_NEWBB_POSTEDON, |
|
| 700 | - 'lang_groups' => _MD_NEWBB_GROUPS |
|
| 701 | - ]); |
|
| 690 | + 'lang_forum_index' => sprintf(_MD_NEWBB_FORUMINDEX, htmlspecialchars($GLOBALS['xoopsConfig']['sitename'], ENT_QUOTES)), |
|
| 691 | + 'lang_from' => _MD_NEWBB_FROM, |
|
| 692 | + 'lang_joined' => _MD_NEWBB_JOINED, |
|
| 693 | + 'lang_posts' => _MD_NEWBB_POSTS, |
|
| 694 | + 'lang_poster' => _MD_NEWBB_POSTER, |
|
| 695 | + 'lang_thread' => _MD_NEWBB_THREAD, |
|
| 696 | + 'lang_edit' => _EDIT, |
|
| 697 | + 'lang_delete' => _DELETE, |
|
| 698 | + 'lang_reply' => _REPLY, |
|
| 699 | + 'lang_postedon' => _MD_NEWBB_POSTEDON, |
|
| 700 | + 'lang_groups' => _MD_NEWBB_GROUPS |
|
| 701 | + ]); |
|
| 702 | 702 | |
| 703 | 703 | $viewmode_options = []; |
| 704 | 704 | if ('DESC' === $order) { |
| 705 | - $viewmode_options[] = [ |
|
| 706 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/viewtopic.php?order=ASC&status=$status&topic_id=' . $topic_id, |
|
| 707 | - 'title' => _OLDESTFIRST |
|
| 708 | - ]; |
|
| 705 | + $viewmode_options[] = [ |
|
| 706 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/viewtopic.php?order=ASC&status=$status&topic_id=' . $topic_id, |
|
| 707 | + 'title' => _OLDESTFIRST |
|
| 708 | + ]; |
|
| 709 | 709 | } else { |
| 710 | - $viewmode_options[] = [ |
|
| 711 | - 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/viewtopic.php?order=DESC&status=$status&topic_id=' . $topic_id, |
|
| 712 | - 'title' => _NEWESTFIRST |
|
| 713 | - ]; |
|
| 710 | + $viewmode_options[] = [ |
|
| 711 | + 'link' => XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/viewtopic.php?order=DESC&status=$status&topic_id=' . $topic_id, |
|
| 712 | + 'title' => _NEWESTFIRST |
|
| 713 | + ]; |
|
| 714 | 714 | } |
| 715 | 715 | |
| 716 | 716 | switch ($status) { |
| 717 | - case 'active': |
|
| 718 | - $current_status = '[' . _MD_NEWBB_TYPE_ADMIN . ']'; |
|
| 719 | - break; |
|
| 720 | - case 'pending': |
|
| 721 | - $current_status = '[' . _MD_NEWBB_TYPE_PENDING . ']'; |
|
| 722 | - break; |
|
| 723 | - case 'deleted': |
|
| 724 | - $current_status = '[' . _MD_NEWBB_TYPE_DELETED . ']'; |
|
| 725 | - break; |
|
| 726 | - default: |
|
| 727 | - $current_status = ''; |
|
| 728 | - break; |
|
| 717 | + case 'active': |
|
| 718 | + $current_status = '[' . _MD_NEWBB_TYPE_ADMIN . ']'; |
|
| 719 | + break; |
|
| 720 | + case 'pending': |
|
| 721 | + $current_status = '[' . _MD_NEWBB_TYPE_PENDING . ']'; |
|
| 722 | + break; |
|
| 723 | + case 'deleted': |
|
| 724 | + $current_status = '[' . _MD_NEWBB_TYPE_DELETED . ']'; |
|
| 725 | + break; |
|
| 726 | + default: |
|
| 727 | + $current_status = ''; |
|
| 728 | + break; |
|
| 729 | 729 | } |
| 730 | 730 | $xoopsTpl->assign('topicstatus', $current_status); |
| 731 | 731 | |
@@ -741,91 +741,91 @@ discard block |
||
| 741 | 741 | //check banning |
| 742 | 742 | //$moderateHandler = Newbb\Helper::getInstance()->getHandler('Moderate'); |
| 743 | 743 | if (!empty($GLOBALS['xoopsModuleConfig']['quickreply_enabled']) |
| 744 | - && $topicHandler->getPermission($forumObject, $topicObject->getVar('topic_status'), 'reply') |
|
| 745 | - && $moderateHandler->verifyUser(-1, '', $forumObject->getVar('forum_id'))) { |
|
| 746 | - // END irmtfan add verifyUser to quick reply |
|
| 747 | - $forum_form = new \XoopsThemeForm(_MD_NEWBB_POSTREPLY, 'quick_reply', XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/post.php', 'post', true); |
|
| 748 | - if (!is_object($GLOBALS['xoopsUser'])) { |
|
| 749 | - //$configHandler = xoops_getHandler('config'); |
|
| 750 | - $user_tray = new \XoopsFormElementTray(_MD_NEWBB_ACCOUNT); |
|
| 751 | - $user_tray->addElement(new \XoopsFormText(_MD_NEWBB_NAME, 'uname', 26, 255)); |
|
| 752 | - $user_tray->addElement(new \XoopsFormPassword(_MD_NEWBB_PASSWORD, 'pass', 10, 32)); |
|
| 753 | - $login_checkbox = new \XoopsFormCheckBox('', 'login', 1); |
|
| 754 | - $login_checkbox->addOption(1, _MD_NEWBB_LOGIN); |
|
| 755 | - $user_tray->addElement($login_checkbox); |
|
| 756 | - $forum_form->addElement($user_tray); |
|
| 757 | - $captcha = new \XoopsFormCaptcha('', "topic_{$topic_id}_{$start}"); |
|
| 758 | - $captcha->setConfig('mode', 'text'); |
|
| 759 | - $forum_form->addElement($captcha); |
|
| 760 | - } |
|
| 761 | - |
|
| 762 | - //$quickform = ( !empty($GLOBALS['xoopsModuleConfig']["editor_default"]) ) ? $GLOBALS['xoopsModuleConfig']["editor_default"] : "textarea"; |
|
| 763 | - $quickform = !empty($GLOBALS['xoopsModuleConfig']['editor_quick_default']) ? $GLOBALS['xoopsModuleConfig']['editor_quick_default'] : 'textarea'; |
|
| 764 | - $editor_configs = []; |
|
| 765 | - $editor_configs ['name'] = 'message'; |
|
| 766 | - //$editor_configs [ "value" ] = $message ; |
|
| 767 | - $editor_configs ['rows'] = empty($GLOBALS['xoopsModuleConfig'] ['editor_rows']) ? 10 : $GLOBALS['xoopsModuleConfig'] ['editor_rows']; |
|
| 768 | - $editor_configs ['cols'] = empty($GLOBALS['xoopsModuleConfig'] ['editor_cols']) ? 30 : $GLOBALS['xoopsModuleConfig'] ['editor_cols']; |
|
| 769 | - $editor_configs ['width'] = empty($GLOBALS['xoopsModuleConfig'] ['editor_width']) ? '100%' : $GLOBALS['xoopsModuleConfig'] ['editor_width']; |
|
| 770 | - $editor_configs ['height'] = empty($GLOBALS['xoopsModuleConfig'] ['editor_height']) ? '400px' : $GLOBALS['xoopsModuleConfig'] ['editor_height']; |
|
| 771 | - $_editor = new \XoopsFormEditor(_MD_NEWBB_MESSAGEC, $quickform, $editor_configs, true); |
|
| 772 | - $forum_form->addElement($_editor, true); |
|
| 773 | - |
|
| 774 | - $forum_form->addElement(new \XoopsFormHidden('dohtml', 0)); |
|
| 775 | - $forum_form->addElement(new \XoopsFormHidden('dosmiley', 1)); |
|
| 776 | - $forum_form->addElement(new \XoopsFormHidden('doxcode', 1)); |
|
| 777 | - $forum_form->addElement(new \XoopsFormHidden('dobr', 1)); |
|
| 778 | - $forum_form->addElement(new \XoopsFormHidden('attachsig', 1)); |
|
| 779 | - |
|
| 780 | - $forum_form->addElement(new \XoopsFormHidden('isreply', 1)); |
|
| 781 | - |
|
| 782 | - $forum_form->addElement(new \XoopsFormHidden('subject', _MD_NEWBB_RE . ': ' . $topicObject->getVar('topic_title', 'e'))); |
|
| 783 | - $forum_form->addElement(new \XoopsFormHidden('pid', empty($post_id) ? $topicHandler->getTopPostId($topic_id) : $post_id)); |
|
| 784 | - $forum_form->addElement(new \XoopsFormHidden('topic_id', $topic_id)); |
|
| 785 | - $forum_form->addElement(new \XoopsFormHidden('forum', $forum_id)); |
|
| 786 | - //$forum_form->addElement(new \XoopsFormHidden('viewmode', $viewmode)); |
|
| 787 | - $forum_form->addElement(new \XoopsFormHidden('order', $order)); |
|
| 788 | - $forum_form->addElement(new \XoopsFormHidden('start', $start)); |
|
| 789 | - |
|
| 790 | - $forum_form->addElement(new \XoopsFormHidden('notify', -1)); |
|
| 791 | - $forum_form->addElement(new \XoopsFormHidden('contents_submit', 1)); |
|
| 792 | - |
|
| 793 | - $submit_button = new \XoopsFormButton('', 'quick_submit', _SUBMIT, 'submit'); |
|
| 794 | - $submit_button->setExtra('onclick="if (document.forms.quick_reply.message.value === \'RE\' || document.forms.quick_reply.message.value === \'\') { alert(\'' . _MD_NEWBB_QUICKREPLY_EMPTY . '\'); return false;} else { return true;}"'); |
|
| 795 | - $forum_form->addElement($submit_button); |
|
| 796 | - |
|
| 797 | - $toggles = newbbGetCookie('G', true); |
|
| 798 | - // START irmtfan improve quickreply smarty variable - add alt key to quick reply button - change $display to $style for more comprehension - add toggle $quickreply['expand'] |
|
| 799 | - $quickreply = []; |
|
| 800 | - $qr_collapse = 't_qr'; |
|
| 801 | - $qr_expand = 't_qr_expand'; // change this |
|
| 802 | - $quickreply['icon'] = [ |
|
| 803 | - 'expand' => $iconHandler->getImageSource($qr_expand), |
|
| 804 | - 'collapse' => $iconHandler->getImageSource($qr_collapse) |
|
| 805 | - ]; |
|
| 806 | - $quickreply['show'] = 1; // = !empty($GLOBALS['xoopsModuleConfig']['quickreply_enabled'] |
|
| 807 | - $quickreply['expand'] = (count($toggles) > 0) ? (in_array('qr', $toggles, true) ? false : true) : true; |
|
| 808 | - if ($quickreply['expand']) { |
|
| 809 | - $quickreply['style'] = 'block'; //irmtfan move semicolon |
|
| 810 | - $quickreply_icon_display = $qr_expand; |
|
| 811 | - $quickreply_alt = _MD_NEWBB_HIDE . ' ' . _MD_NEWBB_QUICKREPLY; |
|
| 812 | - } else { |
|
| 813 | - $quickreply['style'] = 'none'; //irmtfan move semicolon |
|
| 814 | - $quickreply_icon_display = $qr_collapse; |
|
| 815 | - $quickreply_alt = _MD_NEWBB_SEE . ' ' . _MD_NEWBB_QUICKREPLY; |
|
| 816 | - } |
|
| 817 | - $quickreply['displayImage'] = newbbDisplayImage($quickreply_icon_display, $quickreply_alt); |
|
| 818 | - $quickreply['form'] = $forum_form->render(); |
|
| 819 | - $xoopsTpl->assign('quickreply', $quickreply); |
|
| 820 | - // END irmtfan improve quickreply smarty variable |
|
| 821 | - unset($forum_form); |
|
| 744 | + && $topicHandler->getPermission($forumObject, $topicObject->getVar('topic_status'), 'reply') |
|
| 745 | + && $moderateHandler->verifyUser(-1, '', $forumObject->getVar('forum_id'))) { |
|
| 746 | + // END irmtfan add verifyUser to quick reply |
|
| 747 | + $forum_form = new \XoopsThemeForm(_MD_NEWBB_POSTREPLY, 'quick_reply', XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname', 'n') . '/post.php', 'post', true); |
|
| 748 | + if (!is_object($GLOBALS['xoopsUser'])) { |
|
| 749 | + //$configHandler = xoops_getHandler('config'); |
|
| 750 | + $user_tray = new \XoopsFormElementTray(_MD_NEWBB_ACCOUNT); |
|
| 751 | + $user_tray->addElement(new \XoopsFormText(_MD_NEWBB_NAME, 'uname', 26, 255)); |
|
| 752 | + $user_tray->addElement(new \XoopsFormPassword(_MD_NEWBB_PASSWORD, 'pass', 10, 32)); |
|
| 753 | + $login_checkbox = new \XoopsFormCheckBox('', 'login', 1); |
|
| 754 | + $login_checkbox->addOption(1, _MD_NEWBB_LOGIN); |
|
| 755 | + $user_tray->addElement($login_checkbox); |
|
| 756 | + $forum_form->addElement($user_tray); |
|
| 757 | + $captcha = new \XoopsFormCaptcha('', "topic_{$topic_id}_{$start}"); |
|
| 758 | + $captcha->setConfig('mode', 'text'); |
|
| 759 | + $forum_form->addElement($captcha); |
|
| 760 | + } |
|
| 761 | + |
|
| 762 | + //$quickform = ( !empty($GLOBALS['xoopsModuleConfig']["editor_default"]) ) ? $GLOBALS['xoopsModuleConfig']["editor_default"] : "textarea"; |
|
| 763 | + $quickform = !empty($GLOBALS['xoopsModuleConfig']['editor_quick_default']) ? $GLOBALS['xoopsModuleConfig']['editor_quick_default'] : 'textarea'; |
|
| 764 | + $editor_configs = []; |
|
| 765 | + $editor_configs ['name'] = 'message'; |
|
| 766 | + //$editor_configs [ "value" ] = $message ; |
|
| 767 | + $editor_configs ['rows'] = empty($GLOBALS['xoopsModuleConfig'] ['editor_rows']) ? 10 : $GLOBALS['xoopsModuleConfig'] ['editor_rows']; |
|
| 768 | + $editor_configs ['cols'] = empty($GLOBALS['xoopsModuleConfig'] ['editor_cols']) ? 30 : $GLOBALS['xoopsModuleConfig'] ['editor_cols']; |
|
| 769 | + $editor_configs ['width'] = empty($GLOBALS['xoopsModuleConfig'] ['editor_width']) ? '100%' : $GLOBALS['xoopsModuleConfig'] ['editor_width']; |
|
| 770 | + $editor_configs ['height'] = empty($GLOBALS['xoopsModuleConfig'] ['editor_height']) ? '400px' : $GLOBALS['xoopsModuleConfig'] ['editor_height']; |
|
| 771 | + $_editor = new \XoopsFormEditor(_MD_NEWBB_MESSAGEC, $quickform, $editor_configs, true); |
|
| 772 | + $forum_form->addElement($_editor, true); |
|
| 773 | + |
|
| 774 | + $forum_form->addElement(new \XoopsFormHidden('dohtml', 0)); |
|
| 775 | + $forum_form->addElement(new \XoopsFormHidden('dosmiley', 1)); |
|
| 776 | + $forum_form->addElement(new \XoopsFormHidden('doxcode', 1)); |
|
| 777 | + $forum_form->addElement(new \XoopsFormHidden('dobr', 1)); |
|
| 778 | + $forum_form->addElement(new \XoopsFormHidden('attachsig', 1)); |
|
| 779 | + |
|
| 780 | + $forum_form->addElement(new \XoopsFormHidden('isreply', 1)); |
|
| 781 | + |
|
| 782 | + $forum_form->addElement(new \XoopsFormHidden('subject', _MD_NEWBB_RE . ': ' . $topicObject->getVar('topic_title', 'e'))); |
|
| 783 | + $forum_form->addElement(new \XoopsFormHidden('pid', empty($post_id) ? $topicHandler->getTopPostId($topic_id) : $post_id)); |
|
| 784 | + $forum_form->addElement(new \XoopsFormHidden('topic_id', $topic_id)); |
|
| 785 | + $forum_form->addElement(new \XoopsFormHidden('forum', $forum_id)); |
|
| 786 | + //$forum_form->addElement(new \XoopsFormHidden('viewmode', $viewmode)); |
|
| 787 | + $forum_form->addElement(new \XoopsFormHidden('order', $order)); |
|
| 788 | + $forum_form->addElement(new \XoopsFormHidden('start', $start)); |
|
| 789 | + |
|
| 790 | + $forum_form->addElement(new \XoopsFormHidden('notify', -1)); |
|
| 791 | + $forum_form->addElement(new \XoopsFormHidden('contents_submit', 1)); |
|
| 792 | + |
|
| 793 | + $submit_button = new \XoopsFormButton('', 'quick_submit', _SUBMIT, 'submit'); |
|
| 794 | + $submit_button->setExtra('onclick="if (document.forms.quick_reply.message.value === \'RE\' || document.forms.quick_reply.message.value === \'\') { alert(\'' . _MD_NEWBB_QUICKREPLY_EMPTY . '\'); return false;} else { return true;}"'); |
|
| 795 | + $forum_form->addElement($submit_button); |
|
| 796 | + |
|
| 797 | + $toggles = newbbGetCookie('G', true); |
|
| 798 | + // START irmtfan improve quickreply smarty variable - add alt key to quick reply button - change $display to $style for more comprehension - add toggle $quickreply['expand'] |
|
| 799 | + $quickreply = []; |
|
| 800 | + $qr_collapse = 't_qr'; |
|
| 801 | + $qr_expand = 't_qr_expand'; // change this |
|
| 802 | + $quickreply['icon'] = [ |
|
| 803 | + 'expand' => $iconHandler->getImageSource($qr_expand), |
|
| 804 | + 'collapse' => $iconHandler->getImageSource($qr_collapse) |
|
| 805 | + ]; |
|
| 806 | + $quickreply['show'] = 1; // = !empty($GLOBALS['xoopsModuleConfig']['quickreply_enabled'] |
|
| 807 | + $quickreply['expand'] = (count($toggles) > 0) ? (in_array('qr', $toggles, true) ? false : true) : true; |
|
| 808 | + if ($quickreply['expand']) { |
|
| 809 | + $quickreply['style'] = 'block'; //irmtfan move semicolon |
|
| 810 | + $quickreply_icon_display = $qr_expand; |
|
| 811 | + $quickreply_alt = _MD_NEWBB_HIDE . ' ' . _MD_NEWBB_QUICKREPLY; |
|
| 812 | + } else { |
|
| 813 | + $quickreply['style'] = 'none'; //irmtfan move semicolon |
|
| 814 | + $quickreply_icon_display = $qr_collapse; |
|
| 815 | + $quickreply_alt = _MD_NEWBB_SEE . ' ' . _MD_NEWBB_QUICKREPLY; |
|
| 816 | + } |
|
| 817 | + $quickreply['displayImage'] = newbbDisplayImage($quickreply_icon_display, $quickreply_alt); |
|
| 818 | + $quickreply['form'] = $forum_form->render(); |
|
| 819 | + $xoopsTpl->assign('quickreply', $quickreply); |
|
| 820 | + // END irmtfan improve quickreply smarty variable |
|
| 821 | + unset($forum_form); |
|
| 822 | 822 | } else { |
| 823 | - $xoopsTpl->assign('quickreply', ['show' => 0]); |
|
| 823 | + $xoopsTpl->assign('quickreply', ['show' => 0]); |
|
| 824 | 824 | } |
| 825 | 825 | |
| 826 | 826 | if ($GLOBALS['xoopsModuleConfig']['do_tag'] |
| 827 | - && @require_once $GLOBALS['xoops']->path('modules/tag/include/tagbar.php')) { |
|
| 828 | - $xoopsTpl->assign('tagbar', tagBar($topicObject->getVar('topic_tags', 'n'))); |
|
| 827 | + && @require_once $GLOBALS['xoops']->path('modules/tag/include/tagbar.php')) { |
|
| 828 | + $xoopsTpl->assign('tagbar', tagBar($topicObject->getVar('topic_tags', 'n'))); |
|
| 829 | 829 | } |
| 830 | 830 | // irmtfan move to footer.php |
| 831 | 831 | require_once __DIR__ . '/footer.php'; |
@@ -32,19 +32,19 @@ discard block |
||
| 32 | 32 | */ |
| 33 | 33 | $op = Request::getCmd('op', ''); |
| 34 | 34 | $validOps = [ |
| 35 | - 'save_type', |
|
| 36 | - 'delete', |
|
| 37 | - 'template', |
|
| 38 | - 'save_template', |
|
| 39 | - 'apply', |
|
| 40 | - 'save_apply', |
|
| 41 | - 'forum', |
|
| 42 | - 'edit_forum', |
|
| 43 | - 'save_forum', |
|
| 44 | - 'add' |
|
| 35 | + 'save_type', |
|
| 36 | + 'delete', |
|
| 37 | + 'template', |
|
| 38 | + 'save_template', |
|
| 39 | + 'apply', |
|
| 40 | + 'save_apply', |
|
| 41 | + 'forum', |
|
| 42 | + 'edit_forum', |
|
| 43 | + 'save_forum', |
|
| 44 | + 'add' |
|
| 45 | 45 | ]; |
| 46 | 46 | if (!in_array($op, $validOps, true)) { |
| 47 | - $op = ''; |
|
| 47 | + $op = ''; |
|
| 48 | 48 | } |
| 49 | 49 | |
| 50 | 50 | ///** @var Newbb\TypeHandler $typeHandler */ |
@@ -52,386 +52,386 @@ discard block |
||
| 52 | 52 | $cacheHelper = new \Xmf\Module\Helper\Cache('newbb'); |
| 53 | 53 | |
| 54 | 54 | switch ($op) { |
| 55 | - case 'save_type': |
|
| 56 | - $type_names0 = $_POST['type_name']; |
|
| 57 | - $type_names = Request::getArray('type_name', null, 'POST'); |
|
| 58 | - $type_del = []; |
|
| 59 | - foreach (array_keys($type_names) as $key) { |
|
| 60 | - if (Request::getBool('isnew', '', 'POST')) { |
|
| 61 | - $typeObject = $typeHandler->create(); |
|
| 62 | - } elseif (!$typeObject = $typeHandler->get($key)) { |
|
| 63 | - continue; |
|
| 64 | - } |
|
| 65 | - |
|
| 66 | - // if (Request::getArray("type_del[$key]", '', 'POST')) { |
|
| 67 | - $temp = Request::getArray('type_del', '', 'POST'); |
|
| 68 | - if ($temp[$key]) { |
|
| 69 | - $type_del[] = $key; |
|
| 70 | - continue; |
|
| 71 | - } else { |
|
| 72 | - foreach (['type_name', 'type_color', 'type_description'] as $var) { |
|
| 73 | - // if ($typeObject->getVar($var) != @$_POST[$var][$key]) { |
|
| 74 | - // $typeObject->setVar($var, @$_POST[$var][$key]); |
|
| 75 | - // } |
|
| 76 | - $temp = Request::getArray($var, '', 'POST'); |
|
| 77 | - if ($typeObject->getVar($var) != $temp[$key]) { |
|
| 78 | - $typeObject->setVar($var, $temp[$key]); |
|
| 79 | - } |
|
| 80 | - |
|
| 81 | - // $typeObject->setVar($var, Request::getArray($var, '', 'POST')[$key]); |
|
| 82 | - } |
|
| 83 | - $typeHandler->insert($typeObject); |
|
| 84 | - unset($typeObject); |
|
| 85 | - } |
|
| 86 | - } |
|
| 87 | - if (count($type_del) > 0) { |
|
| 88 | - $type_list = $typeHandler->getList(new \Criteria('type_id', '(' . implode(', ', $type_del) . ')', 'IN')); |
|
| 89 | - xoops_confirm(['op' => 'delete', 'type_del' => serialize($type_del)], xoops_getenv('PHP_SELF'), sprintf(_AM_NEWBB_TODEL_TYPE, implode(', ', array_values($type_list))), '', false); |
|
| 90 | - } else { |
|
| 91 | - redirect_header(xoops_getenv('PHP_SELF'), 2, _MD_NEWBB_DBUPDATED); |
|
| 92 | - } |
|
| 93 | - break; |
|
| 94 | - |
|
| 95 | - case 'delete': |
|
| 96 | - $type_dels = @unserialize(Request::getString('type_del', '', 'POST')); |
|
| 97 | - foreach ($type_dels as $key) { |
|
| 98 | - if (!$typeObject = $typeHandler->get($key)) { |
|
| 99 | - continue; |
|
| 100 | - } |
|
| 101 | - $typeHandler->delete($typeObject); |
|
| 102 | - unset($typeObject); |
|
| 103 | - } |
|
| 104 | - redirect_header(xoops_getenv('PHP_SELF'), 2, _MD_NEWBB_DBUPDATED); |
|
| 105 | - break; |
|
| 106 | - |
|
| 107 | - case 'template': |
|
| 108 | - $typesObject = $typeHandler->getAll(); |
|
| 109 | - if (0 === count($typesObject)) { |
|
| 110 | - redirect_header(xoops_getenv('PHP_SELF'), 2, _AM_NEWBB_TYPE_ADD_ERR); |
|
| 111 | - } |
|
| 112 | - |
|
| 113 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_ADD, 'admin_type_manager.php?op=add', $icon = 'add'); |
|
| 114 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE, 'admin_type_manager.php?op=template', $icon = 'add'); |
|
| 115 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE_APPLY, 'admin_type_manager.php?op=apply', $icon = 'add'); |
|
| 116 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_FORUM, 'admin_type_manager.php?op=forum', $icon = 'add'); |
|
| 117 | - $adminObject->displayButton('left'); |
|
| 118 | - echo '<legend style="font-weight: bold; color: #900;">' . _AM_NEWBB_TYPE_ORDER_DESC . '</legend>'; |
|
| 119 | - echo "<table width='100%' border='0' cellspacing='1' class='outer'>" . "<tr><td class='odd'>"; |
|
| 120 | - echo "<form name='template' method='post' action='" . xoops_getenv('PHP_SELF') . "'>"; |
|
| 121 | - echo "<table border='0' cellpadding='4' cellspacing='1' width='100%' class='outer'>"; |
|
| 122 | - echo "<tr align='center'>"; |
|
| 123 | - echo "<th class='bg3' width='20%'>" . _AM_NEWBB_TYPE_ORDER . '</th>'; |
|
| 124 | - echo "<th class='bg3' width='20%'>" . _AM_NEWBB_TYPE_NAME . '</th>'; |
|
| 125 | - echo "<th class='bg3'>" . _AM_NEWBB_TYPE_DESCRIPTION . '</th>'; |
|
| 126 | - echo '</tr>'; |
|
| 127 | - |
|
| 128 | - if ($templates = $cacheHelper->read('type_template')) { |
|
| 129 | - arsort($templates); |
|
| 130 | - foreach ($templates as $order => $key) { |
|
| 131 | - if (!isset($typesObject[$key])) { |
|
| 132 | - continue; |
|
| 133 | - } |
|
| 134 | - $typeObject = $typesObject[$key]; |
|
| 135 | - echo "<tr class='even' align='left'>"; |
|
| 136 | - echo "<td><input type='text' name='type_order[{$key}]' value='" . $order . "' size='10' /></td>"; |
|
| 137 | - echo "<td><em style='color:" . $typeObject->getVar('type_color') . ";'>" . $typeObject->getVar('type_name') . '</em></td>'; |
|
| 138 | - echo '<td>' . $typeObject->getVar('type_description') . '</td>'; |
|
| 139 | - echo '</tr>'; |
|
| 140 | - unset($typesObject[$key]); |
|
| 141 | - } |
|
| 142 | - echo "<tr><td colspan='3' height='5px'></td></tr>"; |
|
| 143 | - } |
|
| 144 | - foreach ($typesObject as $key => $typeObject) { |
|
| 145 | - echo "<tr class='odd' align='left'>"; |
|
| 146 | - echo "<td><input type='text' name='type_order[{$key}]' value='0' size='10' /></td>"; |
|
| 147 | - echo "<td><em style='color:" . $typeObject->getVar('type_color') . ";'>" . $typeObject->getVar('type_name') . '</em></td>'; |
|
| 148 | - echo '<td>' . $typeObject->getVar('type_description') . '</td>'; |
|
| 149 | - echo '</tr>'; |
|
| 150 | - } |
|
| 151 | - |
|
| 152 | - echo "<tr><td colspan='3' style='text-align:center;'>"; |
|
| 153 | - echo "<input type='hidden' name='op' value='save_template' />"; |
|
| 154 | - echo "<input type='submit' name='submit' value='" . _SUBMIT . "' /> "; |
|
| 155 | - echo "<input type='reset' value='" . _CANCEL . "' />"; |
|
| 156 | - echo '</td></tr></table>'; |
|
| 157 | - echo '</form>'; |
|
| 158 | - echo '</td></tr></table>'; |
|
| 159 | - break; |
|
| 160 | - |
|
| 161 | - case 'save_template': |
|
| 162 | - $templates = array_flip(array_filter(Request::getArray('type_order', [], 'POST'))); |
|
| 163 | - $cacheHelper->write('type_template', $templates); |
|
| 164 | - redirect_header(xoops_getenv('PHP_SELF') . '?op=template', 2, _MD_NEWBB_DBUPDATED); |
|
| 165 | - break; |
|
| 166 | - |
|
| 167 | - case 'apply': |
|
| 168 | - if (!$templates = $cacheHelper->read('type_template')) { |
|
| 169 | - redirect_header(xoops_getenv('PHP_SELF') . '?op=template', 2, _AM_NEWBB_TYPE_TEMPLATE_ERR); |
|
| 170 | - } |
|
| 171 | - |
|
| 172 | - // $categoryHandler = Newbb\Helper::getInstance()->getHandler('Category'); |
|
| 173 | - $criteriaCategory = new \CriteriaCompo(new \Criteria('1', 1)); |
|
| 174 | - $criteriaCategory->setSort('cat_order'); |
|
| 175 | - $categories = $categoryHandler->getList($criteriaCategory); |
|
| 176 | - // $forumHandler = Newbb\Helper::getInstance()->getHandler('Forum'); |
|
| 177 | - $forums = $forumHandler->getTree(array_keys($categories), 0, 'all'); |
|
| 178 | - foreach (array_keys($forums) as $c) { |
|
| 179 | - $fm_options[-1 * $c] = '[' . $categories[$c] . ']'; |
|
| 180 | - foreach (array_keys($forums[$c]) as $f) { |
|
| 181 | - $fm_options[$f] = $forums[$c][$f]['prefix'] . $forums[$c][$f]['forum_name']; |
|
| 182 | - } |
|
| 183 | - } |
|
| 184 | - unset($forums, $categories); |
|
| 185 | - $fmform = new \XoopsThemeForm(_AM_NEWBB_TYPE_TEMPLATE_APPLY, 'fmform', xoops_getenv('PHP_SELF'), 'post', true); |
|
| 186 | - $fm_select = new \XoopsFormSelect(_AM_NEWBB_PERM_FORUMS, 'forums', null, 10, true); |
|
| 187 | - $fm_select->addOptionArray($fm_options); |
|
| 188 | - $fmform->addElement($fm_select); |
|
| 189 | - $tray = new \XoopsFormElementTray(''); |
|
| 190 | - $tray->addElement(new \XoopsFormHidden('op', 'save_apply')); |
|
| 191 | - $tray->addElement(new \XoopsFormButton('', 'submit', _SUBMIT, 'submit')); |
|
| 192 | - $tray->addElement(new \XoopsFormButton('', 'reset', _CANCEL, 'reset')); |
|
| 193 | - $fmform->addElement($tray); |
|
| 194 | - |
|
| 195 | - //loadModuleAdminMenu(11, _AM_NEWBB_TYPE_TEMPLATE_APPLY); |
|
| 196 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_ADD, 'admin_type_manager.php?op=add', $icon = 'add'); |
|
| 197 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE, 'admin_type_manager.php?op=template', $icon = 'add'); |
|
| 198 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE_APPLY, 'admin_type_manager.php?op=apply', $icon = 'add'); |
|
| 199 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_FORUM, 'admin_type_manager.php?op=forum', $icon = 'add'); |
|
| 200 | - $adminObject->displayButton('left'); |
|
| 201 | - |
|
| 202 | - echo "<table width='100%' border='0' cellspacing='1' class='outer'>" . "<tr><td class='odd'>"; |
|
| 203 | - echo "<table border='0' cellpadding='4' cellspacing='1' width='100%' class='outer'>"; |
|
| 204 | - echo "<tr align='center'>"; |
|
| 205 | - echo "<th class='bg3' width='20%'>" . _AM_NEWBB_TYPE_NAME . '</th>'; |
|
| 206 | - echo "<th class='bg3' width='20%'>" . _AM_NEWBB_TYPE_ORDER . '</th>'; |
|
| 207 | - echo "<th class='bg3'>" . _AM_NEWBB_TYPE_DESCRIPTION . '</th>'; |
|
| 208 | - echo '</tr>'; |
|
| 209 | - |
|
| 210 | - $typesObject = $typeHandler->getAll(new \Criteria('type_id', '(' . implode(', ', array_values($templates)) . ')', 'IN')); |
|
| 211 | - arsort($templates); |
|
| 212 | - foreach ($templates as $order => $key) { |
|
| 213 | - if (!isset($typesObject[$key])) { |
|
| 214 | - continue; |
|
| 215 | - } |
|
| 216 | - $typeObject = $typesObject[$key]; |
|
| 217 | - echo "<tr class='even' align='left'>"; |
|
| 218 | - echo "<td><em style='color:" . $typeObject->getVar('type_color') . ";'>" . $typeObject->getVar('type_name') . '</em></td>'; |
|
| 219 | - echo '<td>' . $order . '</td>'; |
|
| 220 | - echo '<td>' . $typeObject->getVar('type_description') . '</td>'; |
|
| 221 | - echo '</tr>'; |
|
| 222 | - unset($typesObject[$key]); |
|
| 223 | - } |
|
| 224 | - echo '</table>'; |
|
| 225 | - echo '</td></tr></table>'; |
|
| 226 | - echo '<br>'; |
|
| 227 | - $fmform->display(); |
|
| 228 | - break; |
|
| 229 | - |
|
| 230 | - case 'save_apply': |
|
| 231 | - if (!$templates = $cacheHelper->read('type_template')) { |
|
| 232 | - redirect_header(xoops_getenv('PHP_SELF') . '?op=template', 2, _AM_NEWBB_TYPE_TEMPLATE); |
|
| 233 | - } |
|
| 234 | - foreach (Request::getArray('forums', [], 'POST') as $forum) { |
|
| 235 | - if ($forum < 1) { |
|
| 236 | - continue; |
|
| 237 | - } |
|
| 238 | - $typeHandler->updateByForum($forum, array_flip($templates)); |
|
| 239 | - } |
|
| 240 | - redirect_header(xoops_getenv('PHP_SELF'), 2, _MD_NEWBB_DBUPDATED); |
|
| 241 | - break; |
|
| 242 | - |
|
| 243 | - case 'forum': |
|
| 244 | - // $categoryHandler = Newbb\Helper::getInstance()->getHandler('Category'); |
|
| 245 | - $criteriaCategory = new \CriteriaCompo(new \Criteria('1', 1)); |
|
| 246 | - $criteriaCategory->setSort('cat_order'); |
|
| 247 | - $categories = $categoryHandler->getList($criteriaCategory); |
|
| 248 | - if (empty($categories)) { |
|
| 249 | - redirect_header('admin_cat_manager.php', 2, _AM_NEWBB_CREATENEWCATEGORY); |
|
| 250 | - } |
|
| 251 | - // $forumHandler = Newbb\Helper::getInstance()->getHandler('Forum'); |
|
| 252 | - $forums = $forumHandler->getTree(array_keys($categories)); |
|
| 253 | - if (empty($forums)) { |
|
| 254 | - redirect_header('admin_forum_manager.php', 2, _AM_NEWBB_CREATENEWFORUM); |
|
| 255 | - } |
|
| 256 | - |
|
| 257 | - foreach (array_keys($forums) as $c) { |
|
| 258 | - $fm_options[-1 * $c] = '[' . $categories[$c] . ']'; |
|
| 259 | - foreach (array_keys($forums[$c]) as $f) { |
|
| 260 | - $fm_options[$f] = $forums[$c][$f]['prefix'] . $forums[$c][$f]['forum_name']; |
|
| 261 | - } |
|
| 262 | - } |
|
| 263 | - unset($forums, $categories); |
|
| 264 | - $fmform = new \XoopsThemeForm(_AM_NEWBB_TYPE_FORUM, 'fmform', xoops_getenv('PHP_SELF'), 'post', true); |
|
| 265 | - $fm_select = new \XoopsFormSelect(_AM_NEWBB_PERM_FORUMS, 'forum', null, 5, false); |
|
| 266 | - $fm_select->addOptionArray($fm_options); |
|
| 267 | - $fmform->addElement($fm_select); |
|
| 268 | - $tray = new \XoopsFormElementTray(''); |
|
| 269 | - $tray->addElement(new \XoopsFormHidden('op', 'edit_forum')); |
|
| 270 | - $tray->addElement(new \XoopsFormButton('', 'submit', _SUBMIT, 'submit')); |
|
| 271 | - $tray->addElement(new \XoopsFormButton('', 'reset', _CANCEL, 'reset')); |
|
| 272 | - $fmform->addElement($tray); |
|
| 273 | - |
|
| 274 | - //loadModuleAdminMenu(11, _AM_NEWBB_TYPE_FORUM); |
|
| 275 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_ADD, 'admin_type_manager.php?op=add', $icon = 'add'); |
|
| 276 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE, 'admin_type_manager.php?op=template', $icon = 'add'); |
|
| 277 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_FORUM, 'admin_type_manager.php?op=forum', $icon = 'add'); |
|
| 278 | - $adminObject->displayButton('left'); |
|
| 279 | - |
|
| 280 | - $fmform->display(); |
|
| 281 | - break; |
|
| 282 | - |
|
| 283 | - case 'edit_forum': |
|
| 284 | - if (!Request::getInt('forum', 0, 'POST') || Request::getInt('forum', 0, 'POST') < 1) { |
|
| 285 | - redirect_header(xoops_getenv('PHP_SELF') . '?op=forum', 2, _AM_NEWBB_TYPE_FORUM_ERR); |
|
| 286 | - } |
|
| 287 | - |
|
| 288 | - // $forumHandler = Newbb\Helper::getInstance()->getHandler('Forum'); |
|
| 289 | - if (!$forumObject = $forumHandler->get(Request::getInt('forum', 0, 'POST'))) { |
|
| 290 | - redirect_header(xoops_getenv('PHP_SELF') . '?op=forum', 2, _AM_NEWBB_TYPE_FORUM_ERR); |
|
| 291 | - } |
|
| 292 | - |
|
| 293 | - $typesObject = $typeHandler->getAll(); |
|
| 294 | - if (0 === count($typesObject)) { |
|
| 295 | - redirect_header(xoops_getenv('PHP_SELF'), 2, _AM_NEWBB_TYPE_ADD_ERR); |
|
| 296 | - } |
|
| 297 | - |
|
| 298 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_ADD, 'admin_type_manager.php?op=add', $icon = 'add'); |
|
| 299 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE, 'admin_type_manager.php?op=template', $icon = 'add'); |
|
| 300 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_FORUM, 'admin_type_manager.php?op=forum', $icon = 'add'); |
|
| 301 | - $adminObject->displayButton('left'); |
|
| 302 | - echo '<legend style="font-weight: bold; color: #900;">' . _AM_NEWBB_TYPE_ORDER_DESC . '</legend>'; |
|
| 303 | - echo "<table width='100%' border='0' cellspacing='1' class='outer'>" . "<tr><td class='odd'>"; |
|
| 304 | - echo "<form name='template' method='post' action='" . xoops_getenv('PHP_SELF') . "'>"; |
|
| 305 | - echo "<table border='0' cellpadding='4' cellspacing='1' width='100%' class='outer'>"; |
|
| 306 | - echo "<tr align='center'>"; |
|
| 307 | - echo "<th class='bg3' width='20%'>" . _AM_NEWBB_TYPE_ORDER . '</th>'; |
|
| 308 | - echo "<th class='bg3' width='20%'>" . _AM_NEWBB_TYPE_NAME . '</th>'; |
|
| 309 | - echo "<th class='bg3'>" . _AM_NEWBB_TYPE_DESCRIPTION . '</th>'; |
|
| 310 | - echo '</tr>'; |
|
| 311 | - |
|
| 312 | - $types = $typeHandler->getByForum(Request::getInt('forum', 0, 'POST')); |
|
| 313 | - $types_order = []; |
|
| 314 | - foreach ($types as $key => $type) { |
|
| 315 | - $types_order[] = $type['type_order']; |
|
| 316 | - } |
|
| 317 | - array_multisort($types_order, $types); |
|
| 318 | - foreach ($types as $key => $type) { |
|
| 319 | - if (!isset($typesObject[$type['type_id']])) { |
|
| 320 | - continue; |
|
| 321 | - } |
|
| 322 | - $typeObject = $typesObject[$type['type_id']]; |
|
| 323 | - echo "<tr class='even' align='left'>"; |
|
| 324 | - echo "<td><input type='text' name='type_order[" . $type['type_id'] . "]' value='" . $type['type_order'] . "' size='10' /></td>"; |
|
| 325 | - echo "<td><em style='color:" . $typeObject->getVar('type_color') . ";'>" . $typeObject->getVar('type_name') . '</em></td>'; |
|
| 326 | - echo '<td>' . $typeObject->getVar('type_description') . '</td>'; |
|
| 327 | - echo '</tr>'; |
|
| 328 | - unset($typesObject[$type['type_id']]); |
|
| 329 | - } |
|
| 330 | - echo "<tr><td colspan='3' height='5px'></td></tr>"; |
|
| 331 | - foreach ($typesObject as $key => $typeObject) { |
|
| 332 | - echo "<tr class='odd' align='left'>"; |
|
| 333 | - echo "<td><input type='text' name='type_order[{$key}]' value='0' size='10' /></td>"; |
|
| 334 | - echo "<td><em style='color:" . $typeObject->getVar('type_color') . ";'>" . $typeObject->getVar('type_name') . '</em></td>'; |
|
| 335 | - echo '<td>' . $typeObject->getVar('type_description') . '</td>'; |
|
| 336 | - echo '</tr>'; |
|
| 337 | - } |
|
| 338 | - |
|
| 339 | - echo "<tr><td colspan='3' style='text-align:center;'>"; |
|
| 340 | - echo '<legend style="font-weight: bold; color: #900;">' . _AM_NEWBB_TYPE_EDITFORUM_DESC . '</legend>'; |
|
| 341 | - echo "<input type='hidden' name='forum' value='" . Request::getInt('forum', 0, 'POST') . "' />"; |
|
| 342 | - echo "<input type='hidden' name='op' value='save_forum' />"; |
|
| 343 | - echo "<input type='submit' name='submit' value='" . _SUBMIT . "' /> "; |
|
| 344 | - echo "<input type='reset' value='" . _CANCEL . "' />"; |
|
| 345 | - echo '</td></tr></table>'; |
|
| 346 | - echo '</form>'; |
|
| 347 | - echo '</td></tr></table>'; |
|
| 348 | - break; |
|
| 349 | - |
|
| 350 | - case 'save_forum': |
|
| 351 | - if (!Request::getInt('forum', 0, 'POST') || Request::getInt('forum', 0, 'POST') < 1) { |
|
| 352 | - redirect_header(xoops_getenv('PHP_SELF') . '?op=forum', 2, _AM_NEWBB_TYPE_FORUM); |
|
| 353 | - } |
|
| 354 | - $typeHandler->updateByForum(Request::getInt('forum', 0, 'POST'), Request::getArray('type_order', null, 'POST')); |
|
| 355 | - redirect_header(xoops_getenv('PHP_SELF') . '?op=forum', 2, _MD_NEWBB_DBUPDATED); |
|
| 356 | - break; |
|
| 357 | - |
|
| 358 | - case 'add': |
|
| 359 | - default: |
|
| 360 | - $typesObject = $typeHandler->getAll(); |
|
| 361 | - if (0 === count($typesObject)) { |
|
| 362 | - $op = 'add'; |
|
| 363 | - $title = _AM_NEWBB_TYPE_ADD; |
|
| 364 | - } else { |
|
| 365 | - $title = _AM_NEWBB_TYPE_LIST; |
|
| 366 | - } |
|
| 367 | - |
|
| 368 | - if ('add' !== $op) { |
|
| 369 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_ADD, 'admin_type_manager.php?op=add', $icon = 'add'); |
|
| 370 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE, 'admin_type_manager.php?op=template', $icon = 'add'); |
|
| 371 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_FORUM, 'admin_type_manager.php?op=forum', $icon = 'add'); |
|
| 372 | - $adminObject->displayButton('left'); |
|
| 373 | - } |
|
| 374 | - echo _AM_NEWBB_TYPE_HELP; |
|
| 375 | - echo "<table width='100%' border='0' cellspacing='1' class='outer'>" . "<tr><td class='odd'>"; |
|
| 376 | - echo "<form name='list' method='post' action='" . xoops_getenv('PHP_SELF') . "'>"; |
|
| 377 | - echo "<table border='0' cellpadding='4' cellspacing='1' width='100%' class='outer'>"; |
|
| 378 | - echo "<tr align='center'>"; |
|
| 379 | - if ('add' !== $op) { |
|
| 380 | - echo "<th class='bg3' width='5%'>" . _DELETE . '</th>'; |
|
| 381 | - } |
|
| 382 | - echo "<th align='left' class='bg3' width='20%'>" . _AM_NEWBB_TYPE_NAME . '</th>'; |
|
| 383 | - echo "<th class='bg3' width='15%'>" . _AM_NEWBB_TYPE_COLOR . '</th>'; |
|
| 384 | - echo "<th align='left' class='bg3'>" . _AM_NEWBB_TYPE_DESCRIPTION . '</th>'; |
|
| 385 | - echo '</tr>'; |
|
| 55 | + case 'save_type': |
|
| 56 | + $type_names0 = $_POST['type_name']; |
|
| 57 | + $type_names = Request::getArray('type_name', null, 'POST'); |
|
| 58 | + $type_del = []; |
|
| 59 | + foreach (array_keys($type_names) as $key) { |
|
| 60 | + if (Request::getBool('isnew', '', 'POST')) { |
|
| 61 | + $typeObject = $typeHandler->create(); |
|
| 62 | + } elseif (!$typeObject = $typeHandler->get($key)) { |
|
| 63 | + continue; |
|
| 64 | + } |
|
| 65 | + |
|
| 66 | + // if (Request::getArray("type_del[$key]", '', 'POST')) { |
|
| 67 | + $temp = Request::getArray('type_del', '', 'POST'); |
|
| 68 | + if ($temp[$key]) { |
|
| 69 | + $type_del[] = $key; |
|
| 70 | + continue; |
|
| 71 | + } else { |
|
| 72 | + foreach (['type_name', 'type_color', 'type_description'] as $var) { |
|
| 73 | + // if ($typeObject->getVar($var) != @$_POST[$var][$key]) { |
|
| 74 | + // $typeObject->setVar($var, @$_POST[$var][$key]); |
|
| 75 | + // } |
|
| 76 | + $temp = Request::getArray($var, '', 'POST'); |
|
| 77 | + if ($typeObject->getVar($var) != $temp[$key]) { |
|
| 78 | + $typeObject->setVar($var, $temp[$key]); |
|
| 79 | + } |
|
| 80 | + |
|
| 81 | + // $typeObject->setVar($var, Request::getArray($var, '', 'POST')[$key]); |
|
| 82 | + } |
|
| 83 | + $typeHandler->insert($typeObject); |
|
| 84 | + unset($typeObject); |
|
| 85 | + } |
|
| 86 | + } |
|
| 87 | + if (count($type_del) > 0) { |
|
| 88 | + $type_list = $typeHandler->getList(new \Criteria('type_id', '(' . implode(', ', $type_del) . ')', 'IN')); |
|
| 89 | + xoops_confirm(['op' => 'delete', 'type_del' => serialize($type_del)], xoops_getenv('PHP_SELF'), sprintf(_AM_NEWBB_TODEL_TYPE, implode(', ', array_values($type_list))), '', false); |
|
| 90 | + } else { |
|
| 91 | + redirect_header(xoops_getenv('PHP_SELF'), 2, _MD_NEWBB_DBUPDATED); |
|
| 92 | + } |
|
| 93 | + break; |
|
| 94 | + |
|
| 95 | + case 'delete': |
|
| 96 | + $type_dels = @unserialize(Request::getString('type_del', '', 'POST')); |
|
| 97 | + foreach ($type_dels as $key) { |
|
| 98 | + if (!$typeObject = $typeHandler->get($key)) { |
|
| 99 | + continue; |
|
| 100 | + } |
|
| 101 | + $typeHandler->delete($typeObject); |
|
| 102 | + unset($typeObject); |
|
| 103 | + } |
|
| 104 | + redirect_header(xoops_getenv('PHP_SELF'), 2, _MD_NEWBB_DBUPDATED); |
|
| 105 | + break; |
|
| 106 | + |
|
| 107 | + case 'template': |
|
| 108 | + $typesObject = $typeHandler->getAll(); |
|
| 109 | + if (0 === count($typesObject)) { |
|
| 110 | + redirect_header(xoops_getenv('PHP_SELF'), 2, _AM_NEWBB_TYPE_ADD_ERR); |
|
| 111 | + } |
|
| 112 | + |
|
| 113 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_ADD, 'admin_type_manager.php?op=add', $icon = 'add'); |
|
| 114 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE, 'admin_type_manager.php?op=template', $icon = 'add'); |
|
| 115 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE_APPLY, 'admin_type_manager.php?op=apply', $icon = 'add'); |
|
| 116 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_FORUM, 'admin_type_manager.php?op=forum', $icon = 'add'); |
|
| 117 | + $adminObject->displayButton('left'); |
|
| 118 | + echo '<legend style="font-weight: bold; color: #900;">' . _AM_NEWBB_TYPE_ORDER_DESC . '</legend>'; |
|
| 119 | + echo "<table width='100%' border='0' cellspacing='1' class='outer'>" . "<tr><td class='odd'>"; |
|
| 120 | + echo "<form name='template' method='post' action='" . xoops_getenv('PHP_SELF') . "'>"; |
|
| 121 | + echo "<table border='0' cellpadding='4' cellspacing='1' width='100%' class='outer'>"; |
|
| 122 | + echo "<tr align='center'>"; |
|
| 123 | + echo "<th class='bg3' width='20%'>" . _AM_NEWBB_TYPE_ORDER . '</th>'; |
|
| 124 | + echo "<th class='bg3' width='20%'>" . _AM_NEWBB_TYPE_NAME . '</th>'; |
|
| 125 | + echo "<th class='bg3'>" . _AM_NEWBB_TYPE_DESCRIPTION . '</th>'; |
|
| 126 | + echo '</tr>'; |
|
| 127 | + |
|
| 128 | + if ($templates = $cacheHelper->read('type_template')) { |
|
| 129 | + arsort($templates); |
|
| 130 | + foreach ($templates as $order => $key) { |
|
| 131 | + if (!isset($typesObject[$key])) { |
|
| 132 | + continue; |
|
| 133 | + } |
|
| 134 | + $typeObject = $typesObject[$key]; |
|
| 135 | + echo "<tr class='even' align='left'>"; |
|
| 136 | + echo "<td><input type='text' name='type_order[{$key}]' value='" . $order . "' size='10' /></td>"; |
|
| 137 | + echo "<td><em style='color:" . $typeObject->getVar('type_color') . ";'>" . $typeObject->getVar('type_name') . '</em></td>'; |
|
| 138 | + echo '<td>' . $typeObject->getVar('type_description') . '</td>'; |
|
| 139 | + echo '</tr>'; |
|
| 140 | + unset($typesObject[$key]); |
|
| 141 | + } |
|
| 142 | + echo "<tr><td colspan='3' height='5px'></td></tr>"; |
|
| 143 | + } |
|
| 144 | + foreach ($typesObject as $key => $typeObject) { |
|
| 145 | + echo "<tr class='odd' align='left'>"; |
|
| 146 | + echo "<td><input type='text' name='type_order[{$key}]' value='0' size='10' /></td>"; |
|
| 147 | + echo "<td><em style='color:" . $typeObject->getVar('type_color') . ";'>" . $typeObject->getVar('type_name') . '</em></td>'; |
|
| 148 | + echo '<td>' . $typeObject->getVar('type_description') . '</td>'; |
|
| 149 | + echo '</tr>'; |
|
| 150 | + } |
|
| 151 | + |
|
| 152 | + echo "<tr><td colspan='3' style='text-align:center;'>"; |
|
| 153 | + echo "<input type='hidden' name='op' value='save_template' />"; |
|
| 154 | + echo "<input type='submit' name='submit' value='" . _SUBMIT . "' /> "; |
|
| 155 | + echo "<input type='reset' value='" . _CANCEL . "' />"; |
|
| 156 | + echo '</td></tr></table>'; |
|
| 157 | + echo '</form>'; |
|
| 158 | + echo '</td></tr></table>'; |
|
| 159 | + break; |
|
| 160 | + |
|
| 161 | + case 'save_template': |
|
| 162 | + $templates = array_flip(array_filter(Request::getArray('type_order', [], 'POST'))); |
|
| 163 | + $cacheHelper->write('type_template', $templates); |
|
| 164 | + redirect_header(xoops_getenv('PHP_SELF') . '?op=template', 2, _MD_NEWBB_DBUPDATED); |
|
| 165 | + break; |
|
| 166 | + |
|
| 167 | + case 'apply': |
|
| 168 | + if (!$templates = $cacheHelper->read('type_template')) { |
|
| 169 | + redirect_header(xoops_getenv('PHP_SELF') . '?op=template', 2, _AM_NEWBB_TYPE_TEMPLATE_ERR); |
|
| 170 | + } |
|
| 171 | + |
|
| 172 | + // $categoryHandler = Newbb\Helper::getInstance()->getHandler('Category'); |
|
| 173 | + $criteriaCategory = new \CriteriaCompo(new \Criteria('1', 1)); |
|
| 174 | + $criteriaCategory->setSort('cat_order'); |
|
| 175 | + $categories = $categoryHandler->getList($criteriaCategory); |
|
| 176 | + // $forumHandler = Newbb\Helper::getInstance()->getHandler('Forum'); |
|
| 177 | + $forums = $forumHandler->getTree(array_keys($categories), 0, 'all'); |
|
| 178 | + foreach (array_keys($forums) as $c) { |
|
| 179 | + $fm_options[-1 * $c] = '[' . $categories[$c] . ']'; |
|
| 180 | + foreach (array_keys($forums[$c]) as $f) { |
|
| 181 | + $fm_options[$f] = $forums[$c][$f]['prefix'] . $forums[$c][$f]['forum_name']; |
|
| 182 | + } |
|
| 183 | + } |
|
| 184 | + unset($forums, $categories); |
|
| 185 | + $fmform = new \XoopsThemeForm(_AM_NEWBB_TYPE_TEMPLATE_APPLY, 'fmform', xoops_getenv('PHP_SELF'), 'post', true); |
|
| 186 | + $fm_select = new \XoopsFormSelect(_AM_NEWBB_PERM_FORUMS, 'forums', null, 10, true); |
|
| 187 | + $fm_select->addOptionArray($fm_options); |
|
| 188 | + $fmform->addElement($fm_select); |
|
| 189 | + $tray = new \XoopsFormElementTray(''); |
|
| 190 | + $tray->addElement(new \XoopsFormHidden('op', 'save_apply')); |
|
| 191 | + $tray->addElement(new \XoopsFormButton('', 'submit', _SUBMIT, 'submit')); |
|
| 192 | + $tray->addElement(new \XoopsFormButton('', 'reset', _CANCEL, 'reset')); |
|
| 193 | + $fmform->addElement($tray); |
|
| 194 | + |
|
| 195 | + //loadModuleAdminMenu(11, _AM_NEWBB_TYPE_TEMPLATE_APPLY); |
|
| 196 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_ADD, 'admin_type_manager.php?op=add', $icon = 'add'); |
|
| 197 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE, 'admin_type_manager.php?op=template', $icon = 'add'); |
|
| 198 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE_APPLY, 'admin_type_manager.php?op=apply', $icon = 'add'); |
|
| 199 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_FORUM, 'admin_type_manager.php?op=forum', $icon = 'add'); |
|
| 200 | + $adminObject->displayButton('left'); |
|
| 201 | + |
|
| 202 | + echo "<table width='100%' border='0' cellspacing='1' class='outer'>" . "<tr><td class='odd'>"; |
|
| 203 | + echo "<table border='0' cellpadding='4' cellspacing='1' width='100%' class='outer'>"; |
|
| 204 | + echo "<tr align='center'>"; |
|
| 205 | + echo "<th class='bg3' width='20%'>" . _AM_NEWBB_TYPE_NAME . '</th>'; |
|
| 206 | + echo "<th class='bg3' width='20%'>" . _AM_NEWBB_TYPE_ORDER . '</th>'; |
|
| 207 | + echo "<th class='bg3'>" . _AM_NEWBB_TYPE_DESCRIPTION . '</th>'; |
|
| 208 | + echo '</tr>'; |
|
| 209 | + |
|
| 210 | + $typesObject = $typeHandler->getAll(new \Criteria('type_id', '(' . implode(', ', array_values($templates)) . ')', 'IN')); |
|
| 211 | + arsort($templates); |
|
| 212 | + foreach ($templates as $order => $key) { |
|
| 213 | + if (!isset($typesObject[$key])) { |
|
| 214 | + continue; |
|
| 215 | + } |
|
| 216 | + $typeObject = $typesObject[$key]; |
|
| 217 | + echo "<tr class='even' align='left'>"; |
|
| 218 | + echo "<td><em style='color:" . $typeObject->getVar('type_color') . ";'>" . $typeObject->getVar('type_name') . '</em></td>'; |
|
| 219 | + echo '<td>' . $order . '</td>'; |
|
| 220 | + echo '<td>' . $typeObject->getVar('type_description') . '</td>'; |
|
| 221 | + echo '</tr>'; |
|
| 222 | + unset($typesObject[$key]); |
|
| 223 | + } |
|
| 224 | + echo '</table>'; |
|
| 225 | + echo '</td></tr></table>'; |
|
| 226 | + echo '<br>'; |
|
| 227 | + $fmform->display(); |
|
| 228 | + break; |
|
| 229 | + |
|
| 230 | + case 'save_apply': |
|
| 231 | + if (!$templates = $cacheHelper->read('type_template')) { |
|
| 232 | + redirect_header(xoops_getenv('PHP_SELF') . '?op=template', 2, _AM_NEWBB_TYPE_TEMPLATE); |
|
| 233 | + } |
|
| 234 | + foreach (Request::getArray('forums', [], 'POST') as $forum) { |
|
| 235 | + if ($forum < 1) { |
|
| 236 | + continue; |
|
| 237 | + } |
|
| 238 | + $typeHandler->updateByForum($forum, array_flip($templates)); |
|
| 239 | + } |
|
| 240 | + redirect_header(xoops_getenv('PHP_SELF'), 2, _MD_NEWBB_DBUPDATED); |
|
| 241 | + break; |
|
| 242 | + |
|
| 243 | + case 'forum': |
|
| 244 | + // $categoryHandler = Newbb\Helper::getInstance()->getHandler('Category'); |
|
| 245 | + $criteriaCategory = new \CriteriaCompo(new \Criteria('1', 1)); |
|
| 246 | + $criteriaCategory->setSort('cat_order'); |
|
| 247 | + $categories = $categoryHandler->getList($criteriaCategory); |
|
| 248 | + if (empty($categories)) { |
|
| 249 | + redirect_header('admin_cat_manager.php', 2, _AM_NEWBB_CREATENEWCATEGORY); |
|
| 250 | + } |
|
| 251 | + // $forumHandler = Newbb\Helper::getInstance()->getHandler('Forum'); |
|
| 252 | + $forums = $forumHandler->getTree(array_keys($categories)); |
|
| 253 | + if (empty($forums)) { |
|
| 254 | + redirect_header('admin_forum_manager.php', 2, _AM_NEWBB_CREATENEWFORUM); |
|
| 255 | + } |
|
| 256 | + |
|
| 257 | + foreach (array_keys($forums) as $c) { |
|
| 258 | + $fm_options[-1 * $c] = '[' . $categories[$c] . ']'; |
|
| 259 | + foreach (array_keys($forums[$c]) as $f) { |
|
| 260 | + $fm_options[$f] = $forums[$c][$f]['prefix'] . $forums[$c][$f]['forum_name']; |
|
| 261 | + } |
|
| 262 | + } |
|
| 263 | + unset($forums, $categories); |
|
| 264 | + $fmform = new \XoopsThemeForm(_AM_NEWBB_TYPE_FORUM, 'fmform', xoops_getenv('PHP_SELF'), 'post', true); |
|
| 265 | + $fm_select = new \XoopsFormSelect(_AM_NEWBB_PERM_FORUMS, 'forum', null, 5, false); |
|
| 266 | + $fm_select->addOptionArray($fm_options); |
|
| 267 | + $fmform->addElement($fm_select); |
|
| 268 | + $tray = new \XoopsFormElementTray(''); |
|
| 269 | + $tray->addElement(new \XoopsFormHidden('op', 'edit_forum')); |
|
| 270 | + $tray->addElement(new \XoopsFormButton('', 'submit', _SUBMIT, 'submit')); |
|
| 271 | + $tray->addElement(new \XoopsFormButton('', 'reset', _CANCEL, 'reset')); |
|
| 272 | + $fmform->addElement($tray); |
|
| 273 | + |
|
| 274 | + //loadModuleAdminMenu(11, _AM_NEWBB_TYPE_FORUM); |
|
| 275 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_ADD, 'admin_type_manager.php?op=add', $icon = 'add'); |
|
| 276 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE, 'admin_type_manager.php?op=template', $icon = 'add'); |
|
| 277 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_FORUM, 'admin_type_manager.php?op=forum', $icon = 'add'); |
|
| 278 | + $adminObject->displayButton('left'); |
|
| 279 | + |
|
| 280 | + $fmform->display(); |
|
| 281 | + break; |
|
| 282 | + |
|
| 283 | + case 'edit_forum': |
|
| 284 | + if (!Request::getInt('forum', 0, 'POST') || Request::getInt('forum', 0, 'POST') < 1) { |
|
| 285 | + redirect_header(xoops_getenv('PHP_SELF') . '?op=forum', 2, _AM_NEWBB_TYPE_FORUM_ERR); |
|
| 286 | + } |
|
| 287 | + |
|
| 288 | + // $forumHandler = Newbb\Helper::getInstance()->getHandler('Forum'); |
|
| 289 | + if (!$forumObject = $forumHandler->get(Request::getInt('forum', 0, 'POST'))) { |
|
| 290 | + redirect_header(xoops_getenv('PHP_SELF') . '?op=forum', 2, _AM_NEWBB_TYPE_FORUM_ERR); |
|
| 291 | + } |
|
| 292 | + |
|
| 293 | + $typesObject = $typeHandler->getAll(); |
|
| 294 | + if (0 === count($typesObject)) { |
|
| 295 | + redirect_header(xoops_getenv('PHP_SELF'), 2, _AM_NEWBB_TYPE_ADD_ERR); |
|
| 296 | + } |
|
| 297 | + |
|
| 298 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_ADD, 'admin_type_manager.php?op=add', $icon = 'add'); |
|
| 299 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE, 'admin_type_manager.php?op=template', $icon = 'add'); |
|
| 300 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_FORUM, 'admin_type_manager.php?op=forum', $icon = 'add'); |
|
| 301 | + $adminObject->displayButton('left'); |
|
| 302 | + echo '<legend style="font-weight: bold; color: #900;">' . _AM_NEWBB_TYPE_ORDER_DESC . '</legend>'; |
|
| 303 | + echo "<table width='100%' border='0' cellspacing='1' class='outer'>" . "<tr><td class='odd'>"; |
|
| 304 | + echo "<form name='template' method='post' action='" . xoops_getenv('PHP_SELF') . "'>"; |
|
| 305 | + echo "<table border='0' cellpadding='4' cellspacing='1' width='100%' class='outer'>"; |
|
| 306 | + echo "<tr align='center'>"; |
|
| 307 | + echo "<th class='bg3' width='20%'>" . _AM_NEWBB_TYPE_ORDER . '</th>'; |
|
| 308 | + echo "<th class='bg3' width='20%'>" . _AM_NEWBB_TYPE_NAME . '</th>'; |
|
| 309 | + echo "<th class='bg3'>" . _AM_NEWBB_TYPE_DESCRIPTION . '</th>'; |
|
| 310 | + echo '</tr>'; |
|
| 311 | + |
|
| 312 | + $types = $typeHandler->getByForum(Request::getInt('forum', 0, 'POST')); |
|
| 313 | + $types_order = []; |
|
| 314 | + foreach ($types as $key => $type) { |
|
| 315 | + $types_order[] = $type['type_order']; |
|
| 316 | + } |
|
| 317 | + array_multisort($types_order, $types); |
|
| 318 | + foreach ($types as $key => $type) { |
|
| 319 | + if (!isset($typesObject[$type['type_id']])) { |
|
| 320 | + continue; |
|
| 321 | + } |
|
| 322 | + $typeObject = $typesObject[$type['type_id']]; |
|
| 323 | + echo "<tr class='even' align='left'>"; |
|
| 324 | + echo "<td><input type='text' name='type_order[" . $type['type_id'] . "]' value='" . $type['type_order'] . "' size='10' /></td>"; |
|
| 325 | + echo "<td><em style='color:" . $typeObject->getVar('type_color') . ";'>" . $typeObject->getVar('type_name') . '</em></td>'; |
|
| 326 | + echo '<td>' . $typeObject->getVar('type_description') . '</td>'; |
|
| 327 | + echo '</tr>'; |
|
| 328 | + unset($typesObject[$type['type_id']]); |
|
| 329 | + } |
|
| 330 | + echo "<tr><td colspan='3' height='5px'></td></tr>"; |
|
| 331 | + foreach ($typesObject as $key => $typeObject) { |
|
| 332 | + echo "<tr class='odd' align='left'>"; |
|
| 333 | + echo "<td><input type='text' name='type_order[{$key}]' value='0' size='10' /></td>"; |
|
| 334 | + echo "<td><em style='color:" . $typeObject->getVar('type_color') . ";'>" . $typeObject->getVar('type_name') . '</em></td>'; |
|
| 335 | + echo '<td>' . $typeObject->getVar('type_description') . '</td>'; |
|
| 336 | + echo '</tr>'; |
|
| 337 | + } |
|
| 338 | + |
|
| 339 | + echo "<tr><td colspan='3' style='text-align:center;'>"; |
|
| 340 | + echo '<legend style="font-weight: bold; color: #900;">' . _AM_NEWBB_TYPE_EDITFORUM_DESC . '</legend>'; |
|
| 341 | + echo "<input type='hidden' name='forum' value='" . Request::getInt('forum', 0, 'POST') . "' />"; |
|
| 342 | + echo "<input type='hidden' name='op' value='save_forum' />"; |
|
| 343 | + echo "<input type='submit' name='submit' value='" . _SUBMIT . "' /> "; |
|
| 344 | + echo "<input type='reset' value='" . _CANCEL . "' />"; |
|
| 345 | + echo '</td></tr></table>'; |
|
| 346 | + echo '</form>'; |
|
| 347 | + echo '</td></tr></table>'; |
|
| 348 | + break; |
|
| 349 | + |
|
| 350 | + case 'save_forum': |
|
| 351 | + if (!Request::getInt('forum', 0, 'POST') || Request::getInt('forum', 0, 'POST') < 1) { |
|
| 352 | + redirect_header(xoops_getenv('PHP_SELF') . '?op=forum', 2, _AM_NEWBB_TYPE_FORUM); |
|
| 353 | + } |
|
| 354 | + $typeHandler->updateByForum(Request::getInt('forum', 0, 'POST'), Request::getArray('type_order', null, 'POST')); |
|
| 355 | + redirect_header(xoops_getenv('PHP_SELF') . '?op=forum', 2, _MD_NEWBB_DBUPDATED); |
|
| 356 | + break; |
|
| 357 | + |
|
| 358 | + case 'add': |
|
| 359 | + default: |
|
| 360 | + $typesObject = $typeHandler->getAll(); |
|
| 361 | + if (0 === count($typesObject)) { |
|
| 362 | + $op = 'add'; |
|
| 363 | + $title = _AM_NEWBB_TYPE_ADD; |
|
| 364 | + } else { |
|
| 365 | + $title = _AM_NEWBB_TYPE_LIST; |
|
| 366 | + } |
|
| 367 | + |
|
| 368 | + if ('add' !== $op) { |
|
| 369 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_ADD, 'admin_type_manager.php?op=add', $icon = 'add'); |
|
| 370 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE, 'admin_type_manager.php?op=template', $icon = 'add'); |
|
| 371 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_FORUM, 'admin_type_manager.php?op=forum', $icon = 'add'); |
|
| 372 | + $adminObject->displayButton('left'); |
|
| 373 | + } |
|
| 374 | + echo _AM_NEWBB_TYPE_HELP; |
|
| 375 | + echo "<table width='100%' border='0' cellspacing='1' class='outer'>" . "<tr><td class='odd'>"; |
|
| 376 | + echo "<form name='list' method='post' action='" . xoops_getenv('PHP_SELF') . "'>"; |
|
| 377 | + echo "<table border='0' cellpadding='4' cellspacing='1' width='100%' class='outer'>"; |
|
| 378 | + echo "<tr align='center'>"; |
|
| 379 | + if ('add' !== $op) { |
|
| 380 | + echo "<th class='bg3' width='5%'>" . _DELETE . '</th>'; |
|
| 381 | + } |
|
| 382 | + echo "<th align='left' class='bg3' width='20%'>" . _AM_NEWBB_TYPE_NAME . '</th>'; |
|
| 383 | + echo "<th class='bg3' width='15%'>" . _AM_NEWBB_TYPE_COLOR . '</th>'; |
|
| 384 | + echo "<th align='left' class='bg3'>" . _AM_NEWBB_TYPE_DESCRIPTION . '</th>'; |
|
| 385 | + echo '</tr>'; |
|
| 386 | 386 | |
| 387 | 387 | // $isColorpicker = require_once $GLOBALS['xoops']->path('class/xoopsform/formcolorpicker.php'); |
| 388 | - xoops_load('XoopsFormColorPicker'); |
|
| 389 | - |
|
| 390 | - if ('add' !== $op) { |
|
| 391 | - foreach ($typesObject as $key => $typeObject) { |
|
| 392 | - echo "<tr class='odd' align='left'>"; |
|
| 393 | - echo "<td><input type='checkbox' name='type_del[{$key}]' /></td>"; |
|
| 394 | - echo "<td><input type='text' name='type_name[{$key}]' value='" . $typeObject->getVar('type_name') . "' size='10' /></td>"; |
|
| 395 | - if ($isColorpicker) { |
|
| 396 | - $form_colorpicker = new \XoopsFormColorPicker('', "type_color[{$key}]", $typeObject->getVar('type_color')); |
|
| 397 | - echo '<td>' . $form_colorpicker->render() . '</td>'; |
|
| 398 | - } else { |
|
| 399 | - echo "<td><input type='text' name='type_color[{$key}]' value='" . $typeObject->getVar('type_color') . "' size='10' /></td>"; |
|
| 400 | - } |
|
| 401 | - echo "<td><input type='text' name='type_description[{$key}]' value='" . $typeObject->getVar('type_description') . "' size='30' /></td>"; |
|
| 402 | - echo '</tr>'; |
|
| 403 | - } |
|
| 404 | - echo "<tr><td colspan='4' style='text-align:center;'>"; |
|
| 405 | - } else { |
|
| 406 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE, 'admin_type_manager.php?op=template', $icon = 'add'); |
|
| 407 | - $adminObject->addItemButton(_AM_NEWBB_TYPE_FORUM, 'admin_type_manager.php?op=forum', $icon = 'add'); |
|
| 408 | - $adminObject->displayButton('left'); |
|
| 409 | - for ($i = 0; $i < 10; ++$i) { |
|
| 410 | - echo "<tr class='odd' align='left'>"; |
|
| 411 | - echo "<td><input type='text' name='type_name[{$i}]' value='' size='10' /></td>"; |
|
| 412 | - if ($isColorpicker) { |
|
| 413 | - $form_colorpicker = new \XoopsFormColorPicker('', "type_color[{$i}]", ''); |
|
| 414 | - echo '<td>' . $form_colorpicker->render() . '</td>'; |
|
| 415 | - } else { |
|
| 416 | - echo "<td><input type='text' name='type_color[{$i}]' value='' size='10' /></td>"; |
|
| 417 | - } |
|
| 418 | - echo "<td><input type='text' name='type_description[{$i}]' value='' size='40' /></td>"; |
|
| 419 | - echo '</tr>'; |
|
| 420 | - } |
|
| 421 | - echo "<tr><td colspan='3' style='text-align:center;'>"; |
|
| 422 | - echo "<input type='hidden' name='isnew' value='1' />"; |
|
| 423 | - } |
|
| 424 | - echo "<input type='hidden' name='op' value='save_type' />"; |
|
| 425 | - echo "<input type='submit' name='submit' value='" . _SUBMIT . "' /> "; |
|
| 426 | - echo "<input type='reset' value='" . _CANCEL . "' />"; |
|
| 427 | - echo '</td></tr></table>'; |
|
| 428 | - echo '</form>'; |
|
| 429 | - echo '</td></tr></table>'; |
|
| 430 | - echo '<fieldset>'; |
|
| 431 | - echo '<legend> ' . _MI_NEWBB_ADMENU_TYPE . ' </legend>'; |
|
| 432 | - echo _AM_NEWBB_HELP_TYPE_TAB; |
|
| 433 | - echo '</fieldset>'; |
|
| 434 | - break; |
|
| 388 | + xoops_load('XoopsFormColorPicker'); |
|
| 389 | + |
|
| 390 | + if ('add' !== $op) { |
|
| 391 | + foreach ($typesObject as $key => $typeObject) { |
|
| 392 | + echo "<tr class='odd' align='left'>"; |
|
| 393 | + echo "<td><input type='checkbox' name='type_del[{$key}]' /></td>"; |
|
| 394 | + echo "<td><input type='text' name='type_name[{$key}]' value='" . $typeObject->getVar('type_name') . "' size='10' /></td>"; |
|
| 395 | + if ($isColorpicker) { |
|
| 396 | + $form_colorpicker = new \XoopsFormColorPicker('', "type_color[{$key}]", $typeObject->getVar('type_color')); |
|
| 397 | + echo '<td>' . $form_colorpicker->render() . '</td>'; |
|
| 398 | + } else { |
|
| 399 | + echo "<td><input type='text' name='type_color[{$key}]' value='" . $typeObject->getVar('type_color') . "' size='10' /></td>"; |
|
| 400 | + } |
|
| 401 | + echo "<td><input type='text' name='type_description[{$key}]' value='" . $typeObject->getVar('type_description') . "' size='30' /></td>"; |
|
| 402 | + echo '</tr>'; |
|
| 403 | + } |
|
| 404 | + echo "<tr><td colspan='4' style='text-align:center;'>"; |
|
| 405 | + } else { |
|
| 406 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_TEMPLATE, 'admin_type_manager.php?op=template', $icon = 'add'); |
|
| 407 | + $adminObject->addItemButton(_AM_NEWBB_TYPE_FORUM, 'admin_type_manager.php?op=forum', $icon = 'add'); |
|
| 408 | + $adminObject->displayButton('left'); |
|
| 409 | + for ($i = 0; $i < 10; ++$i) { |
|
| 410 | + echo "<tr class='odd' align='left'>"; |
|
| 411 | + echo "<td><input type='text' name='type_name[{$i}]' value='' size='10' /></td>"; |
|
| 412 | + if ($isColorpicker) { |
|
| 413 | + $form_colorpicker = new \XoopsFormColorPicker('', "type_color[{$i}]", ''); |
|
| 414 | + echo '<td>' . $form_colorpicker->render() . '</td>'; |
|
| 415 | + } else { |
|
| 416 | + echo "<td><input type='text' name='type_color[{$i}]' value='' size='10' /></td>"; |
|
| 417 | + } |
|
| 418 | + echo "<td><input type='text' name='type_description[{$i}]' value='' size='40' /></td>"; |
|
| 419 | + echo '</tr>'; |
|
| 420 | + } |
|
| 421 | + echo "<tr><td colspan='3' style='text-align:center;'>"; |
|
| 422 | + echo "<input type='hidden' name='isnew' value='1' />"; |
|
| 423 | + } |
|
| 424 | + echo "<input type='hidden' name='op' value='save_type' />"; |
|
| 425 | + echo "<input type='submit' name='submit' value='" . _SUBMIT . "' /> "; |
|
| 426 | + echo "<input type='reset' value='" . _CANCEL . "' />"; |
|
| 427 | + echo '</td></tr></table>'; |
|
| 428 | + echo '</form>'; |
|
| 429 | + echo '</td></tr></table>'; |
|
| 430 | + echo '<fieldset>'; |
|
| 431 | + echo '<legend> ' . _MI_NEWBB_ADMENU_TYPE . ' </legend>'; |
|
| 432 | + echo _AM_NEWBB_HELP_TYPE_TAB; |
|
| 433 | + echo '</fieldset>'; |
|
| 434 | + break; |
|
| 435 | 435 | } |
| 436 | 436 | |
| 437 | 437 | require_once __DIR__ . '/admin_footer.php'; |
@@ -39,84 +39,84 @@ |
||
| 39 | 39 | $pathModIcon32 = $helper->getModule()->getInfo('modicons32'); |
| 40 | 40 | |
| 41 | 41 | $adminmenu[] = [ |
| 42 | - 'title' => _MI_NEWBB_ADMENU_INDEX, |
|
| 43 | - 'link' => 'admin/index.php', |
|
| 44 | - 'icon' => $pathIcon32 . 'home.png' |
|
| 42 | + 'title' => _MI_NEWBB_ADMENU_INDEX, |
|
| 43 | + 'link' => 'admin/index.php', |
|
| 44 | + 'icon' => $pathIcon32 . 'home.png' |
|
| 45 | 45 | ]; |
| 46 | 46 | |
| 47 | 47 | $adminmenu[] = [ |
| 48 | - 'title' => _MI_NEWBB_ADMENU_CATEGORY, |
|
| 49 | - 'link' => 'admin/admin_cat_manager.php', |
|
| 50 | - 'icon' => $pathIcon32 . 'category.png' |
|
| 48 | + 'title' => _MI_NEWBB_ADMENU_CATEGORY, |
|
| 49 | + 'link' => 'admin/admin_cat_manager.php', |
|
| 50 | + 'icon' => $pathIcon32 . 'category.png' |
|
| 51 | 51 | ]; |
| 52 | 52 | |
| 53 | 53 | $adminmenu[] = [ |
| 54 | - 'title' => _MI_NEWBB_ADMENU_FORUM, |
|
| 55 | - 'link' => 'admin/admin_forum_manager.php', |
|
| 56 | - 'icon' => $pathIcon32 . 'forums.png' |
|
| 54 | + 'title' => _MI_NEWBB_ADMENU_FORUM, |
|
| 55 | + 'link' => 'admin/admin_forum_manager.php', |
|
| 56 | + 'icon' => $pathIcon32 . 'forums.png' |
|
| 57 | 57 | ]; |
| 58 | 58 | |
| 59 | 59 | $adminmenu[] = [ |
| 60 | - 'title' => _MI_NEWBB_ADMENU_PERMISSION, |
|
| 61 | - 'link' => 'admin/admin_permissions.php', |
|
| 62 | - 'icon' => $pathIcon32 . 'permissions.png' |
|
| 60 | + 'title' => _MI_NEWBB_ADMENU_PERMISSION, |
|
| 61 | + 'link' => 'admin/admin_permissions.php', |
|
| 62 | + 'icon' => $pathIcon32 . 'permissions.png' |
|
| 63 | 63 | ]; |
| 64 | 64 | |
| 65 | 65 | $adminmenu[] = [ |
| 66 | - 'title' => _MI_NEWBB_ADMENU_ORDER, |
|
| 67 | - 'link' => 'admin/admin_forum_reorder.php', |
|
| 68 | - 'icon' => $pathIcon32 . 'compfile.png' |
|
| 66 | + 'title' => _MI_NEWBB_ADMENU_ORDER, |
|
| 67 | + 'link' => 'admin/admin_forum_reorder.php', |
|
| 68 | + 'icon' => $pathIcon32 . 'compfile.png' |
|
| 69 | 69 | ]; |
| 70 | 70 | |
| 71 | 71 | $adminmenu[] = [ |
| 72 | - 'title' => _MI_NEWBB_ADMENU_PRUNE, |
|
| 73 | - 'link' => 'admin/admin_forum_prune.php', |
|
| 74 | - 'icon' => $pathIcon32 . 'update.png' |
|
| 72 | + 'title' => _MI_NEWBB_ADMENU_PRUNE, |
|
| 73 | + 'link' => 'admin/admin_forum_prune.php', |
|
| 74 | + 'icon' => $pathIcon32 . 'update.png' |
|
| 75 | 75 | ]; |
| 76 | 76 | |
| 77 | 77 | $adminmenu[] = [ |
| 78 | - 'title' => _MI_NEWBB_ADMENU_REPORT, |
|
| 79 | - 'link' => 'admin/admin_report.php', |
|
| 80 | - 'icon' => $pathIcon32 . 'content.png' |
|
| 78 | + 'title' => _MI_NEWBB_ADMENU_REPORT, |
|
| 79 | + 'link' => 'admin/admin_report.php', |
|
| 80 | + 'icon' => $pathIcon32 . 'content.png' |
|
| 81 | 81 | ]; |
| 82 | 82 | |
| 83 | 83 | $adminmenu[] = [ |
| 84 | - 'title' => _MI_NEWBB_ADMENU_DIGEST, |
|
| 85 | - 'link' => 'admin/admin_digest.php', |
|
| 86 | - 'icon' => $pathIcon32 . 'digest.png' |
|
| 84 | + 'title' => _MI_NEWBB_ADMENU_DIGEST, |
|
| 85 | + 'link' => 'admin/admin_digest.php', |
|
| 86 | + 'icon' => $pathIcon32 . 'digest.png' |
|
| 87 | 87 | ]; |
| 88 | 88 | |
| 89 | 89 | $adminmenu[] = [ |
| 90 | - 'title' => _MI_NEWBB_ADMENU_VOTE, |
|
| 91 | - 'link' => 'admin/admin_votedata.php', |
|
| 92 | - 'icon' => $pathIcon32 . 'button_ok.png' |
|
| 90 | + 'title' => _MI_NEWBB_ADMENU_VOTE, |
|
| 91 | + 'link' => 'admin/admin_votedata.php', |
|
| 92 | + 'icon' => $pathIcon32 . 'button_ok.png' |
|
| 93 | 93 | ]; |
| 94 | 94 | |
| 95 | 95 | $adminmenu[] = [ |
| 96 | - 'title' => _MI_NEWBB_ADMENU_TYPE, |
|
| 97 | - 'link' => 'admin/admin_type_manager.php', |
|
| 98 | - 'icon' => $pathIcon32 . 'type.png' |
|
| 96 | + 'title' => _MI_NEWBB_ADMENU_TYPE, |
|
| 97 | + 'link' => 'admin/admin_type_manager.php', |
|
| 98 | + 'icon' => $pathIcon32 . 'type.png' |
|
| 99 | 99 | ]; |
| 100 | 100 | |
| 101 | 101 | $adminmenu[] = [ |
| 102 | - 'title' => _MI_NEWBB_ADMENU_GROUPMOD, |
|
| 103 | - 'link' => 'admin/admin_groupmod.php', |
|
| 104 | - 'icon' => $pathIcon32 . 'groupmod.png' |
|
| 102 | + 'title' => _MI_NEWBB_ADMENU_GROUPMOD, |
|
| 103 | + 'link' => 'admin/admin_groupmod.php', |
|
| 104 | + 'icon' => $pathIcon32 . 'groupmod.png' |
|
| 105 | 105 | ]; |
| 106 | 106 | |
| 107 | 107 | $adminmenu[] = [ |
| 108 | - 'title' => _MI_NEWBB_ADMENU_SYNC, |
|
| 109 | - 'link' => 'admin/admin_synchronization.php', |
|
| 110 | - 'icon' => $pathIcon32 . 'synchronized.png' |
|
| 108 | + 'title' => _MI_NEWBB_ADMENU_SYNC, |
|
| 109 | + 'link' => 'admin/admin_synchronization.php', |
|
| 110 | + 'icon' => $pathIcon32 . 'synchronized.png' |
|
| 111 | 111 | ]; |
| 112 | 112 | |
| 113 | 113 | $adminmenu[] = [ |
| 114 | - 'title' => _MI_NEWBB_ADMENU_MIGRATE, |
|
| 115 | - 'link' => 'admin/migrate.php', |
|
| 116 | - 'icon' => $pathIcon32 . 'database_go.png' |
|
| 114 | + 'title' => _MI_NEWBB_ADMENU_MIGRATE, |
|
| 115 | + 'link' => 'admin/migrate.php', |
|
| 116 | + 'icon' => $pathIcon32 . 'database_go.png' |
|
| 117 | 117 | ]; |
| 118 | 118 | $adminmenu[] = [ |
| 119 | - 'title' => _MI_NEWBB_ADMENU_ABOUT, |
|
| 120 | - 'link' => 'admin/about.php', |
|
| 121 | - 'icon' => $pathIcon32 . 'about.png' |
|
| 119 | + 'title' => _MI_NEWBB_ADMENU_ABOUT, |
|
| 120 | + 'link' => 'admin/about.php', |
|
| 121 | + 'icon' => $pathIcon32 . 'about.png' |
|
| 122 | 122 | ]; |
@@ -49,10 +49,10 @@ discard block |
||
| 49 | 49 | */ |
| 50 | 50 | function newbb_admin_mkdir($target, $mode = 0777) |
| 51 | 51 | { |
| 52 | - $target = str_replace('..', '', $target); |
|
| 52 | + $target = str_replace('..', '', $target); |
|
| 53 | 53 | |
| 54 | - // http://www.php.net/manual/en/function.mkdir.php |
|
| 55 | - return is_dir($target) || (newbb_admin_mkdir(dirname($target), $mode) && (!mkdir($target, $mode) && !is_dir($target))); |
|
| 54 | + // http://www.php.net/manual/en/function.mkdir.php |
|
| 55 | + return is_dir($target) || (newbb_admin_mkdir(dirname($target), $mode) && (!mkdir($target, $mode) && !is_dir($target))); |
|
| 56 | 56 | } |
| 57 | 57 | |
| 58 | 58 | /** |
@@ -62,9 +62,9 @@ discard block |
||
| 62 | 62 | */ |
| 63 | 63 | function newbb_admin_chmod($target, $mode = 0777) |
| 64 | 64 | { |
| 65 | - $target = str_replace('..', '', $target); |
|
| 65 | + $target = str_replace('..', '', $target); |
|
| 66 | 66 | |
| 67 | - return @chmod($target, $mode); |
|
| 67 | + return @chmod($target, $mode); |
|
| 68 | 68 | } |
| 69 | 69 | |
| 70 | 70 | /** |
@@ -72,32 +72,32 @@ discard block |
||
| 72 | 72 | */ |
| 73 | 73 | function newbb_getImageLibs() |
| 74 | 74 | { |
| 75 | - $imageLibs = []; |
|
| 76 | - unset($output, $status); |
|
| 77 | - if (1 == $GLOBALS['xoopsModuleConfig']['image_lib'] || 0 == $GLOBALS['xoopsModuleConfig']['image_lib']) { |
|
| 78 | - $path = empty($GLOBALS['xoopsModuleConfig']['path_magick']) ? '' : $GLOBALS['xoopsModuleConfig']['path_magick'] . '/'; |
|
| 79 | - @exec($path . 'convert -version', $output, $status); |
|
| 80 | - if (empty($status) && !empty($output) && preg_match("/imagemagick[ \t]+([0-9\.]+)/i", $output[0], $matches)) { |
|
| 81 | - $imageLibs['imagemagick'] = $matches[0]; |
|
| 82 | - } |
|
| 83 | - |
|
| 84 | - unset($output, $status); |
|
| 85 | - } |
|
| 86 | - if (2 == $GLOBALS['xoopsModuleConfig']['image_lib'] || 0 == $GLOBALS['xoopsModuleConfig']['image_lib']) { |
|
| 87 | - $path = empty($GLOBALS['xoopsModuleConfig']['path_netpbm']) ? '' : $GLOBALS['xoopsModuleConfig']['path_netpbm'] . '/'; |
|
| 88 | - @exec($path . 'jpegtopnm -version 2>&1', $output, $status); |
|
| 89 | - if (empty($status) && !empty($output) && preg_match("/netpbm[ \t]+([0-9\.]+)/i", $output[0], $matches)) { |
|
| 90 | - $imageLibs['netpbm'] = $matches[0]; |
|
| 91 | - } |
|
| 92 | - unset($output, $status); |
|
| 93 | - } |
|
| 94 | - |
|
| 95 | - if (function_exists('gd_info')) { |
|
| 96 | - $tmpInfo = gd_info(); |
|
| 97 | - $imageLibs['gd'] = $tmpInfo['GD Version']; |
|
| 98 | - } |
|
| 99 | - |
|
| 100 | - return $imageLibs; |
|
| 75 | + $imageLibs = []; |
|
| 76 | + unset($output, $status); |
|
| 77 | + if (1 == $GLOBALS['xoopsModuleConfig']['image_lib'] || 0 == $GLOBALS['xoopsModuleConfig']['image_lib']) { |
|
| 78 | + $path = empty($GLOBALS['xoopsModuleConfig']['path_magick']) ? '' : $GLOBALS['xoopsModuleConfig']['path_magick'] . '/'; |
|
| 79 | + @exec($path . 'convert -version', $output, $status); |
|
| 80 | + if (empty($status) && !empty($output) && preg_match("/imagemagick[ \t]+([0-9\.]+)/i", $output[0], $matches)) { |
|
| 81 | + $imageLibs['imagemagick'] = $matches[0]; |
|
| 82 | + } |
|
| 83 | + |
|
| 84 | + unset($output, $status); |
|
| 85 | + } |
|
| 86 | + if (2 == $GLOBALS['xoopsModuleConfig']['image_lib'] || 0 == $GLOBALS['xoopsModuleConfig']['image_lib']) { |
|
| 87 | + $path = empty($GLOBALS['xoopsModuleConfig']['path_netpbm']) ? '' : $GLOBALS['xoopsModuleConfig']['path_netpbm'] . '/'; |
|
| 88 | + @exec($path . 'jpegtopnm -version 2>&1', $output, $status); |
|
| 89 | + if (empty($status) && !empty($output) && preg_match("/netpbm[ \t]+([0-9\.]+)/i", $output[0], $matches)) { |
|
| 90 | + $imageLibs['netpbm'] = $matches[0]; |
|
| 91 | + } |
|
| 92 | + unset($output, $status); |
|
| 93 | + } |
|
| 94 | + |
|
| 95 | + if (function_exists('gd_info')) { |
|
| 96 | + $tmpInfo = gd_info(); |
|
| 97 | + $imageLibs['gd'] = $tmpInfo['GD Version']; |
|
| 98 | + } |
|
| 99 | + |
|
| 100 | + return $imageLibs; |
|
| 101 | 101 | } |
| 102 | 102 | |
| 103 | 103 | xoops_cp_header(); |
@@ -113,7 +113,7 @@ discard block |
||
| 113 | 113 | //XOOPS_POLL |
| 114 | 114 | $xoopspoll = $moduleHandler->getByDirname($GLOBALS['xoopsModuleConfig']['poll_module']); |
| 115 | 115 | if (is_object($xoopspoll)) { |
| 116 | - $isOK = $xoopspoll->getVar('isactive'); |
|
| 116 | + $isOK = $xoopspoll->getVar('isactive'); |
|
| 117 | 117 | } |
| 118 | 118 | // END irmtfan add a poll_module config |
| 119 | 119 | |
@@ -121,19 +121,19 @@ discard block |
||
| 121 | 121 | $postmaxsize_iniphp = return_bytes(@ini_get('post_max_size')); |
| 122 | 122 | $uploadlimit = _AM_NEWBB_MEMLIMITTOLARGE; |
| 123 | 123 | if ($postmaxsize_iniphp < $memlimit_iniphp) { |
| 124 | - $uploadlimit = sprintf(_AM_NEWBB_MEMLIMITOK, return_bytes($postmaxsize_iniphp, true)); |
|
| 124 | + $uploadlimit = sprintf(_AM_NEWBB_MEMLIMITOK, return_bytes($postmaxsize_iniphp, true)); |
|
| 125 | 125 | } |
| 126 | 126 | |
| 127 | 127 | $adminObject->addInfoBox(_AM_NEWBB_PREFERENCES); |
| 128 | 128 | // START irmtfan better poll module display link and version - check if xoops poll module is available |
| 129 | 129 | if ($isOK) { |
| 130 | - $pollLink = _AM_NEWBB_AVAILABLE . ': '; |
|
| 131 | - $pollLink .= '<a href="' . XOOPS_URL . '/modules/' . $xoopspoll->getVar('dirname') . '/admin/index.php"'; |
|
| 132 | - $pollLink .= ' alt="' . $xoopspoll->getVar('name') . ' ' . _VERSION . ' (' . $xoopspoll->getInfo('version') . ') "'; |
|
| 133 | - $pollLink .= ' title="' . $xoopspoll->getVar('name') . ' ' . _VERSION . ' (' . $xoopspoll->getInfo('version') . ') "'; |
|
| 134 | - $pollLink .= '>' . '(' . $xoopspoll->getVar('name') . ')</a>'; |
|
| 130 | + $pollLink = _AM_NEWBB_AVAILABLE . ': '; |
|
| 131 | + $pollLink .= '<a href="' . XOOPS_URL . '/modules/' . $xoopspoll->getVar('dirname') . '/admin/index.php"'; |
|
| 132 | + $pollLink .= ' alt="' . $xoopspoll->getVar('name') . ' ' . _VERSION . ' (' . $xoopspoll->getInfo('version') . ') "'; |
|
| 133 | + $pollLink .= ' title="' . $xoopspoll->getVar('name') . ' ' . _VERSION . ' (' . $xoopspoll->getInfo('version') . ') "'; |
|
| 134 | + $pollLink .= '>' . '(' . $xoopspoll->getVar('name') . ')</a>'; |
|
| 135 | 135 | } else { |
| 136 | - $pollLink = _AM_NEWBB_NOTAVAILABLE; |
|
| 136 | + $pollLink = _AM_NEWBB_NOTAVAILABLE; |
|
| 137 | 137 | } |
| 138 | 138 | $adminObject->addInfoBoxLine(sprintf(_AM_NEWBB_POLLMODULE . ': %s', $pollLink)); |
| 139 | 139 | // END irmtfan better poll module display link and version - check if xoops poll module is available |
@@ -153,8 +153,8 @@ discard block |
||
| 153 | 153 | $adminObject->addInfoBoxLine(sprintf(_AM_NEWBB_REPORT_PROCESSED . ': %s', $reportHandler->getCount(new \Criteria('report_result', 1)))); |
| 154 | 154 | |
| 155 | 155 | foreach (array_keys($GLOBALS['uploadFolders']) as $i) { |
| 156 | - Newbb\Utility::prepareFolder($uploadFolders[$i]); |
|
| 157 | - $adminObject->addConfigBoxLine($uploadFolders[$i], 'folder'); |
|
| 156 | + Newbb\Utility::prepareFolder($uploadFolders[$i]); |
|
| 157 | + $adminObject->addConfigBoxLine($uploadFolders[$i], 'folder'); |
|
| 158 | 158 | } |
| 159 | 159 | |
| 160 | 160 | $adminObject->displayNavigation(basename(__FILE__)); |
@@ -174,24 +174,24 @@ discard block |
||
| 174 | 174 | */ |
| 175 | 175 | function return_bytes($sizeAsString, $b = false) |
| 176 | 176 | { |
| 177 | - if (false === $b) { |
|
| 178 | - switch (substr($sizeAsString, -1)) { |
|
| 179 | - case 'M': |
|
| 180 | - case 'm': |
|
| 181 | - return (int)$sizeAsString * 1048576; |
|
| 182 | - case 'K': |
|
| 183 | - case 'k': |
|
| 184 | - return (int)$sizeAsString * 1024; |
|
| 185 | - case 'G': |
|
| 186 | - case 'g': |
|
| 187 | - return (int)$sizeAsString * 1073741824; |
|
| 188 | - default: |
|
| 189 | - return $sizeAsString; |
|
| 190 | - } |
|
| 191 | - } else { |
|
| 192 | - $base = log($sizeAsString) / log(1024); |
|
| 193 | - $suffix = ['', 'KB', 'MB', 'GB', 'TB']; |
|
| 194 | - |
|
| 195 | - return round(1024 ** ($base - floor($base))) . ' ' . $suffix[(int)floor($base)]; |
|
| 196 | - } |
|
| 177 | + if (false === $b) { |
|
| 178 | + switch (substr($sizeAsString, -1)) { |
|
| 179 | + case 'M': |
|
| 180 | + case 'm': |
|
| 181 | + return (int)$sizeAsString * 1048576; |
|
| 182 | + case 'K': |
|
| 183 | + case 'k': |
|
| 184 | + return (int)$sizeAsString * 1024; |
|
| 185 | + case 'G': |
|
| 186 | + case 'g': |
|
| 187 | + return (int)$sizeAsString * 1073741824; |
|
| 188 | + default: |
|
| 189 | + return $sizeAsString; |
|
| 190 | + } |
|
| 191 | + } else { |
|
| 192 | + $base = log($sizeAsString) / log(1024); |
|
| 193 | + $suffix = ['', 'KB', 'MB', 'GB', 'TB']; |
|
| 194 | + |
|
| 195 | + return round(1024 ** ($base - floor($base))) . ' ' . $suffix[(int)floor($base)]; |
|
| 196 | + } |
|
| 197 | 197 | } |
@@ -31,49 +31,49 @@ |
||
| 31 | 31 | */ |
| 32 | 32 | class Breadcrumb |
| 33 | 33 | { |
| 34 | - /** @var string */ |
|
| 35 | - private $dirname; |
|
| 34 | + /** @var string */ |
|
| 35 | + private $dirname; |
|
| 36 | 36 | |
| 37 | - /** @var array */ |
|
| 38 | - private $bread = []; |
|
| 37 | + /** @var array */ |
|
| 38 | + private $bread = []; |
|
| 39 | 39 | |
| 40 | - public function __construct() |
|
| 41 | - { |
|
| 42 | - $this->dirname = basename(dirname(dirname(__DIR__))); |
|
| 43 | - } |
|
| 40 | + public function __construct() |
|
| 41 | + { |
|
| 42 | + $this->dirname = basename(dirname(dirname(__DIR__))); |
|
| 43 | + } |
|
| 44 | 44 | |
| 45 | - /** |
|
| 46 | - * Add link to breadcrumb |
|
| 47 | - * |
|
| 48 | - * @param string $title |
|
| 49 | - * @param string $link |
|
| 50 | - */ |
|
| 51 | - public function addLink($title = '', $link = '') |
|
| 52 | - { |
|
| 53 | - $this->bread[] = [ |
|
| 54 | - 'link' => $link, |
|
| 55 | - 'title' => $title |
|
| 56 | - ]; |
|
| 57 | - } |
|
| 45 | + /** |
|
| 46 | + * Add link to breadcrumb |
|
| 47 | + * |
|
| 48 | + * @param string $title |
|
| 49 | + * @param string $link |
|
| 50 | + */ |
|
| 51 | + public function addLink($title = '', $link = '') |
|
| 52 | + { |
|
| 53 | + $this->bread[] = [ |
|
| 54 | + 'link' => $link, |
|
| 55 | + 'title' => $title |
|
| 56 | + ]; |
|
| 57 | + } |
|
| 58 | 58 | |
| 59 | - /** |
|
| 60 | - * Render Pedigree BreadCrumb |
|
| 61 | - * |
|
| 62 | - * @return string |
|
| 63 | - */ |
|
| 64 | - public function render() |
|
| 65 | - { |
|
| 66 | - if (!isset($GLOBALS['xoTheme']) || !is_object($GLOBALS['xoTheme'])) { |
|
| 67 | - require_once $GLOBALS['xoops']->path('class/theme.php'); |
|
| 68 | - $GLOBALS['xoTheme'] = new \xos_opal_Theme(); |
|
| 69 | - } |
|
| 59 | + /** |
|
| 60 | + * Render Pedigree BreadCrumb |
|
| 61 | + * |
|
| 62 | + * @return string |
|
| 63 | + */ |
|
| 64 | + public function render() |
|
| 65 | + { |
|
| 66 | + if (!isset($GLOBALS['xoTheme']) || !is_object($GLOBALS['xoTheme'])) { |
|
| 67 | + require_once $GLOBALS['xoops']->path('class/theme.php'); |
|
| 68 | + $GLOBALS['xoTheme'] = new \xos_opal_Theme(); |
|
| 69 | + } |
|
| 70 | 70 | |
| 71 | - require_once $GLOBALS['xoops']->path('class/template.php'); |
|
| 72 | - $breadcrumbTpl = new \XoopsTpl(); |
|
| 73 | - $breadcrumbTpl->assign('breadcrumb', $this->bread); |
|
| 74 | - $html = $breadcrumbTpl->fetch('db:' . $this->dirname . '_common_breadcrumb.tpl'); |
|
| 75 | - unset($breadcrumbTpl); |
|
| 71 | + require_once $GLOBALS['xoops']->path('class/template.php'); |
|
| 72 | + $breadcrumbTpl = new \XoopsTpl(); |
|
| 73 | + $breadcrumbTpl->assign('breadcrumb', $this->bread); |
|
| 74 | + $html = $breadcrumbTpl->fetch('db:' . $this->dirname . '_common_breadcrumb.tpl'); |
|
| 75 | + unset($breadcrumbTpl); |
|
| 76 | 76 | |
| 77 | - return $html; |
|
| 78 | - } |
|
| 77 | + return $html; |
|
| 78 | + } |
|
| 79 | 79 | } |
@@ -27,35 +27,35 @@ |
||
| 27 | 27 | */ |
| 28 | 28 | class Configurator |
| 29 | 29 | { |
| 30 | - public $name; |
|
| 31 | - public $paths = []; |
|
| 32 | - public $uploadFolders = []; |
|
| 33 | - public $copyBlankFiles = []; |
|
| 34 | - public $copyTestFolders = []; |
|
| 35 | - public $templateFolders = []; |
|
| 36 | - public $oldFiles = []; |
|
| 37 | - public $oldFolders = []; |
|
| 38 | - public $modCopyright; |
|
| 30 | + public $name; |
|
| 31 | + public $paths = []; |
|
| 32 | + public $uploadFolders = []; |
|
| 33 | + public $copyBlankFiles = []; |
|
| 34 | + public $copyTestFolders = []; |
|
| 35 | + public $templateFolders = []; |
|
| 36 | + public $oldFiles = []; |
|
| 37 | + public $oldFolders = []; |
|
| 38 | + public $modCopyright; |
|
| 39 | 39 | |
| 40 | - /** |
|
| 41 | - * Configurator constructor. |
|
| 42 | - */ |
|
| 43 | - public function __construct() |
|
| 44 | - { |
|
| 45 | - $moduleDirName = basename(dirname(dirname(__DIR__))); |
|
| 46 | - $capsDirName = strtoupper($moduleDirName); |
|
| 40 | + /** |
|
| 41 | + * Configurator constructor. |
|
| 42 | + */ |
|
| 43 | + public function __construct() |
|
| 44 | + { |
|
| 45 | + $moduleDirName = basename(dirname(dirname(__DIR__))); |
|
| 46 | + $capsDirName = strtoupper($moduleDirName); |
|
| 47 | 47 | |
| 48 | - require_once dirname(dirname(__DIR__)) . '/include/config.php'; |
|
| 49 | - $config = getConfig(); |
|
| 48 | + require_once dirname(dirname(__DIR__)) . '/include/config.php'; |
|
| 49 | + $config = getConfig(); |
|
| 50 | 50 | |
| 51 | - $this->name = $config->name; |
|
| 52 | - $this->paths = $config->paths; |
|
| 53 | - $this->uploadFolders = $config->uploadFolders; |
|
| 54 | - $this->copyBlankFiles = $config->copyBlankFiles; |
|
| 55 | - $this->copyTestFolders = $config->copyTestFolders; |
|
| 56 | - $this->templateFolders = $config->templateFolders; |
|
| 57 | - $this->oldFiles = $config->oldFiles; |
|
| 58 | - $this->oldFolders = $config->oldFolders; |
|
| 59 | - $this->modCopyright = $config->modCopyright; |
|
| 60 | - } |
|
| 51 | + $this->name = $config->name; |
|
| 52 | + $this->paths = $config->paths; |
|
| 53 | + $this->uploadFolders = $config->uploadFolders; |
|
| 54 | + $this->copyBlankFiles = $config->copyBlankFiles; |
|
| 55 | + $this->copyTestFolders = $config->copyTestFolders; |
|
| 56 | + $this->templateFolders = $config->templateFolders; |
|
| 57 | + $this->oldFiles = $config->oldFiles; |
|
| 58 | + $this->oldFolders = $config->oldFolders; |
|
| 59 | + $this->modCopyright = $config->modCopyright; |
|
| 60 | + } |
|
| 61 | 61 | } |
@@ -17,63 +17,63 @@ |
||
| 17 | 17 | */ |
| 18 | 18 | trait VersionChecks |
| 19 | 19 | { |
| 20 | - /** |
|
| 21 | - * |
|
| 22 | - * Verifies XOOPS version meets minimum requirements for this module |
|
| 23 | - * @static |
|
| 24 | - * @param \XoopsModule $module |
|
| 25 | - * |
|
| 26 | - * @param null|string $requiredVer |
|
| 27 | - * @return bool true if meets requirements, false if not |
|
| 28 | - */ |
|
| 29 | - public static function checkVerXoops(\XoopsModule $module = null, $requiredVer = null) |
|
| 30 | - { |
|
| 31 | - $moduleDirName = basename(dirname(dirname(__DIR__))); |
|
| 32 | - $moduleDirNameUpper = strtoupper($moduleDirName); |
|
| 33 | - if (null === $module) { |
|
| 34 | - $module = \XoopsModule::getByDirname($moduleDirName); |
|
| 35 | - } |
|
| 36 | - xoops_loadLanguage('admin', $moduleDirName); |
|
| 20 | + /** |
|
| 21 | + * |
|
| 22 | + * Verifies XOOPS version meets minimum requirements for this module |
|
| 23 | + * @static |
|
| 24 | + * @param \XoopsModule $module |
|
| 25 | + * |
|
| 26 | + * @param null|string $requiredVer |
|
| 27 | + * @return bool true if meets requirements, false if not |
|
| 28 | + */ |
|
| 29 | + public static function checkVerXoops(\XoopsModule $module = null, $requiredVer = null) |
|
| 30 | + { |
|
| 31 | + $moduleDirName = basename(dirname(dirname(__DIR__))); |
|
| 32 | + $moduleDirNameUpper = strtoupper($moduleDirName); |
|
| 33 | + if (null === $module) { |
|
| 34 | + $module = \XoopsModule::getByDirname($moduleDirName); |
|
| 35 | + } |
|
| 36 | + xoops_loadLanguage('admin', $moduleDirName); |
|
| 37 | 37 | |
| 38 | - //check for minimum XOOPS version |
|
| 39 | - $currentVer = substr(XOOPS_VERSION, 6); // get the numeric part of string |
|
| 40 | - if (null === $requiredVer) { |
|
| 41 | - $requiredVer = '' . $module->getInfo('min_xoops'); //making sure it's a string |
|
| 42 | - } |
|
| 43 | - $success = true; |
|
| 38 | + //check for minimum XOOPS version |
|
| 39 | + $currentVer = substr(XOOPS_VERSION, 6); // get the numeric part of string |
|
| 40 | + if (null === $requiredVer) { |
|
| 41 | + $requiredVer = '' . $module->getInfo('min_xoops'); //making sure it's a string |
|
| 42 | + } |
|
| 43 | + $success = true; |
|
| 44 | 44 | |
| 45 | - if (version_compare($currentVer, $requiredVer, '<')) { |
|
| 46 | - $success = false; |
|
| 47 | - $module->setErrors(sprintf(constant('CO_' . $moduleDirNameUpper . '_ERROR_BAD_XOOPS'), $requiredVer, $currentVer)); |
|
| 48 | - } |
|
| 45 | + if (version_compare($currentVer, $requiredVer, '<')) { |
|
| 46 | + $success = false; |
|
| 47 | + $module->setErrors(sprintf(constant('CO_' . $moduleDirNameUpper . '_ERROR_BAD_XOOPS'), $requiredVer, $currentVer)); |
|
| 48 | + } |
|
| 49 | 49 | |
| 50 | - return $success; |
|
| 51 | - } |
|
| 50 | + return $success; |
|
| 51 | + } |
|
| 52 | 52 | |
| 53 | - /** |
|
| 54 | - * |
|
| 55 | - * Verifies PHP version meets minimum requirements for this module |
|
| 56 | - * @static |
|
| 57 | - * @param \XoopsModule $module |
|
| 58 | - * |
|
| 59 | - * @return bool true if meets requirements, false if not |
|
| 60 | - */ |
|
| 61 | - public static function checkVerPhp(\XoopsModule $module) |
|
| 62 | - { |
|
| 63 | - $moduleDirName = basename(dirname(dirname(__DIR__))); |
|
| 64 | - $moduleDirNameUpper = strtoupper($moduleDirName); |
|
| 65 | - xoops_loadLanguage('admin', $module->dirname()); |
|
| 66 | - // check for minimum PHP version |
|
| 67 | - $success = true; |
|
| 68 | - $verNum = PHP_VERSION; |
|
| 69 | - $reqVer = $module->getInfo('min_php'); |
|
| 70 | - if (false !== $reqVer && '' !== $reqVer) { |
|
| 71 | - if (version_compare($verNum, $reqVer, '<')) { |
|
| 72 | - $module->setErrors(sprintf(constant('CO_' . $moduleDirNameUpper . '_ERROR_BAD_PHP'), $reqVer, $verNum)); |
|
| 73 | - $success = false; |
|
| 74 | - } |
|
| 75 | - } |
|
| 53 | + /** |
|
| 54 | + * |
|
| 55 | + * Verifies PHP version meets minimum requirements for this module |
|
| 56 | + * @static |
|
| 57 | + * @param \XoopsModule $module |
|
| 58 | + * |
|
| 59 | + * @return bool true if meets requirements, false if not |
|
| 60 | + */ |
|
| 61 | + public static function checkVerPhp(\XoopsModule $module) |
|
| 62 | + { |
|
| 63 | + $moduleDirName = basename(dirname(dirname(__DIR__))); |
|
| 64 | + $moduleDirNameUpper = strtoupper($moduleDirName); |
|
| 65 | + xoops_loadLanguage('admin', $module->dirname()); |
|
| 66 | + // check for minimum PHP version |
|
| 67 | + $success = true; |
|
| 68 | + $verNum = PHP_VERSION; |
|
| 69 | + $reqVer = $module->getInfo('min_php'); |
|
| 70 | + if (false !== $reqVer && '' !== $reqVer) { |
|
| 71 | + if (version_compare($verNum, $reqVer, '<')) { |
|
| 72 | + $module->setErrors(sprintf(constant('CO_' . $moduleDirNameUpper . '_ERROR_BAD_PHP'), $reqVer, $verNum)); |
|
| 73 | + $success = false; |
|
| 74 | + } |
|
| 75 | + } |
|
| 76 | 76 | |
| 77 | - return $success; |
|
| 78 | - } |
|
| 77 | + return $success; |
|
| 78 | + } |
|
| 79 | 79 | } |
@@ -22,96 +22,96 @@ |
||
| 22 | 22 | */ |
| 23 | 23 | class Migrate extends \Xmf\Database\Migrate |
| 24 | 24 | { |
| 25 | - private $renameTables; |
|
| 25 | + private $renameTables; |
|
| 26 | 26 | |
| 27 | - /** |
|
| 28 | - * Migrate constructor. |
|
| 29 | - * @throws \RuntimeException |
|
| 30 | - * @throws \InvalidArgumentException |
|
| 31 | - */ |
|
| 32 | - public function __construct() |
|
| 33 | - { require_once dirname(dirname(__DIR__)) . '/include/config.php'; |
|
| 34 | - $config = getConfig(); |
|
| 35 | - $this->renameTables = $config->renameTables; |
|
| 27 | + /** |
|
| 28 | + * Migrate constructor. |
|
| 29 | + * @throws \RuntimeException |
|
| 30 | + * @throws \InvalidArgumentException |
|
| 31 | + */ |
|
| 32 | + public function __construct() |
|
| 33 | + { require_once dirname(dirname(__DIR__)) . '/include/config.php'; |
|
| 34 | + $config = getConfig(); |
|
| 35 | + $this->renameTables = $config->renameTables; |
|
| 36 | 36 | |
| 37 | - $moduleDirName = basename(dirname(dirname(__DIR__))); |
|
| 38 | - parent::__construct($moduleDirName); |
|
| 39 | - } |
|
| 37 | + $moduleDirName = basename(dirname(dirname(__DIR__))); |
|
| 38 | + parent::__construct($moduleDirName); |
|
| 39 | + } |
|
| 40 | 40 | |
| 41 | - /** |
|
| 42 | - * change table prefix if needed |
|
| 43 | - */ |
|
| 44 | - private function changePrefix() |
|
| 45 | - { |
|
| 46 | - foreach ($this->renameTables as $oldName => $newName) { |
|
| 47 | - if ($this->tableHandler->useTable($oldName)) { |
|
| 48 | - $this->tableHandler->renameTable($oldName, $newName); |
|
| 49 | - } |
|
| 50 | - } |
|
| 51 | - } |
|
| 41 | + /** |
|
| 42 | + * change table prefix if needed |
|
| 43 | + */ |
|
| 44 | + private function changePrefix() |
|
| 45 | + { |
|
| 46 | + foreach ($this->renameTables as $oldName => $newName) { |
|
| 47 | + if ($this->tableHandler->useTable($oldName)) { |
|
| 48 | + $this->tableHandler->renameTable($oldName, $newName); |
|
| 49 | + } |
|
| 50 | + } |
|
| 51 | + } |
|
| 52 | 52 | |
| 53 | - /** |
|
| 54 | - * Change integer IPv4 column to varchar IPv6 capable |
|
| 55 | - * |
|
| 56 | - * @param string $tableName table to convert |
|
| 57 | - * @param string $columnName column with IP address |
|
| 58 | - * |
|
| 59 | - * @return void |
|
| 60 | - */ |
|
| 61 | - private function convertIPAddresses($tableName, $columnName) |
|
| 62 | - { |
|
| 63 | - if ($this->tableHandler->useTable($tableName)) { |
|
| 64 | - $attributes = $this->tableHandler->getColumnAttributes($tableName, $columnName); |
|
| 65 | - if (false !== strpos($attributes, ' int(')) { |
|
| 66 | - if (false === strpos($attributes, 'unsigned')) { |
|
| 67 | - $this->tableHandler->alterColumn($tableName, $columnName, " bigint(16) NOT NULL DEFAULT '0' "); |
|
| 68 | - $this->tableHandler->update($tableName, [$columnName => "4294967296 + $columnName"], "WHERE $columnName < 0", false); |
|
| 69 | - } |
|
| 70 | - $this->tableHandler->alterColumn($tableName, $columnName, " varchar(45) NOT NULL DEFAULT '' "); |
|
| 71 | - $this->tableHandler->update($tableName, [$columnName => "INET_NTOA($columnName)"], '', false); |
|
| 72 | - } |
|
| 73 | - } |
|
| 74 | - } |
|
| 53 | + /** |
|
| 54 | + * Change integer IPv4 column to varchar IPv6 capable |
|
| 55 | + * |
|
| 56 | + * @param string $tableName table to convert |
|
| 57 | + * @param string $columnName column with IP address |
|
| 58 | + * |
|
| 59 | + * @return void |
|
| 60 | + */ |
|
| 61 | + private function convertIPAddresses($tableName, $columnName) |
|
| 62 | + { |
|
| 63 | + if ($this->tableHandler->useTable($tableName)) { |
|
| 64 | + $attributes = $this->tableHandler->getColumnAttributes($tableName, $columnName); |
|
| 65 | + if (false !== strpos($attributes, ' int(')) { |
|
| 66 | + if (false === strpos($attributes, 'unsigned')) { |
|
| 67 | + $this->tableHandler->alterColumn($tableName, $columnName, " bigint(16) NOT NULL DEFAULT '0' "); |
|
| 68 | + $this->tableHandler->update($tableName, [$columnName => "4294967296 + $columnName"], "WHERE $columnName < 0", false); |
|
| 69 | + } |
|
| 70 | + $this->tableHandler->alterColumn($tableName, $columnName, " varchar(45) NOT NULL DEFAULT '' "); |
|
| 71 | + $this->tableHandler->update($tableName, [$columnName => "INET_NTOA($columnName)"], '', false); |
|
| 72 | + } |
|
| 73 | + } |
|
| 74 | + } |
|
| 75 | 75 | |
| 76 | - /** |
|
| 77 | - * Move do* columns from newbb_posts to newbb_posts_text table |
|
| 78 | - * |
|
| 79 | - * @return void |
|
| 80 | - */ |
|
| 81 | - private function moveDoColumns() |
|
| 82 | - { |
|
| 83 | - $tableName = 'newbb_posts_text'; |
|
| 84 | - $srcTableName = 'newbb_posts'; |
|
| 85 | - if (false !== $this->tableHandler->useTable($tableName) |
|
| 86 | - && false !== $this->tableHandler->useTable($srcTableName)) { |
|
| 87 | - $attributes = $this->tableHandler->getColumnAttributes($tableName, 'dohtml'); |
|
| 88 | - if (false === $attributes) { |
|
| 89 | - $this->synchronizeTable($tableName); |
|
| 90 | - $updateTable = $GLOBALS['xoopsDB']->prefix($tableName); |
|
| 91 | - $joinTable = $GLOBALS['xoopsDB']->prefix($srcTableName); |
|
| 92 | - $sql = "UPDATE `$updateTable` t1 INNER JOIN `$joinTable` t2 ON t1.post_id = t2.post_id \n" . "SET t1.dohtml = t2.dohtml, t1.dosmiley = t2.dosmiley, t1.doxcode = t2.doxcode\n" . ' , t1.doimage = t2.doimage, t1.dobr = t2.dobr'; |
|
| 93 | - $this->tableHandler->addToQueue($sql); |
|
| 94 | - } |
|
| 95 | - } |
|
| 96 | - } |
|
| 76 | + /** |
|
| 77 | + * Move do* columns from newbb_posts to newbb_posts_text table |
|
| 78 | + * |
|
| 79 | + * @return void |
|
| 80 | + */ |
|
| 81 | + private function moveDoColumns() |
|
| 82 | + { |
|
| 83 | + $tableName = 'newbb_posts_text'; |
|
| 84 | + $srcTableName = 'newbb_posts'; |
|
| 85 | + if (false !== $this->tableHandler->useTable($tableName) |
|
| 86 | + && false !== $this->tableHandler->useTable($srcTableName)) { |
|
| 87 | + $attributes = $this->tableHandler->getColumnAttributes($tableName, 'dohtml'); |
|
| 88 | + if (false === $attributes) { |
|
| 89 | + $this->synchronizeTable($tableName); |
|
| 90 | + $updateTable = $GLOBALS['xoopsDB']->prefix($tableName); |
|
| 91 | + $joinTable = $GLOBALS['xoopsDB']->prefix($srcTableName); |
|
| 92 | + $sql = "UPDATE `$updateTable` t1 INNER JOIN `$joinTable` t2 ON t1.post_id = t2.post_id \n" . "SET t1.dohtml = t2.dohtml, t1.dosmiley = t2.dosmiley, t1.doxcode = t2.doxcode\n" . ' , t1.doimage = t2.doimage, t1.dobr = t2.dobr'; |
|
| 93 | + $this->tableHandler->addToQueue($sql); |
|
| 94 | + } |
|
| 95 | + } |
|
| 96 | + } |
|
| 97 | 97 | |
| 98 | - /** |
|
| 99 | - * Perform any upfront actions before synchronizing the schema |
|
| 100 | - * |
|
| 101 | - * Some typical uses include |
|
| 102 | - * table and column renames |
|
| 103 | - * data conversions |
|
| 104 | - * |
|
| 105 | - * @return void |
|
| 106 | - */ |
|
| 107 | - protected function preSyncActions() |
|
| 108 | - { |
|
| 109 | - // change 'bb' table prefix to 'newbb' |
|
| 110 | - $this->changePrefix(); |
|
| 111 | - // columns dohtml, dosmiley, doxcode, doimage and dobr moved between tables as some point |
|
| 112 | - $this->moveDoColumns(); |
|
| 113 | - // Convert IP address columns from int to readable varchar(45) for IPv6 |
|
| 114 | - $this->convertIPAddresses('newbb_posts', 'poster_ip'); |
|
| 115 | - $this->convertIPAddresses('newbb_report', 'reporter_ip'); |
|
| 116 | - } |
|
| 98 | + /** |
|
| 99 | + * Perform any upfront actions before synchronizing the schema |
|
| 100 | + * |
|
| 101 | + * Some typical uses include |
|
| 102 | + * table and column renames |
|
| 103 | + * data conversions |
|
| 104 | + * |
|
| 105 | + * @return void |
|
| 106 | + */ |
|
| 107 | + protected function preSyncActions() |
|
| 108 | + { |
|
| 109 | + // change 'bb' table prefix to 'newbb' |
|
| 110 | + $this->changePrefix(); |
|
| 111 | + // columns dohtml, dosmiley, doxcode, doimage and dobr moved between tables as some point |
|
| 112 | + $this->moveDoColumns(); |
|
| 113 | + // Convert IP address columns from int to readable varchar(45) for IPv6 |
|
| 114 | + $this->convertIPAddresses('newbb_posts', 'poster_ip'); |
|
| 115 | + $this->convertIPAddresses('newbb_report', 'reporter_ip'); |
|
| 116 | + } |
|
| 117 | 117 | } |
@@ -43,672 +43,672 @@ |
||
| 43 | 43 | */ |
| 44 | 44 | class Post extends \XoopsObject |
| 45 | 45 | { |
| 46 | - //class Post extends \XoopsObject { |
|
| 47 | - private $attachmentArray = []; |
|
| 48 | - |
|
| 49 | - /** |
|
| 50 | - * |
|
| 51 | - */ |
|
| 52 | - public function __construct() |
|
| 53 | - { |
|
| 54 | - parent::__construct(); |
|
| 55 | - |
|
| 56 | - $this->initVar('post_id', XOBJ_DTYPE_INT); |
|
| 57 | - $this->initVar('topic_id', XOBJ_DTYPE_INT, 0, true); |
|
| 58 | - $this->initVar('forum_id', XOBJ_DTYPE_INT, 0, true); |
|
| 59 | - $this->initVar('post_time', XOBJ_DTYPE_INT, 0, true); |
|
| 60 | - // $this->initVar('poster_ip', XOBJ_DTYPE_INT, 0); |
|
| 61 | - $this->initVar('poster_ip', XOBJ_DTYPE_TXTBOX, ''); |
|
| 62 | - $this->initVar('poster_name', XOBJ_DTYPE_TXTBOX, ''); |
|
| 63 | - $this->initVar('subject', XOBJ_DTYPE_TXTBOX, '', true); |
|
| 64 | - $this->initVar('pid', XOBJ_DTYPE_INT, 0); |
|
| 65 | - $this->initVar('dohtml', XOBJ_DTYPE_INT, 0); |
|
| 66 | - $this->initVar('dosmiley', XOBJ_DTYPE_INT, 1); |
|
| 67 | - $this->initVar('doxcode', XOBJ_DTYPE_INT, 1); |
|
| 68 | - $this->initVar('doimage', XOBJ_DTYPE_INT, 1); |
|
| 69 | - $this->initVar('dobr', XOBJ_DTYPE_INT, 1); |
|
| 70 | - $this->initVar('uid', XOBJ_DTYPE_INT, 1); |
|
| 71 | - $this->initVar('icon', XOBJ_DTYPE_TXTBOX, ''); |
|
| 72 | - $this->initVar('attachsig', XOBJ_DTYPE_INT, 0); |
|
| 73 | - $this->initVar('approved', XOBJ_DTYPE_INT, 1); |
|
| 74 | - $this->initVar('post_karma', XOBJ_DTYPE_INT, 0); |
|
| 75 | - $this->initVar('require_reply', XOBJ_DTYPE_INT, 0); |
|
| 76 | - $this->initVar('attachment', XOBJ_DTYPE_TXTAREA, ''); |
|
| 77 | - $this->initVar('post_text', XOBJ_DTYPE_TXTAREA, ''); |
|
| 78 | - $this->initVar('post_edit', XOBJ_DTYPE_TXTAREA, ''); |
|
| 79 | - } |
|
| 80 | - |
|
| 81 | - // //////////////////////////////////////////////////////////////////////////////////// |
|
| 82 | - // attachment functions TODO: there should be a file/attachment management class |
|
| 83 | - /** |
|
| 84 | - * @return array|mixed|null |
|
| 85 | - */ |
|
| 86 | - public function getAttachment() |
|
| 87 | - { |
|
| 88 | - if (count($this->attachmentArray)) { |
|
| 89 | - return $this->attachmentArray; |
|
| 90 | - } |
|
| 91 | - $attachment = $this->getVar('attachment'); |
|
| 92 | - if (empty($attachment)) { |
|
| 93 | - $this->attachmentArray = []; |
|
| 94 | - } else { |
|
| 95 | - $this->attachmentArray = @unserialize(base64_decode($attachment)); |
|
| 96 | - } |
|
| 97 | - |
|
| 98 | - return $this->attachmentArray; |
|
| 99 | - } |
|
| 100 | - |
|
| 101 | - /** |
|
| 102 | - * @param $attachKey |
|
| 103 | - * @return bool |
|
| 104 | - */ |
|
| 105 | - public function incrementDownload($attachKey) |
|
| 106 | - { |
|
| 107 | - if (!$attachKey) { |
|
| 108 | - return false; |
|
| 109 | - } |
|
| 110 | - $this->attachmentArray[(string)$attachKey]['numDownload']++; |
|
| 111 | - |
|
| 112 | - return $this->attachmentArray[(string)$attachKey]['numDownload']; |
|
| 113 | - } |
|
| 114 | - |
|
| 115 | - /** |
|
| 116 | - * @return bool |
|
| 117 | - */ |
|
| 118 | - public function saveAttachment() |
|
| 119 | - { |
|
| 120 | - $attachmentSave = ''; |
|
| 121 | - if (is_array($this->attachmentArray) && count($this->attachmentArray) > 0) { |
|
| 122 | - $attachmentSave = base64_encode(serialize($this->attachmentArray)); |
|
| 123 | - } |
|
| 124 | - $this->setVar('attachment', $attachmentSave); |
|
| 125 | - $sql = 'UPDATE ' . $GLOBALS['xoopsDB']->prefix('newbb_posts') . ' SET attachment=' . $GLOBALS['xoopsDB']->quoteString($attachmentSave) . ' WHERE post_id = ' . $this->getVar('post_id'); |
|
| 126 | - if (!$result = $GLOBALS['xoopsDB']->queryF($sql)) { |
|
| 127 | - //xoops_error($GLOBALS['xoopsDB']->error()); |
|
| 128 | - return false; |
|
| 129 | - } |
|
| 130 | - |
|
| 131 | - return true; |
|
| 132 | - } |
|
| 133 | - |
|
| 134 | - /** |
|
| 135 | - * @param array|null $attachArray |
|
| 136 | - * @return bool |
|
| 137 | - */ |
|
| 138 | - public function deleteAttachment($attachArray = null) |
|
| 139 | - { |
|
| 140 | - $attachOld = $this->getAttachment(); |
|
| 141 | - if (!is_array($attachOld) || count($attachOld) < 1) { |
|
| 142 | - return true; |
|
| 143 | - } |
|
| 144 | - $this->attachmentArray = []; |
|
| 145 | - |
|
| 146 | - if (null === $attachArray) { |
|
| 147 | - $attachArray = array_keys($attachOld); |
|
| 148 | - } // to delete all! |
|
| 149 | - if (!is_array($attachArray)) { |
|
| 150 | - $attachArray = [$attachArray]; |
|
| 151 | - } |
|
| 152 | - |
|
| 153 | - foreach ($attachOld as $key => $attach) { |
|
| 154 | - if (in_array($key, $attachArray)) { |
|
| 155 | - @unlink($GLOBALS['xoops']->path($GLOBALS['xoopsModuleConfig']['dir_attachments'] . '/' . $attach['name_saved'])); |
|
| 156 | - @unlink($GLOBALS['xoops']->path($GLOBALS['xoopsModuleConfig']['dir_attachments'] . '/thumbs/' . $attach['name_saved'])); // delete thumbnails |
|
| 157 | - continue; |
|
| 158 | - } |
|
| 159 | - $this->attachmentArray[$key] = $attach; |
|
| 160 | - } |
|
| 161 | - $attachmentSave = ''; |
|
| 162 | - if (is_array($this->attachmentArray) && count($this->attachmentArray) > 0) { |
|
| 163 | - $attachmentSave = base64_encode(serialize($this->attachmentArray)); |
|
| 164 | - } |
|
| 165 | - $this->setVar('attachment', $attachmentSave); |
|
| 166 | - |
|
| 167 | - return true; |
|
| 168 | - } |
|
| 169 | - |
|
| 170 | - /** |
|
| 171 | - * @param string $name_saved |
|
| 172 | - * @param string $nameDisplay |
|
| 173 | - * @param string $mimetype |
|
| 174 | - * @param int $numDownload |
|
| 175 | - * @return bool |
|
| 176 | - */ |
|
| 177 | - public function setAttachment($name_saved = '', $nameDisplay = '', $mimetype = '', $numDownload = 0) |
|
| 178 | - { |
|
| 179 | - static $counter = 0; |
|
| 180 | - $this->attachmentArray = $this->getAttachment(); |
|
| 181 | - if ($name_saved) { |
|
| 182 | - $key = (string)(time() + $counter++); |
|
| 183 | - $this->attachmentArray[$key] = [ |
|
| 184 | - 'name_saved' => $name_saved, |
|
| 185 | - 'nameDisplay' => empty($nameDisplay) ? $nameDisplay : $name_saved, |
|
| 186 | - 'mimetype' => $mimetype, |
|
| 187 | - 'numDownload' => empty($numDownload) ? (int)$numDownload : 0 |
|
| 188 | - ]; |
|
| 189 | - } |
|
| 190 | - $attachmentSave = null; |
|
| 191 | - if (is_array($this->attachmentArray)) { |
|
| 192 | - $attachmentSave = base64_encode(serialize($this->attachmentArray)); |
|
| 193 | - } |
|
| 194 | - $this->setVar('attachment', $attachmentSave); |
|
| 195 | - |
|
| 196 | - return true; |
|
| 197 | - } |
|
| 198 | - |
|
| 199 | - /** |
|
| 200 | - * TODO: refactor |
|
| 201 | - * @param bool $asSource |
|
| 202 | - * @return string |
|
| 203 | - */ |
|
| 204 | - public function displayAttachment($asSource = false) |
|
| 205 | - { |
|
| 206 | - global $xoopsModule; |
|
| 207 | - |
|
| 208 | - $post_attachment = ''; |
|
| 209 | - $attachments = $this->getAttachment(); |
|
| 210 | - if (is_array($attachments) && count($attachments) > 0) { |
|
| 211 | - $iconHandler = newbbGetIconHandler(); |
|
| 212 | - $mime_path = $iconHandler->getPath('mime'); |
|
| 213 | - require_once dirname(__DIR__) . '/include/functions.image.php'; |
|
| 214 | - $image_extensions = ['jpg', 'jpeg', 'gif', 'png', 'bmp']; // need improve !!! |
|
| 215 | - $post_attachment .= '<br><strong>' . _MD_NEWBB_ATTACHMENT . '</strong>:'; |
|
| 216 | - $post_attachment .= '<br><hr size="1" noshade="noshade" /><br>'; |
|
| 217 | - foreach ($attachments as $key => $att) { |
|
| 218 | - $file_extension = ltrim(strrchr($att['name_saved'], '.'), '.'); |
|
| 219 | - $filetype = $file_extension; |
|
| 220 | - if (file_exists($GLOBALS['xoops']->path($mime_path . '/' . $filetype . '.gif'))) { |
|
| 221 | - $icon_filetype = XOOPS_URL . '/' . $mime_path . '/' . $filetype . '.gif'; |
|
| 222 | - } else { |
|
| 223 | - $icon_filetype = XOOPS_URL . '/' . $mime_path . '/unknown.gif'; |
|
| 224 | - } |
|
| 225 | - $file_size = @filesize($GLOBALS['xoops']->path($GLOBALS['xoopsModuleConfig']['dir_attachments'] . '/' . $att['name_saved'])); |
|
| 226 | - $file_size = number_format($file_size / 1024, 2) . ' KB'; |
|
| 227 | - if (in_array(strtolower($file_extension), $image_extensions) |
|
| 228 | - && $GLOBALS['xoopsModuleConfig']['media_allowed']) { |
|
| 229 | - $post_attachment .= '<br><img src="' . $icon_filetype . '" alt="' . $filetype . '" /><strong> ' . $att['nameDisplay'] . '</strong> <small>(' . $file_size . ')</small>'; |
|
| 230 | - $post_attachment .= '<br>' . newbbAttachmentImage($att['name_saved']); |
|
| 231 | - $isDisplayed = true; |
|
| 232 | - } else { |
|
| 233 | - if (empty($GLOBALS['xoopsModuleConfig']['show_userattach'])) { |
|
| 234 | - $post_attachment .= '<a href="' |
|
| 235 | - . XOOPS_URL |
|
| 236 | - . '/modules/' |
|
| 237 | - . $xoopsModule->getVar('dirname', 'n') |
|
| 238 | - . '/dl_attachment.php?attachid=' |
|
| 239 | - . $key |
|
| 240 | - . '&post_id=' |
|
| 241 | - . $this->getVar('post_id') |
|
| 242 | - . '"> <img src="' |
|
| 243 | - . $icon_filetype |
|
| 244 | - . '" alt="' |
|
| 245 | - . $filetype |
|
| 246 | - . '" /> ' |
|
| 247 | - . $att['nameDisplay'] |
|
| 248 | - . '</a> ' |
|
| 249 | - . _MD_NEWBB_FILESIZE |
|
| 250 | - . ': ' |
|
| 251 | - . $file_size |
|
| 252 | - . '; ' |
|
| 253 | - . _MD_NEWBB_HITS |
|
| 254 | - . ': ' |
|
| 255 | - . $att['numDownload']; |
|
| 256 | - } elseif ($GLOBALS['xoopsUser'] && $GLOBALS['xoopsUser']->uid() > 0 |
|
| 257 | - && $GLOBALS['xoopsUser']->isactive()) { |
|
| 258 | - $post_attachment .= '<a href="' |
|
| 259 | - . XOOPS_URL |
|
| 260 | - . '/modules/' |
|
| 261 | - . $xoopsModule->getVar('dirname', 'n') |
|
| 262 | - . '/dl_attachment.php?attachid=' |
|
| 263 | - . $key |
|
| 264 | - . '&post_id=' |
|
| 265 | - . $this->getVar('post_id') |
|
| 266 | - . '"> <img src="' |
|
| 267 | - . $icon_filetype |
|
| 268 | - . '" alt="' |
|
| 269 | - . $filetype |
|
| 270 | - . '" /> ' |
|
| 271 | - . $att['nameDisplay'] |
|
| 272 | - . '</a> ' |
|
| 273 | - . _MD_NEWBB_FILESIZE |
|
| 274 | - . ': ' |
|
| 275 | - . $file_size |
|
| 276 | - . '; ' |
|
| 277 | - . _MD_NEWBB_HITS |
|
| 278 | - . ': ' |
|
| 279 | - . $att['numDownload']; |
|
| 280 | - } else { |
|
| 281 | - $post_attachment .= _MD_NEWBB_SEENOTGUEST; |
|
| 282 | - } |
|
| 283 | - } |
|
| 284 | - $post_attachment .= '<br>'; |
|
| 285 | - } |
|
| 286 | - } |
|
| 287 | - |
|
| 288 | - return $post_attachment; |
|
| 289 | - } |
|
| 290 | - // attachment functions |
|
| 291 | - // //////////////////////////////////////////////////////////////////////////////////// |
|
| 292 | - |
|
| 293 | - /** |
|
| 294 | - * @param string $poster_name |
|
| 295 | - * @param string $post_editmsg |
|
| 296 | - * @return bool |
|
| 297 | - */ |
|
| 298 | - public function setPostEdit($poster_name = '', $post_editmsg = '') |
|
| 299 | - { |
|
| 300 | - $edit_user = ''; |
|
| 301 | - if (empty($GLOBALS['xoopsModuleConfig']['recordedit_timelimit']) |
|
| 302 | - || (time() - $this->getVar('post_time')) < $GLOBALS['xoopsModuleConfig']['recordedit_timelimit'] * 60 |
|
| 303 | - || $this->getVar('approved') < 1) { |
|
| 304 | - return true; |
|
| 305 | - } |
|
| 306 | - if (is_object($GLOBALS['xoopsUser']) && $GLOBALS['xoopsUser']->isActive()) { |
|
| 307 | - if ($GLOBALS['xoopsModuleConfig']['show_realname'] && $GLOBALS['xoopsUser']->getVar('name')) { |
|
| 308 | - $edit_user = $GLOBALS['xoopsUser']->getVar('name'); |
|
| 309 | - } else { |
|
| 310 | - $edit_user = $GLOBALS['xoopsUser']->getVar('uname'); |
|
| 311 | - } |
|
| 312 | - } |
|
| 313 | - $post_edit = []; |
|
| 314 | - $post_edit['edit_user'] = $edit_user; // (?) The proper way is to store uid instead of name. |
|
| 315 | - // However, to save queries when displaying, the current way is ok. |
|
| 316 | - $post_edit['edit_time'] = time(); |
|
| 317 | - $post_edit['edit_msg'] = $post_editmsg; |
|
| 318 | - |
|
| 319 | - $post_edits = $this->getVar('post_edit'); |
|
| 320 | - if (!empty($post_edits)) { |
|
| 321 | - $post_edits = unserialize(base64_decode($post_edits)); |
|
| 322 | - } |
|
| 323 | - if (!is_array($post_edits)) { |
|
| 324 | - $post_edits = []; |
|
| 325 | - } |
|
| 326 | - $post_edits[] = $post_edit; |
|
| 327 | - $post_edit = base64_encode(serialize($post_edits)); |
|
| 328 | - unset($post_edits); |
|
| 329 | - $this->setVar('post_edit', $post_edit); |
|
| 330 | - |
|
| 331 | - return true; |
|
| 332 | - } |
|
| 333 | - |
|
| 334 | - /** |
|
| 335 | - * @return bool|string |
|
| 336 | - */ |
|
| 337 | - public function displayPostEdit() |
|
| 338 | - { |
|
| 339 | - global $myts; |
|
| 340 | - |
|
| 341 | - if (empty($GLOBALS['xoopsModuleConfig']['recordedit_timelimit'])) { |
|
| 342 | - return false; |
|
| 343 | - } |
|
| 344 | - |
|
| 345 | - $post_edit = ''; |
|
| 346 | - $post_edits = $this->getVar('post_edit'); |
|
| 347 | - if (!empty($post_edits)) { |
|
| 348 | - $post_edits = unserialize(base64_decode($post_edits)); |
|
| 349 | - } |
|
| 350 | - if (!isset($post_edits) || !is_array($post_edits)) { |
|
| 351 | - $post_edits = []; |
|
| 352 | - } |
|
| 353 | - if (is_array($post_edits) && count($post_edits) > 0) { |
|
| 354 | - foreach ($post_edits as $postedit) { |
|
| 355 | - $edit_time = (int)$postedit['edit_time']; |
|
| 356 | - $edit_user = $postedit['edit_user']; |
|
| 357 | - $edit_msg = !empty($postedit['edit_msg']) ? $postedit['edit_msg'] : ''; |
|
| 358 | - // Start irmtfan add option to do only the latest edit when do_latestedit=0 (Alfred) |
|
| 359 | - if (empty($GLOBALS['xoopsModuleConfig']['do_latestedit'])) { |
|
| 360 | - $post_edit = ''; |
|
| 361 | - } |
|
| 362 | - // End irmtfan add option to do only the latest edit when do_latestedit=0 (Alfred) |
|
| 363 | - // START hacked by irmtfan |
|
| 364 | - // display/save all edit records. |
|
| 365 | - $post_edit .= _MD_NEWBB_EDITEDBY . ' ' . $edit_user . ' ' . _MD_NEWBB_ON . ' ' . formatTimestamp($edit_time) . '<br>'; |
|
| 366 | - // if reason is not empty |
|
| 367 | - if ('' !== $edit_msg) { |
|
| 368 | - $post_edit .= _MD_NEWBB_EDITEDMSG . ' ' . $edit_msg . '<br>'; |
|
| 369 | - } |
|
| 370 | - // START hacked by irmtfan |
|
| 371 | - } |
|
| 372 | - } |
|
| 373 | - |
|
| 374 | - return $post_edit; |
|
| 375 | - } |
|
| 376 | - |
|
| 377 | - /** |
|
| 378 | - * @return array |
|
| 379 | - */ |
|
| 380 | - public function &getPostBody() |
|
| 381 | - { |
|
| 382 | - global $viewtopic_users; |
|
| 383 | - $newbbConfig = newbbLoadConfig(); |
|
| 384 | - require_once dirname(__DIR__) . '/include/functions.user.php'; |
|
| 385 | - require_once dirname(__DIR__) . '/include/functions.render.php'; |
|
| 386 | - |
|
| 387 | - $uid = is_object($GLOBALS['xoopsUser']) ? $GLOBALS['xoopsUser']->getVar('uid') : 0; |
|
| 388 | - /** @var KarmaHandler $karmaHandler */ |
|
| 389 | - $karmaHandler = Newbb\Helper::getInstance()->getHandler('Karma'); |
|
| 390 | - $user_karma = $karmaHandler->getUserKarma(); |
|
| 391 | - |
|
| 392 | - $post = []; |
|
| 393 | - $post['attachment'] = false; |
|
| 394 | - $post_text = newbbDisplayTarea($this->vars['post_text']['value'], $this->getVar('dohtml'), $this->getVar('dosmiley'), $this->getVar('doxcode'), $this->getVar('doimage'), $this->getVar('dobr')); |
|
| 395 | - if (newbbIsAdmin($this->getVar('forum_id')) || $this->checkIdentity()) { |
|
| 396 | - $post['text'] = $post_text . '<br>' . $this->displayAttachment(); |
|
| 397 | - } elseif ($newbbConfig['enable_karma'] && $this->getVar('post_karma') > $user_karma) { |
|
| 398 | - $post['text'] = sprintf(_MD_NEWBB_KARMA_REQUIREMENT, $user_karma, $this->getVar('post_karma')); |
|
| 399 | - } elseif ($newbbConfig['allow_require_reply'] && $this->getVar('require_reply') |
|
| 400 | - && (!$uid || !isset($viewtopic_users[$uid]))) { |
|
| 401 | - $post['text'] = _MD_NEWBB_REPLY_REQUIREMENT; |
|
| 402 | - } else { |
|
| 403 | - $post['text'] = $post_text . '<br>' . $this->displayAttachment(); |
|
| 404 | - } |
|
| 405 | - /** @var \XoopsMemberHandler $memberHandler */ |
|
| 406 | - $memberHandler = xoops_getHandler('member'); |
|
| 407 | - $eachposter = $memberHandler->getUser($this->getVar('uid')); |
|
| 408 | - if (is_object($eachposter) && $eachposter->isActive()) { |
|
| 409 | - if ($newbbConfig['show_realname'] && $eachposter->getVar('name')) { |
|
| 410 | - $post['author'] = $eachposter->getVar('name'); |
|
| 411 | - } else { |
|
| 412 | - $post['author'] = $eachposter->getVar('uname'); |
|
| 413 | - } |
|
| 414 | - unset($eachposter); |
|
| 415 | - } else { |
|
| 416 | - $post['author'] = $this->getVar('poster_name') ?: $GLOBALS['xoopsConfig']['anonymous']; |
|
| 417 | - } |
|
| 418 | - |
|
| 419 | - $post['subject'] = newbbHtmlspecialchars($this->vars['subject']['value']); |
|
| 420 | - |
|
| 421 | - $post['date'] = $this->getVar('post_time'); |
|
| 422 | - |
|
| 423 | - return $post; |
|
| 424 | - } |
|
| 425 | - |
|
| 426 | - /** |
|
| 427 | - * @return bool |
|
| 428 | - */ |
|
| 429 | - public function isTopic() |
|
| 430 | - { |
|
| 431 | - return !$this->getVar('pid'); |
|
| 432 | - } |
|
| 433 | - |
|
| 434 | - /** |
|
| 435 | - * @param string $action_tag |
|
| 436 | - * @return bool |
|
| 437 | - */ |
|
| 438 | - public function checkTimelimit($action_tag = 'edit_timelimit') |
|
| 439 | - { |
|
| 440 | - $newbbConfig = newbbLoadConfig(); |
|
| 441 | - if (empty($newbbConfig['edit_timelimit'])) { |
|
| 442 | - return true; |
|
| 443 | - } |
|
| 444 | - |
|
| 445 | - return ($this->getVar('post_time') > time() - $newbbConfig[$action_tag] * 60); |
|
| 446 | - } |
|
| 447 | - |
|
| 448 | - /** |
|
| 449 | - * @param int $uid |
|
| 450 | - * @return bool |
|
| 451 | - */ |
|
| 452 | - public function checkIdentity($uid = -1) |
|
| 453 | - { |
|
| 454 | - $uid = ($uid > -1) ? $uid : (is_object($GLOBALS['xoopsUser']) ? $GLOBALS['xoopsUser']->getVar('uid') : 0); |
|
| 455 | - if ($this->getVar('uid') > 0) { |
|
| 456 | - $user_ok = ($uid == $this->getVar('uid')); |
|
| 457 | - } else { |
|
| 458 | - static $user_ip; |
|
| 459 | - if (!isset($user_ip)) { |
|
| 460 | - $user_ip = \Xmf\IPAddress::fromRequest()->asReadable(); |
|
| 461 | - } |
|
| 462 | - $user_ok = ($user_ip == $this->getVar('poster_ip')); |
|
| 463 | - } |
|
| 464 | - |
|
| 465 | - return $user_ok; |
|
| 466 | - } |
|
| 467 | - |
|
| 468 | - // TODO: cleaning up and merge with post hanldings in viewpost.php |
|
| 469 | - |
|
| 470 | - /** |
|
| 471 | - * @param $isAdmin |
|
| 472 | - * @return array |
|
| 473 | - */ |
|
| 474 | - public function showPost($isAdmin) |
|
| 475 | - { |
|
| 476 | - global $xoopsModule, $myts; |
|
| 477 | - global $forumUrl, $forumImage, $forumObject, $online, $viewmode; |
|
| 478 | - global $viewtopic_users, $viewtopic_posters, $topicObject, $user_karma; |
|
| 479 | - global $order, $start, $total_posts, $topic_status; |
|
| 480 | - static $post_NO = 0; |
|
| 481 | - static $name_anonymous; |
|
| 482 | - /** @var TopicHandler $topicHandler */ |
|
| 483 | - $topicHandler = Newbb\Helper::getInstance()->getHandler('Topic'); |
|
| 484 | - if (null === $name_anonymous) { |
|
| 485 | - $name_anonymous = $myts->htmlSpecialChars($GLOBALS['xoopsConfig']['anonymous']); |
|
| 486 | - } |
|
| 487 | - |
|
| 488 | - require_once dirname(__DIR__) . '/include/functions.time.php'; |
|
| 489 | - require_once dirname(__DIR__) . '/include/functions.render.php'; |
|
| 490 | - |
|
| 491 | - $post_id = $this->getVar('post_id'); |
|
| 492 | - $topic_id = $this->getVar('topic_id'); |
|
| 493 | - $forum_id = $this->getVar('forum_id'); |
|
| 494 | - |
|
| 495 | - $query_vars = ['status', 'order', 'start', 'mode', 'viewmode']; |
|
| 496 | - $query_array = []; |
|
| 497 | - $query_array['topic_id'] = "topic_id={$topic_id}"; |
|
| 498 | - foreach ($query_vars as $var) { |
|
| 499 | - if (Request::getString($var, '', 'GET')) { |
|
| 500 | - $query_array[$var] = "{$var}=" . Request::getString($var, '', 'GET'); |
|
| 501 | - } |
|
| 502 | - } |
|
| 503 | - $page_query = htmlspecialchars(implode('&', array_values($query_array)), ENT_QUOTES | ENT_HTML5); |
|
| 504 | - |
|
| 505 | - $uid = is_object($GLOBALS['xoopsUser']) ? $GLOBALS['xoopsUser']->getVar('uid') : 0; |
|
| 506 | - |
|
| 507 | - ++$post_NO; |
|
| 508 | - if ('desc' === strtolower($order)) { |
|
| 509 | - $post_no = $total_posts - ($start + $post_NO) + 1; |
|
| 510 | - } else { |
|
| 511 | - $post_no = $start + $post_NO; |
|
| 512 | - } |
|
| 513 | - |
|
| 514 | - if ($isAdmin || $this->checkIdentity()) { |
|
| 515 | - $post_text = $this->getVar('post_text'); |
|
| 516 | - $post_attachment = $this->displayAttachment(); |
|
| 517 | - } elseif ($GLOBALS['xoopsModuleConfig']['enable_karma'] && $this->getVar('post_karma') > $user_karma) { |
|
| 518 | - $post_text = "<div class='karma'>" . sprintf(_MD_NEWBB_KARMA_REQUIREMENT, $user_karma, $this->getVar('post_karma')) . '</div>'; |
|
| 519 | - $post_attachment = ''; |
|
| 520 | - } elseif ($GLOBALS['xoopsModuleConfig']['allow_require_reply'] && $this->getVar('require_reply') |
|
| 521 | - && (!$uid || !in_array($uid, $viewtopic_posters))) { |
|
| 522 | - $post_text = "<div class='karma'>" . _MD_NEWBB_REPLY_REQUIREMENT . '</div>'; |
|
| 523 | - $post_attachment = ''; |
|
| 524 | - } else { |
|
| 525 | - $post_text = $this->getVar('post_text'); |
|
| 526 | - $post_attachment = $this->displayAttachment(); |
|
| 527 | - } |
|
| 528 | - |
|
| 529 | - // Hightlight search words |
|
| 530 | - $post_title = $this->getVar('subject'); |
|
| 531 | - if ($keywords = Request::getString('keywords', '', 'GET')) { |
|
| 532 | - //$keywords = $myts->htmlSpecialChars(trim(urldecode(Request::getString('keywords', '', 'GET')))); |
|
| 533 | - $post_text = Highlighter::apply($keywords, $post_text, '<mark>', '</mark>'); |
|
| 534 | - $post_title = Highlighter::apply($keywords, $post_title, '<mark>', '</mark>'); |
|
| 535 | - } |
|
| 536 | - |
|
| 537 | - if (isset($viewtopic_users[$this->getVar('uid')])) { |
|
| 538 | - $poster = $viewtopic_users[$this->getVar('uid')]; |
|
| 539 | - } else { |
|
| 540 | - $name = ($post_name = $this->getVar('poster_name')) ? $post_name : $name_anonymous; |
|
| 541 | - $poster = [ |
|
| 542 | - 'poster_uid' => 0, |
|
| 543 | - 'name' => $name, |
|
| 544 | - 'link' => $name |
|
| 545 | - ]; |
|
| 546 | - } |
|
| 547 | - |
|
| 548 | - if ($posticon = $this->getVar('icon')) { |
|
| 549 | - $post_image = '<a name="' . $post_id . '"><img src="' . XOOPS_URL . '/images/subject/' . $posticon . '" alt="" /></a>'; |
|
| 550 | - } else { |
|
| 551 | - $post_image = '<a name="' . $post_id . '"><img src="' . XOOPS_URL . '/images/icons/posticon.gif" alt="" /></a>'; |
|
| 552 | - } |
|
| 553 | - |
|
| 554 | - $thread_buttons = []; |
|
| 555 | - $mod_buttons = []; |
|
| 556 | - |
|
| 557 | - if ($isAdmin && ($GLOBALS['xoopsUser'] && $GLOBALS['xoopsUser']->getVar('uid') !== $this->getVar('uid')) |
|
| 558 | - && $this->getVar('uid') > 0) { |
|
| 559 | - $mod_buttons['bann']['image'] = newbbDisplayImage('p_bann', _MD_NEWBB_SUSPEND_MANAGEMENT); |
|
| 560 | - $mod_buttons['bann']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/moderate.php?forum=' . $forum_id . '&uid=' . $this->getVar('uid'); |
|
| 561 | - $mod_buttons['bann']['name'] = _MD_NEWBB_SUSPEND_MANAGEMENT; |
|
| 562 | - $thread_buttons['bann']['image'] = newbbDisplayImage('p_bann', _MD_NEWBB_SUSPEND_MANAGEMENT); |
|
| 563 | - $thread_buttons['bann']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/moderate.php?forum=' . $forum_id . '&uid=' . $this->getVar('uid'); |
|
| 564 | - $thread_buttons['bann']['name'] = _MD_NEWBB_SUSPEND_MANAGEMENT; |
|
| 565 | - } |
|
| 566 | - |
|
| 567 | - if ($GLOBALS['xoopsModuleConfig']['enable_permcheck']) { |
|
| 568 | - // /** @var TopicHandler $topicHandler */ |
|
| 569 | - // $topicHandler = Newbb\Helper::getInstance()->getHandler('Topic'); |
|
| 570 | - $topic_status = $topicObject->getVar('topic_status'); |
|
| 571 | - if ($topicHandler->getPermission($forum_id, $topic_status, 'edit')) { |
|
| 572 | - $edit_ok = ($isAdmin || ($this->checkIdentity() && $this->checkTimelimit('edit_timelimit'))); |
|
| 573 | - |
|
| 574 | - if ($edit_ok) { |
|
| 575 | - $thread_buttons['edit']['image'] = newbbDisplayImage('p_edit', _EDIT); |
|
| 576 | - $thread_buttons['edit']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/edit.php?{$page_query}"; |
|
| 577 | - $thread_buttons['edit']['name'] = _EDIT; |
|
| 578 | - $mod_buttons['edit']['image'] = newbbDisplayImage('p_edit', _EDIT); |
|
| 579 | - $mod_buttons['edit']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/edit.php?{$page_query}"; |
|
| 580 | - $mod_buttons['edit']['name'] = _EDIT; |
|
| 581 | - } |
|
| 582 | - } |
|
| 583 | - |
|
| 584 | - if ($topicHandler->getPermission($forum_id, $topic_status, 'delete')) { |
|
| 585 | - $delete_ok = ($isAdmin || ($this->checkIdentity() && $this->checkTimelimit('delete_timelimit'))); |
|
| 586 | - |
|
| 587 | - if ($delete_ok) { |
|
| 588 | - $thread_buttons['delete']['image'] = newbbDisplayImage('p_delete', _DELETE); |
|
| 589 | - $thread_buttons['delete']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/delete.php?{$page_query}"; |
|
| 590 | - $thread_buttons['delete']['name'] = _DELETE; |
|
| 591 | - $mod_buttons['delete']['image'] = newbbDisplayImage('p_delete', _DELETE); |
|
| 592 | - $mod_buttons['delete']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/delete.php?{$page_query}"; |
|
| 593 | - $mod_buttons['delete']['name'] = _DELETE; |
|
| 594 | - } |
|
| 595 | - } |
|
| 596 | - if ($topicHandler->getPermission($forum_id, $topic_status, 'reply')) { |
|
| 597 | - $thread_buttons['reply']['image'] = newbbDisplayImage('p_reply', _MD_NEWBB_REPLY); |
|
| 598 | - $thread_buttons['reply']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/reply.php?{$page_query}"; |
|
| 599 | - $thread_buttons['reply']['name'] = _MD_NEWBB_REPLY; |
|
| 600 | - |
|
| 601 | - $thread_buttons['quote']['image'] = newbbDisplayImage('p_quote', _MD_NEWBB_QUOTE); |
|
| 602 | - $thread_buttons['quote']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/reply.php?{$page_query}&quotedac=1"; |
|
| 603 | - $thread_buttons['quote']['name'] = _MD_NEWBB_QUOTE; |
|
| 604 | - } |
|
| 605 | - } else { |
|
| 606 | - $mod_buttons['edit']['image'] = newbbDisplayImage('p_edit', _EDIT); |
|
| 607 | - $mod_buttons['edit']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/edit.php?{$page_query}"; |
|
| 608 | - $mod_buttons['edit']['name'] = _EDIT; |
|
| 609 | - |
|
| 610 | - $mod_buttons['delete']['image'] = newbbDisplayImage('p_delete', _DELETE); |
|
| 611 | - $mod_buttons['delete']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/delete.php?{$page_query}"; |
|
| 612 | - $mod_buttons['delete']['name'] = _DELETE; |
|
| 613 | - |
|
| 614 | - $thread_buttons['reply']['image'] = newbbDisplayImage('p_reply', _MD_NEWBB_REPLY); |
|
| 615 | - $thread_buttons['reply']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/reply.php?{$page_query}"; |
|
| 616 | - $thread_buttons['reply']['name'] = _MD_NEWBB_REPLY; |
|
| 617 | - } |
|
| 618 | - |
|
| 619 | - if (!$isAdmin && $GLOBALS['xoopsModuleConfig']['reportmod_enabled']) { |
|
| 620 | - $thread_buttons['report']['image'] = newbbDisplayImage('p_report', _MD_NEWBB_REPORT); |
|
| 621 | - $thread_buttons['report']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/report.php?{$page_query}"; |
|
| 622 | - $thread_buttons['report']['name'] = _MD_NEWBB_REPORT; |
|
| 623 | - } |
|
| 624 | - |
|
| 625 | - $thread_action = []; |
|
| 626 | - // irmtfan add pdf permission |
|
| 627 | - if (file_exists(XOOPS_ROOT_PATH . '/class/libraries/vendor/tecnickcom/tcpdf/tcpdf.php') |
|
| 628 | - && $topicHandler->getPermission($forum_id, $topic_status, 'pdf')) { |
|
| 629 | - $thread_action['pdf']['image'] = newbbDisplayImage('pdf', _MD_NEWBB_PDF); |
|
| 630 | - $thread_action['pdf']['link'] = XOOPS_URL . '/modules/newbb/makepdf.php?type=post&pageid=0'; |
|
| 631 | - $thread_action['pdf']['name'] = _MD_NEWBB_PDF; |
|
| 632 | - $thread_action['pdf']['target'] = '_blank'; |
|
| 633 | - } |
|
| 634 | - // irmtfan add print permission |
|
| 635 | - if ($topicHandler->getPermission($forum_id, $topic_status, 'print')) { |
|
| 636 | - $thread_action['print']['image'] = newbbDisplayImage('printer', _MD_NEWBB_PRINT); |
|
| 637 | - $thread_action['print']['link'] = XOOPS_URL . '/modules/newbb/print.php?form=2&forum=' . $forum_id . '&topic_id=' . $topic_id; |
|
| 638 | - $thread_action['print']['name'] = _MD_NEWBB_PRINT; |
|
| 639 | - $thread_action['print']['target'] = '_blank'; |
|
| 640 | - } |
|
| 641 | - |
|
| 642 | - if ($GLOBALS['xoopsModuleConfig']['show_sociallinks']) { |
|
| 643 | - $full_title = $this->getVar('subject'); |
|
| 644 | - $clean_title = preg_replace('/[^A-Za-z0-9-]+/', '+', $this->getVar('subject')); |
|
| 645 | - $full_link = XOOPS_URL . '/modules/newbb/viewtopic.php?post_id=' . $post_id; |
|
| 646 | - |
|
| 647 | - $thread_action['social_twitter']['image'] = newbbDisplayImage('twitter', _MD_NEWBB_SHARE_TWITTER); |
|
| 648 | - $thread_action['social_twitter']['link'] = 'http://twitter.com/share?text=' . $clean_title . '&url=' . $full_link; |
|
| 649 | - $thread_action['social_twitter']['name'] = _MD_NEWBB_SHARE_TWITTER; |
|
| 650 | - $thread_action['social_twitter']['target'] = '_blank'; |
|
| 651 | - |
|
| 652 | - $thread_action['social_facebook']['image'] = newbbDisplayImage('facebook', _MD_NEWBB_SHARE_FACEBOOK); |
|
| 653 | - $thread_action['social_facebook']['link'] = 'http://www.facebook.com/sharer.php?u=' . $full_link; |
|
| 654 | - $thread_action['social_facebook']['name'] = _MD_NEWBB_SHARE_FACEBOOK; |
|
| 655 | - $thread_action['social_facebook']['target'] = '_blank'; |
|
| 656 | - |
|
| 657 | - $thread_action['social_gplus']['image'] = newbbDisplayImage('googleplus', _MD_NEWBB_SHARE_GOOGLEPLUS); |
|
| 658 | - $thread_action['social_gplus']['link'] = 'https://plusone.google.com/_/+1/confirm?hl=en&url=' . $full_link; |
|
| 659 | - $thread_action['social_gplus']['name'] = _MD_NEWBB_SHARE_GOOGLEPLUS; |
|
| 660 | - $thread_action['social_gplus']['target'] = '_blank'; |
|
| 661 | - |
|
| 662 | - $thread_action['social_linkedin']['image'] = newbbDisplayImage('linkedin', _MD_NEWBB_SHARE_LINKEDIN); |
|
| 663 | - $thread_action['social_linkedin']['link'] = 'http://www.linkedin.com/shareArticle?mini=true&title=' . $full_title . '&url=' . $full_link; |
|
| 664 | - $thread_action['social_linkedin']['name'] = _MD_NEWBB_SHARE_LINKEDIN; |
|
| 665 | - $thread_action['social_linkedin']['target'] = '_blank'; |
|
| 666 | - |
|
| 667 | - $thread_action['social_delicious']['image'] = newbbDisplayImage('delicious', _MD_NEWBB_SHARE_DELICIOUS); |
|
| 668 | - $thread_action['social_delicious']['link'] = 'http://del.icio.us/post?title=' . $full_title . '&url=' . $full_link; |
|
| 669 | - $thread_action['social_delicious']['name'] = _MD_NEWBB_SHARE_DELICIOUS; |
|
| 670 | - $thread_action['social_delicious']['target'] = '_blank'; |
|
| 671 | - |
|
| 672 | - $thread_action['social_digg']['image'] = newbbDisplayImage('digg', _MD_NEWBB_SHARE_DIGG); |
|
| 673 | - $thread_action['social_digg']['link'] = 'http://digg.com/submit?phase=2&title=' . $full_title . '&url=' . $full_link; |
|
| 674 | - $thread_action['social_digg']['name'] = _MD_NEWBB_SHARE_DIGG; |
|
| 675 | - $thread_action['social_digg']['target'] = '_blank'; |
|
| 676 | - |
|
| 677 | - $thread_action['social_reddit']['image'] = newbbDisplayImage('reddit', _MD_NEWBB_SHARE_REDDIT); |
|
| 678 | - $thread_action['social_reddit']['link'] = 'http://reddit.com/submit?title=' . $full_title . '&url=' . $full_link; |
|
| 679 | - $thread_action['social_reddit']['name'] = _MD_NEWBB_SHARE_REDDIT; |
|
| 680 | - $thread_action['social_reddit']['target'] = '_blank'; |
|
| 681 | - |
|
| 682 | - $thread_action['social_wong']['image'] = newbbDisplayImage('wong', _MD_NEWBB_SHARE_MRWONG); |
|
| 683 | - $thread_action['social_wong']['link'] = 'http://www.mister-wong.de/index.php?action=addurl&bm_url=' . $full_link; |
|
| 684 | - $thread_action['social_wong']['name'] = _MD_NEWBB_SHARE_MRWONG; |
|
| 685 | - $thread_action['social_wong']['target'] = '_blank'; |
|
| 686 | - } |
|
| 687 | - |
|
| 688 | - $post = [ |
|
| 689 | - 'post_id' => $post_id, |
|
| 690 | - 'post_parent_id' => $this->getVar('pid'), |
|
| 691 | - 'post_date' => newbbFormatTimestamp($this->getVar('post_time')), |
|
| 692 | - 'post_image' => $post_image, |
|
| 693 | - 'post_title' => $post_title, |
|
| 694 | - // irmtfan $post_title to add highlight keywords |
|
| 695 | - 'post_text' => $post_text, |
|
| 696 | - 'post_attachment' => $post_attachment, |
|
| 697 | - 'post_edit' => $this->displayPostEdit(), |
|
| 698 | - 'post_no' => $post_no, |
|
| 699 | - 'post_signature' => $this->getVar('attachsig') ? @$poster['signature'] : '', |
|
| 700 | - // 'poster_ip' => ($isAdmin && $GLOBALS['xoopsModuleConfig']['show_ip']) ? long2ip($this->getVar('poster_ip')) : '', |
|
| 701 | - 'poster_ip' => ($isAdmin |
|
| 702 | - && $GLOBALS['xoopsModuleConfig']['show_ip']) ? $this->getVar('poster_ip') : '', |
|
| 703 | - 'thread_action' => $thread_action, |
|
| 704 | - 'thread_buttons' => $thread_buttons, |
|
| 705 | - 'mod_buttons' => $mod_buttons, |
|
| 706 | - 'poster' => $poster, |
|
| 707 | - 'post_permalink' => '<a href="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/viewtopic.php?post_id=' . $post_id . '"></a>' |
|
| 708 | - ]; |
|
| 709 | - |
|
| 710 | - unset($thread_buttons, $mod_buttons, $eachposter); |
|
| 711 | - |
|
| 712 | - return $post; |
|
| 713 | - } |
|
| 46 | + //class Post extends \XoopsObject { |
|
| 47 | + private $attachmentArray = []; |
|
| 48 | + |
|
| 49 | + /** |
|
| 50 | + * |
|
| 51 | + */ |
|
| 52 | + public function __construct() |
|
| 53 | + { |
|
| 54 | + parent::__construct(); |
|
| 55 | + |
|
| 56 | + $this->initVar('post_id', XOBJ_DTYPE_INT); |
|
| 57 | + $this->initVar('topic_id', XOBJ_DTYPE_INT, 0, true); |
|
| 58 | + $this->initVar('forum_id', XOBJ_DTYPE_INT, 0, true); |
|
| 59 | + $this->initVar('post_time', XOBJ_DTYPE_INT, 0, true); |
|
| 60 | + // $this->initVar('poster_ip', XOBJ_DTYPE_INT, 0); |
|
| 61 | + $this->initVar('poster_ip', XOBJ_DTYPE_TXTBOX, ''); |
|
| 62 | + $this->initVar('poster_name', XOBJ_DTYPE_TXTBOX, ''); |
|
| 63 | + $this->initVar('subject', XOBJ_DTYPE_TXTBOX, '', true); |
|
| 64 | + $this->initVar('pid', XOBJ_DTYPE_INT, 0); |
|
| 65 | + $this->initVar('dohtml', XOBJ_DTYPE_INT, 0); |
|
| 66 | + $this->initVar('dosmiley', XOBJ_DTYPE_INT, 1); |
|
| 67 | + $this->initVar('doxcode', XOBJ_DTYPE_INT, 1); |
|
| 68 | + $this->initVar('doimage', XOBJ_DTYPE_INT, 1); |
|
| 69 | + $this->initVar('dobr', XOBJ_DTYPE_INT, 1); |
|
| 70 | + $this->initVar('uid', XOBJ_DTYPE_INT, 1); |
|
| 71 | + $this->initVar('icon', XOBJ_DTYPE_TXTBOX, ''); |
|
| 72 | + $this->initVar('attachsig', XOBJ_DTYPE_INT, 0); |
|
| 73 | + $this->initVar('approved', XOBJ_DTYPE_INT, 1); |
|
| 74 | + $this->initVar('post_karma', XOBJ_DTYPE_INT, 0); |
|
| 75 | + $this->initVar('require_reply', XOBJ_DTYPE_INT, 0); |
|
| 76 | + $this->initVar('attachment', XOBJ_DTYPE_TXTAREA, ''); |
|
| 77 | + $this->initVar('post_text', XOBJ_DTYPE_TXTAREA, ''); |
|
| 78 | + $this->initVar('post_edit', XOBJ_DTYPE_TXTAREA, ''); |
|
| 79 | + } |
|
| 80 | + |
|
| 81 | + // //////////////////////////////////////////////////////////////////////////////////// |
|
| 82 | + // attachment functions TODO: there should be a file/attachment management class |
|
| 83 | + /** |
|
| 84 | + * @return array|mixed|null |
|
| 85 | + */ |
|
| 86 | + public function getAttachment() |
|
| 87 | + { |
|
| 88 | + if (count($this->attachmentArray)) { |
|
| 89 | + return $this->attachmentArray; |
|
| 90 | + } |
|
| 91 | + $attachment = $this->getVar('attachment'); |
|
| 92 | + if (empty($attachment)) { |
|
| 93 | + $this->attachmentArray = []; |
|
| 94 | + } else { |
|
| 95 | + $this->attachmentArray = @unserialize(base64_decode($attachment)); |
|
| 96 | + } |
|
| 97 | + |
|
| 98 | + return $this->attachmentArray; |
|
| 99 | + } |
|
| 100 | + |
|
| 101 | + /** |
|
| 102 | + * @param $attachKey |
|
| 103 | + * @return bool |
|
| 104 | + */ |
|
| 105 | + public function incrementDownload($attachKey) |
|
| 106 | + { |
|
| 107 | + if (!$attachKey) { |
|
| 108 | + return false; |
|
| 109 | + } |
|
| 110 | + $this->attachmentArray[(string)$attachKey]['numDownload']++; |
|
| 111 | + |
|
| 112 | + return $this->attachmentArray[(string)$attachKey]['numDownload']; |
|
| 113 | + } |
|
| 114 | + |
|
| 115 | + /** |
|
| 116 | + * @return bool |
|
| 117 | + */ |
|
| 118 | + public function saveAttachment() |
|
| 119 | + { |
|
| 120 | + $attachmentSave = ''; |
|
| 121 | + if (is_array($this->attachmentArray) && count($this->attachmentArray) > 0) { |
|
| 122 | + $attachmentSave = base64_encode(serialize($this->attachmentArray)); |
|
| 123 | + } |
|
| 124 | + $this->setVar('attachment', $attachmentSave); |
|
| 125 | + $sql = 'UPDATE ' . $GLOBALS['xoopsDB']->prefix('newbb_posts') . ' SET attachment=' . $GLOBALS['xoopsDB']->quoteString($attachmentSave) . ' WHERE post_id = ' . $this->getVar('post_id'); |
|
| 126 | + if (!$result = $GLOBALS['xoopsDB']->queryF($sql)) { |
|
| 127 | + //xoops_error($GLOBALS['xoopsDB']->error()); |
|
| 128 | + return false; |
|
| 129 | + } |
|
| 130 | + |
|
| 131 | + return true; |
|
| 132 | + } |
|
| 133 | + |
|
| 134 | + /** |
|
| 135 | + * @param array|null $attachArray |
|
| 136 | + * @return bool |
|
| 137 | + */ |
|
| 138 | + public function deleteAttachment($attachArray = null) |
|
| 139 | + { |
|
| 140 | + $attachOld = $this->getAttachment(); |
|
| 141 | + if (!is_array($attachOld) || count($attachOld) < 1) { |
|
| 142 | + return true; |
|
| 143 | + } |
|
| 144 | + $this->attachmentArray = []; |
|
| 145 | + |
|
| 146 | + if (null === $attachArray) { |
|
| 147 | + $attachArray = array_keys($attachOld); |
|
| 148 | + } // to delete all! |
|
| 149 | + if (!is_array($attachArray)) { |
|
| 150 | + $attachArray = [$attachArray]; |
|
| 151 | + } |
|
| 152 | + |
|
| 153 | + foreach ($attachOld as $key => $attach) { |
|
| 154 | + if (in_array($key, $attachArray)) { |
|
| 155 | + @unlink($GLOBALS['xoops']->path($GLOBALS['xoopsModuleConfig']['dir_attachments'] . '/' . $attach['name_saved'])); |
|
| 156 | + @unlink($GLOBALS['xoops']->path($GLOBALS['xoopsModuleConfig']['dir_attachments'] . '/thumbs/' . $attach['name_saved'])); // delete thumbnails |
|
| 157 | + continue; |
|
| 158 | + } |
|
| 159 | + $this->attachmentArray[$key] = $attach; |
|
| 160 | + } |
|
| 161 | + $attachmentSave = ''; |
|
| 162 | + if (is_array($this->attachmentArray) && count($this->attachmentArray) > 0) { |
|
| 163 | + $attachmentSave = base64_encode(serialize($this->attachmentArray)); |
|
| 164 | + } |
|
| 165 | + $this->setVar('attachment', $attachmentSave); |
|
| 166 | + |
|
| 167 | + return true; |
|
| 168 | + } |
|
| 169 | + |
|
| 170 | + /** |
|
| 171 | + * @param string $name_saved |
|
| 172 | + * @param string $nameDisplay |
|
| 173 | + * @param string $mimetype |
|
| 174 | + * @param int $numDownload |
|
| 175 | + * @return bool |
|
| 176 | + */ |
|
| 177 | + public function setAttachment($name_saved = '', $nameDisplay = '', $mimetype = '', $numDownload = 0) |
|
| 178 | + { |
|
| 179 | + static $counter = 0; |
|
| 180 | + $this->attachmentArray = $this->getAttachment(); |
|
| 181 | + if ($name_saved) { |
|
| 182 | + $key = (string)(time() + $counter++); |
|
| 183 | + $this->attachmentArray[$key] = [ |
|
| 184 | + 'name_saved' => $name_saved, |
|
| 185 | + 'nameDisplay' => empty($nameDisplay) ? $nameDisplay : $name_saved, |
|
| 186 | + 'mimetype' => $mimetype, |
|
| 187 | + 'numDownload' => empty($numDownload) ? (int)$numDownload : 0 |
|
| 188 | + ]; |
|
| 189 | + } |
|
| 190 | + $attachmentSave = null; |
|
| 191 | + if (is_array($this->attachmentArray)) { |
|
| 192 | + $attachmentSave = base64_encode(serialize($this->attachmentArray)); |
|
| 193 | + } |
|
| 194 | + $this->setVar('attachment', $attachmentSave); |
|
| 195 | + |
|
| 196 | + return true; |
|
| 197 | + } |
|
| 198 | + |
|
| 199 | + /** |
|
| 200 | + * TODO: refactor |
|
| 201 | + * @param bool $asSource |
|
| 202 | + * @return string |
|
| 203 | + */ |
|
| 204 | + public function displayAttachment($asSource = false) |
|
| 205 | + { |
|
| 206 | + global $xoopsModule; |
|
| 207 | + |
|
| 208 | + $post_attachment = ''; |
|
| 209 | + $attachments = $this->getAttachment(); |
|
| 210 | + if (is_array($attachments) && count($attachments) > 0) { |
|
| 211 | + $iconHandler = newbbGetIconHandler(); |
|
| 212 | + $mime_path = $iconHandler->getPath('mime'); |
|
| 213 | + require_once dirname(__DIR__) . '/include/functions.image.php'; |
|
| 214 | + $image_extensions = ['jpg', 'jpeg', 'gif', 'png', 'bmp']; // need improve !!! |
|
| 215 | + $post_attachment .= '<br><strong>' . _MD_NEWBB_ATTACHMENT . '</strong>:'; |
|
| 216 | + $post_attachment .= '<br><hr size="1" noshade="noshade" /><br>'; |
|
| 217 | + foreach ($attachments as $key => $att) { |
|
| 218 | + $file_extension = ltrim(strrchr($att['name_saved'], '.'), '.'); |
|
| 219 | + $filetype = $file_extension; |
|
| 220 | + if (file_exists($GLOBALS['xoops']->path($mime_path . '/' . $filetype . '.gif'))) { |
|
| 221 | + $icon_filetype = XOOPS_URL . '/' . $mime_path . '/' . $filetype . '.gif'; |
|
| 222 | + } else { |
|
| 223 | + $icon_filetype = XOOPS_URL . '/' . $mime_path . '/unknown.gif'; |
|
| 224 | + } |
|
| 225 | + $file_size = @filesize($GLOBALS['xoops']->path($GLOBALS['xoopsModuleConfig']['dir_attachments'] . '/' . $att['name_saved'])); |
|
| 226 | + $file_size = number_format($file_size / 1024, 2) . ' KB'; |
|
| 227 | + if (in_array(strtolower($file_extension), $image_extensions) |
|
| 228 | + && $GLOBALS['xoopsModuleConfig']['media_allowed']) { |
|
| 229 | + $post_attachment .= '<br><img src="' . $icon_filetype . '" alt="' . $filetype . '" /><strong> ' . $att['nameDisplay'] . '</strong> <small>(' . $file_size . ')</small>'; |
|
| 230 | + $post_attachment .= '<br>' . newbbAttachmentImage($att['name_saved']); |
|
| 231 | + $isDisplayed = true; |
|
| 232 | + } else { |
|
| 233 | + if (empty($GLOBALS['xoopsModuleConfig']['show_userattach'])) { |
|
| 234 | + $post_attachment .= '<a href="' |
|
| 235 | + . XOOPS_URL |
|
| 236 | + . '/modules/' |
|
| 237 | + . $xoopsModule->getVar('dirname', 'n') |
|
| 238 | + . '/dl_attachment.php?attachid=' |
|
| 239 | + . $key |
|
| 240 | + . '&post_id=' |
|
| 241 | + . $this->getVar('post_id') |
|
| 242 | + . '"> <img src="' |
|
| 243 | + . $icon_filetype |
|
| 244 | + . '" alt="' |
|
| 245 | + . $filetype |
|
| 246 | + . '" /> ' |
|
| 247 | + . $att['nameDisplay'] |
|
| 248 | + . '</a> ' |
|
| 249 | + . _MD_NEWBB_FILESIZE |
|
| 250 | + . ': ' |
|
| 251 | + . $file_size |
|
| 252 | + . '; ' |
|
| 253 | + . _MD_NEWBB_HITS |
|
| 254 | + . ': ' |
|
| 255 | + . $att['numDownload']; |
|
| 256 | + } elseif ($GLOBALS['xoopsUser'] && $GLOBALS['xoopsUser']->uid() > 0 |
|
| 257 | + && $GLOBALS['xoopsUser']->isactive()) { |
|
| 258 | + $post_attachment .= '<a href="' |
|
| 259 | + . XOOPS_URL |
|
| 260 | + . '/modules/' |
|
| 261 | + . $xoopsModule->getVar('dirname', 'n') |
|
| 262 | + . '/dl_attachment.php?attachid=' |
|
| 263 | + . $key |
|
| 264 | + . '&post_id=' |
|
| 265 | + . $this->getVar('post_id') |
|
| 266 | + . '"> <img src="' |
|
| 267 | + . $icon_filetype |
|
| 268 | + . '" alt="' |
|
| 269 | + . $filetype |
|
| 270 | + . '" /> ' |
|
| 271 | + . $att['nameDisplay'] |
|
| 272 | + . '</a> ' |
|
| 273 | + . _MD_NEWBB_FILESIZE |
|
| 274 | + . ': ' |
|
| 275 | + . $file_size |
|
| 276 | + . '; ' |
|
| 277 | + . _MD_NEWBB_HITS |
|
| 278 | + . ': ' |
|
| 279 | + . $att['numDownload']; |
|
| 280 | + } else { |
|
| 281 | + $post_attachment .= _MD_NEWBB_SEENOTGUEST; |
|
| 282 | + } |
|
| 283 | + } |
|
| 284 | + $post_attachment .= '<br>'; |
|
| 285 | + } |
|
| 286 | + } |
|
| 287 | + |
|
| 288 | + return $post_attachment; |
|
| 289 | + } |
|
| 290 | + // attachment functions |
|
| 291 | + // //////////////////////////////////////////////////////////////////////////////////// |
|
| 292 | + |
|
| 293 | + /** |
|
| 294 | + * @param string $poster_name |
|
| 295 | + * @param string $post_editmsg |
|
| 296 | + * @return bool |
|
| 297 | + */ |
|
| 298 | + public function setPostEdit($poster_name = '', $post_editmsg = '') |
|
| 299 | + { |
|
| 300 | + $edit_user = ''; |
|
| 301 | + if (empty($GLOBALS['xoopsModuleConfig']['recordedit_timelimit']) |
|
| 302 | + || (time() - $this->getVar('post_time')) < $GLOBALS['xoopsModuleConfig']['recordedit_timelimit'] * 60 |
|
| 303 | + || $this->getVar('approved') < 1) { |
|
| 304 | + return true; |
|
| 305 | + } |
|
| 306 | + if (is_object($GLOBALS['xoopsUser']) && $GLOBALS['xoopsUser']->isActive()) { |
|
| 307 | + if ($GLOBALS['xoopsModuleConfig']['show_realname'] && $GLOBALS['xoopsUser']->getVar('name')) { |
|
| 308 | + $edit_user = $GLOBALS['xoopsUser']->getVar('name'); |
|
| 309 | + } else { |
|
| 310 | + $edit_user = $GLOBALS['xoopsUser']->getVar('uname'); |
|
| 311 | + } |
|
| 312 | + } |
|
| 313 | + $post_edit = []; |
|
| 314 | + $post_edit['edit_user'] = $edit_user; // (?) The proper way is to store uid instead of name. |
|
| 315 | + // However, to save queries when displaying, the current way is ok. |
|
| 316 | + $post_edit['edit_time'] = time(); |
|
| 317 | + $post_edit['edit_msg'] = $post_editmsg; |
|
| 318 | + |
|
| 319 | + $post_edits = $this->getVar('post_edit'); |
|
| 320 | + if (!empty($post_edits)) { |
|
| 321 | + $post_edits = unserialize(base64_decode($post_edits)); |
|
| 322 | + } |
|
| 323 | + if (!is_array($post_edits)) { |
|
| 324 | + $post_edits = []; |
|
| 325 | + } |
|
| 326 | + $post_edits[] = $post_edit; |
|
| 327 | + $post_edit = base64_encode(serialize($post_edits)); |
|
| 328 | + unset($post_edits); |
|
| 329 | + $this->setVar('post_edit', $post_edit); |
|
| 330 | + |
|
| 331 | + return true; |
|
| 332 | + } |
|
| 333 | + |
|
| 334 | + /** |
|
| 335 | + * @return bool|string |
|
| 336 | + */ |
|
| 337 | + public function displayPostEdit() |
|
| 338 | + { |
|
| 339 | + global $myts; |
|
| 340 | + |
|
| 341 | + if (empty($GLOBALS['xoopsModuleConfig']['recordedit_timelimit'])) { |
|
| 342 | + return false; |
|
| 343 | + } |
|
| 344 | + |
|
| 345 | + $post_edit = ''; |
|
| 346 | + $post_edits = $this->getVar('post_edit'); |
|
| 347 | + if (!empty($post_edits)) { |
|
| 348 | + $post_edits = unserialize(base64_decode($post_edits)); |
|
| 349 | + } |
|
| 350 | + if (!isset($post_edits) || !is_array($post_edits)) { |
|
| 351 | + $post_edits = []; |
|
| 352 | + } |
|
| 353 | + if (is_array($post_edits) && count($post_edits) > 0) { |
|
| 354 | + foreach ($post_edits as $postedit) { |
|
| 355 | + $edit_time = (int)$postedit['edit_time']; |
|
| 356 | + $edit_user = $postedit['edit_user']; |
|
| 357 | + $edit_msg = !empty($postedit['edit_msg']) ? $postedit['edit_msg'] : ''; |
|
| 358 | + // Start irmtfan add option to do only the latest edit when do_latestedit=0 (Alfred) |
|
| 359 | + if (empty($GLOBALS['xoopsModuleConfig']['do_latestedit'])) { |
|
| 360 | + $post_edit = ''; |
|
| 361 | + } |
|
| 362 | + // End irmtfan add option to do only the latest edit when do_latestedit=0 (Alfred) |
|
| 363 | + // START hacked by irmtfan |
|
| 364 | + // display/save all edit records. |
|
| 365 | + $post_edit .= _MD_NEWBB_EDITEDBY . ' ' . $edit_user . ' ' . _MD_NEWBB_ON . ' ' . formatTimestamp($edit_time) . '<br>'; |
|
| 366 | + // if reason is not empty |
|
| 367 | + if ('' !== $edit_msg) { |
|
| 368 | + $post_edit .= _MD_NEWBB_EDITEDMSG . ' ' . $edit_msg . '<br>'; |
|
| 369 | + } |
|
| 370 | + // START hacked by irmtfan |
|
| 371 | + } |
|
| 372 | + } |
|
| 373 | + |
|
| 374 | + return $post_edit; |
|
| 375 | + } |
|
| 376 | + |
|
| 377 | + /** |
|
| 378 | + * @return array |
|
| 379 | + */ |
|
| 380 | + public function &getPostBody() |
|
| 381 | + { |
|
| 382 | + global $viewtopic_users; |
|
| 383 | + $newbbConfig = newbbLoadConfig(); |
|
| 384 | + require_once dirname(__DIR__) . '/include/functions.user.php'; |
|
| 385 | + require_once dirname(__DIR__) . '/include/functions.render.php'; |
|
| 386 | + |
|
| 387 | + $uid = is_object($GLOBALS['xoopsUser']) ? $GLOBALS['xoopsUser']->getVar('uid') : 0; |
|
| 388 | + /** @var KarmaHandler $karmaHandler */ |
|
| 389 | + $karmaHandler = Newbb\Helper::getInstance()->getHandler('Karma'); |
|
| 390 | + $user_karma = $karmaHandler->getUserKarma(); |
|
| 391 | + |
|
| 392 | + $post = []; |
|
| 393 | + $post['attachment'] = false; |
|
| 394 | + $post_text = newbbDisplayTarea($this->vars['post_text']['value'], $this->getVar('dohtml'), $this->getVar('dosmiley'), $this->getVar('doxcode'), $this->getVar('doimage'), $this->getVar('dobr')); |
|
| 395 | + if (newbbIsAdmin($this->getVar('forum_id')) || $this->checkIdentity()) { |
|
| 396 | + $post['text'] = $post_text . '<br>' . $this->displayAttachment(); |
|
| 397 | + } elseif ($newbbConfig['enable_karma'] && $this->getVar('post_karma') > $user_karma) { |
|
| 398 | + $post['text'] = sprintf(_MD_NEWBB_KARMA_REQUIREMENT, $user_karma, $this->getVar('post_karma')); |
|
| 399 | + } elseif ($newbbConfig['allow_require_reply'] && $this->getVar('require_reply') |
|
| 400 | + && (!$uid || !isset($viewtopic_users[$uid]))) { |
|
| 401 | + $post['text'] = _MD_NEWBB_REPLY_REQUIREMENT; |
|
| 402 | + } else { |
|
| 403 | + $post['text'] = $post_text . '<br>' . $this->displayAttachment(); |
|
| 404 | + } |
|
| 405 | + /** @var \XoopsMemberHandler $memberHandler */ |
|
| 406 | + $memberHandler = xoops_getHandler('member'); |
|
| 407 | + $eachposter = $memberHandler->getUser($this->getVar('uid')); |
|
| 408 | + if (is_object($eachposter) && $eachposter->isActive()) { |
|
| 409 | + if ($newbbConfig['show_realname'] && $eachposter->getVar('name')) { |
|
| 410 | + $post['author'] = $eachposter->getVar('name'); |
|
| 411 | + } else { |
|
| 412 | + $post['author'] = $eachposter->getVar('uname'); |
|
| 413 | + } |
|
| 414 | + unset($eachposter); |
|
| 415 | + } else { |
|
| 416 | + $post['author'] = $this->getVar('poster_name') ?: $GLOBALS['xoopsConfig']['anonymous']; |
|
| 417 | + } |
|
| 418 | + |
|
| 419 | + $post['subject'] = newbbHtmlspecialchars($this->vars['subject']['value']); |
|
| 420 | + |
|
| 421 | + $post['date'] = $this->getVar('post_time'); |
|
| 422 | + |
|
| 423 | + return $post; |
|
| 424 | + } |
|
| 425 | + |
|
| 426 | + /** |
|
| 427 | + * @return bool |
|
| 428 | + */ |
|
| 429 | + public function isTopic() |
|
| 430 | + { |
|
| 431 | + return !$this->getVar('pid'); |
|
| 432 | + } |
|
| 433 | + |
|
| 434 | + /** |
|
| 435 | + * @param string $action_tag |
|
| 436 | + * @return bool |
|
| 437 | + */ |
|
| 438 | + public function checkTimelimit($action_tag = 'edit_timelimit') |
|
| 439 | + { |
|
| 440 | + $newbbConfig = newbbLoadConfig(); |
|
| 441 | + if (empty($newbbConfig['edit_timelimit'])) { |
|
| 442 | + return true; |
|
| 443 | + } |
|
| 444 | + |
|
| 445 | + return ($this->getVar('post_time') > time() - $newbbConfig[$action_tag] * 60); |
|
| 446 | + } |
|
| 447 | + |
|
| 448 | + /** |
|
| 449 | + * @param int $uid |
|
| 450 | + * @return bool |
|
| 451 | + */ |
|
| 452 | + public function checkIdentity($uid = -1) |
|
| 453 | + { |
|
| 454 | + $uid = ($uid > -1) ? $uid : (is_object($GLOBALS['xoopsUser']) ? $GLOBALS['xoopsUser']->getVar('uid') : 0); |
|
| 455 | + if ($this->getVar('uid') > 0) { |
|
| 456 | + $user_ok = ($uid == $this->getVar('uid')); |
|
| 457 | + } else { |
|
| 458 | + static $user_ip; |
|
| 459 | + if (!isset($user_ip)) { |
|
| 460 | + $user_ip = \Xmf\IPAddress::fromRequest()->asReadable(); |
|
| 461 | + } |
|
| 462 | + $user_ok = ($user_ip == $this->getVar('poster_ip')); |
|
| 463 | + } |
|
| 464 | + |
|
| 465 | + return $user_ok; |
|
| 466 | + } |
|
| 467 | + |
|
| 468 | + // TODO: cleaning up and merge with post hanldings in viewpost.php |
|
| 469 | + |
|
| 470 | + /** |
|
| 471 | + * @param $isAdmin |
|
| 472 | + * @return array |
|
| 473 | + */ |
|
| 474 | + public function showPost($isAdmin) |
|
| 475 | + { |
|
| 476 | + global $xoopsModule, $myts; |
|
| 477 | + global $forumUrl, $forumImage, $forumObject, $online, $viewmode; |
|
| 478 | + global $viewtopic_users, $viewtopic_posters, $topicObject, $user_karma; |
|
| 479 | + global $order, $start, $total_posts, $topic_status; |
|
| 480 | + static $post_NO = 0; |
|
| 481 | + static $name_anonymous; |
|
| 482 | + /** @var TopicHandler $topicHandler */ |
|
| 483 | + $topicHandler = Newbb\Helper::getInstance()->getHandler('Topic'); |
|
| 484 | + if (null === $name_anonymous) { |
|
| 485 | + $name_anonymous = $myts->htmlSpecialChars($GLOBALS['xoopsConfig']['anonymous']); |
|
| 486 | + } |
|
| 487 | + |
|
| 488 | + require_once dirname(__DIR__) . '/include/functions.time.php'; |
|
| 489 | + require_once dirname(__DIR__) . '/include/functions.render.php'; |
|
| 490 | + |
|
| 491 | + $post_id = $this->getVar('post_id'); |
|
| 492 | + $topic_id = $this->getVar('topic_id'); |
|
| 493 | + $forum_id = $this->getVar('forum_id'); |
|
| 494 | + |
|
| 495 | + $query_vars = ['status', 'order', 'start', 'mode', 'viewmode']; |
|
| 496 | + $query_array = []; |
|
| 497 | + $query_array['topic_id'] = "topic_id={$topic_id}"; |
|
| 498 | + foreach ($query_vars as $var) { |
|
| 499 | + if (Request::getString($var, '', 'GET')) { |
|
| 500 | + $query_array[$var] = "{$var}=" . Request::getString($var, '', 'GET'); |
|
| 501 | + } |
|
| 502 | + } |
|
| 503 | + $page_query = htmlspecialchars(implode('&', array_values($query_array)), ENT_QUOTES | ENT_HTML5); |
|
| 504 | + |
|
| 505 | + $uid = is_object($GLOBALS['xoopsUser']) ? $GLOBALS['xoopsUser']->getVar('uid') : 0; |
|
| 506 | + |
|
| 507 | + ++$post_NO; |
|
| 508 | + if ('desc' === strtolower($order)) { |
|
| 509 | + $post_no = $total_posts - ($start + $post_NO) + 1; |
|
| 510 | + } else { |
|
| 511 | + $post_no = $start + $post_NO; |
|
| 512 | + } |
|
| 513 | + |
|
| 514 | + if ($isAdmin || $this->checkIdentity()) { |
|
| 515 | + $post_text = $this->getVar('post_text'); |
|
| 516 | + $post_attachment = $this->displayAttachment(); |
|
| 517 | + } elseif ($GLOBALS['xoopsModuleConfig']['enable_karma'] && $this->getVar('post_karma') > $user_karma) { |
|
| 518 | + $post_text = "<div class='karma'>" . sprintf(_MD_NEWBB_KARMA_REQUIREMENT, $user_karma, $this->getVar('post_karma')) . '</div>'; |
|
| 519 | + $post_attachment = ''; |
|
| 520 | + } elseif ($GLOBALS['xoopsModuleConfig']['allow_require_reply'] && $this->getVar('require_reply') |
|
| 521 | + && (!$uid || !in_array($uid, $viewtopic_posters))) { |
|
| 522 | + $post_text = "<div class='karma'>" . _MD_NEWBB_REPLY_REQUIREMENT . '</div>'; |
|
| 523 | + $post_attachment = ''; |
|
| 524 | + } else { |
|
| 525 | + $post_text = $this->getVar('post_text'); |
|
| 526 | + $post_attachment = $this->displayAttachment(); |
|
| 527 | + } |
|
| 528 | + |
|
| 529 | + // Hightlight search words |
|
| 530 | + $post_title = $this->getVar('subject'); |
|
| 531 | + if ($keywords = Request::getString('keywords', '', 'GET')) { |
|
| 532 | + //$keywords = $myts->htmlSpecialChars(trim(urldecode(Request::getString('keywords', '', 'GET')))); |
|
| 533 | + $post_text = Highlighter::apply($keywords, $post_text, '<mark>', '</mark>'); |
|
| 534 | + $post_title = Highlighter::apply($keywords, $post_title, '<mark>', '</mark>'); |
|
| 535 | + } |
|
| 536 | + |
|
| 537 | + if (isset($viewtopic_users[$this->getVar('uid')])) { |
|
| 538 | + $poster = $viewtopic_users[$this->getVar('uid')]; |
|
| 539 | + } else { |
|
| 540 | + $name = ($post_name = $this->getVar('poster_name')) ? $post_name : $name_anonymous; |
|
| 541 | + $poster = [ |
|
| 542 | + 'poster_uid' => 0, |
|
| 543 | + 'name' => $name, |
|
| 544 | + 'link' => $name |
|
| 545 | + ]; |
|
| 546 | + } |
|
| 547 | + |
|
| 548 | + if ($posticon = $this->getVar('icon')) { |
|
| 549 | + $post_image = '<a name="' . $post_id . '"><img src="' . XOOPS_URL . '/images/subject/' . $posticon . '" alt="" /></a>'; |
|
| 550 | + } else { |
|
| 551 | + $post_image = '<a name="' . $post_id . '"><img src="' . XOOPS_URL . '/images/icons/posticon.gif" alt="" /></a>'; |
|
| 552 | + } |
|
| 553 | + |
|
| 554 | + $thread_buttons = []; |
|
| 555 | + $mod_buttons = []; |
|
| 556 | + |
|
| 557 | + if ($isAdmin && ($GLOBALS['xoopsUser'] && $GLOBALS['xoopsUser']->getVar('uid') !== $this->getVar('uid')) |
|
| 558 | + && $this->getVar('uid') > 0) { |
|
| 559 | + $mod_buttons['bann']['image'] = newbbDisplayImage('p_bann', _MD_NEWBB_SUSPEND_MANAGEMENT); |
|
| 560 | + $mod_buttons['bann']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/moderate.php?forum=' . $forum_id . '&uid=' . $this->getVar('uid'); |
|
| 561 | + $mod_buttons['bann']['name'] = _MD_NEWBB_SUSPEND_MANAGEMENT; |
|
| 562 | + $thread_buttons['bann']['image'] = newbbDisplayImage('p_bann', _MD_NEWBB_SUSPEND_MANAGEMENT); |
|
| 563 | + $thread_buttons['bann']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/moderate.php?forum=' . $forum_id . '&uid=' . $this->getVar('uid'); |
|
| 564 | + $thread_buttons['bann']['name'] = _MD_NEWBB_SUSPEND_MANAGEMENT; |
|
| 565 | + } |
|
| 566 | + |
|
| 567 | + if ($GLOBALS['xoopsModuleConfig']['enable_permcheck']) { |
|
| 568 | + // /** @var TopicHandler $topicHandler */ |
|
| 569 | + // $topicHandler = Newbb\Helper::getInstance()->getHandler('Topic'); |
|
| 570 | + $topic_status = $topicObject->getVar('topic_status'); |
|
| 571 | + if ($topicHandler->getPermission($forum_id, $topic_status, 'edit')) { |
|
| 572 | + $edit_ok = ($isAdmin || ($this->checkIdentity() && $this->checkTimelimit('edit_timelimit'))); |
|
| 573 | + |
|
| 574 | + if ($edit_ok) { |
|
| 575 | + $thread_buttons['edit']['image'] = newbbDisplayImage('p_edit', _EDIT); |
|
| 576 | + $thread_buttons['edit']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/edit.php?{$page_query}"; |
|
| 577 | + $thread_buttons['edit']['name'] = _EDIT; |
|
| 578 | + $mod_buttons['edit']['image'] = newbbDisplayImage('p_edit', _EDIT); |
|
| 579 | + $mod_buttons['edit']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/edit.php?{$page_query}"; |
|
| 580 | + $mod_buttons['edit']['name'] = _EDIT; |
|
| 581 | + } |
|
| 582 | + } |
|
| 583 | + |
|
| 584 | + if ($topicHandler->getPermission($forum_id, $topic_status, 'delete')) { |
|
| 585 | + $delete_ok = ($isAdmin || ($this->checkIdentity() && $this->checkTimelimit('delete_timelimit'))); |
|
| 586 | + |
|
| 587 | + if ($delete_ok) { |
|
| 588 | + $thread_buttons['delete']['image'] = newbbDisplayImage('p_delete', _DELETE); |
|
| 589 | + $thread_buttons['delete']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/delete.php?{$page_query}"; |
|
| 590 | + $thread_buttons['delete']['name'] = _DELETE; |
|
| 591 | + $mod_buttons['delete']['image'] = newbbDisplayImage('p_delete', _DELETE); |
|
| 592 | + $mod_buttons['delete']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/delete.php?{$page_query}"; |
|
| 593 | + $mod_buttons['delete']['name'] = _DELETE; |
|
| 594 | + } |
|
| 595 | + } |
|
| 596 | + if ($topicHandler->getPermission($forum_id, $topic_status, 'reply')) { |
|
| 597 | + $thread_buttons['reply']['image'] = newbbDisplayImage('p_reply', _MD_NEWBB_REPLY); |
|
| 598 | + $thread_buttons['reply']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/reply.php?{$page_query}"; |
|
| 599 | + $thread_buttons['reply']['name'] = _MD_NEWBB_REPLY; |
|
| 600 | + |
|
| 601 | + $thread_buttons['quote']['image'] = newbbDisplayImage('p_quote', _MD_NEWBB_QUOTE); |
|
| 602 | + $thread_buttons['quote']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/reply.php?{$page_query}&quotedac=1"; |
|
| 603 | + $thread_buttons['quote']['name'] = _MD_NEWBB_QUOTE; |
|
| 604 | + } |
|
| 605 | + } else { |
|
| 606 | + $mod_buttons['edit']['image'] = newbbDisplayImage('p_edit', _EDIT); |
|
| 607 | + $mod_buttons['edit']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/edit.php?{$page_query}"; |
|
| 608 | + $mod_buttons['edit']['name'] = _EDIT; |
|
| 609 | + |
|
| 610 | + $mod_buttons['delete']['image'] = newbbDisplayImage('p_delete', _DELETE); |
|
| 611 | + $mod_buttons['delete']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/delete.php?{$page_query}"; |
|
| 612 | + $mod_buttons['delete']['name'] = _DELETE; |
|
| 613 | + |
|
| 614 | + $thread_buttons['reply']['image'] = newbbDisplayImage('p_reply', _MD_NEWBB_REPLY); |
|
| 615 | + $thread_buttons['reply']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/reply.php?{$page_query}"; |
|
| 616 | + $thread_buttons['reply']['name'] = _MD_NEWBB_REPLY; |
|
| 617 | + } |
|
| 618 | + |
|
| 619 | + if (!$isAdmin && $GLOBALS['xoopsModuleConfig']['reportmod_enabled']) { |
|
| 620 | + $thread_buttons['report']['image'] = newbbDisplayImage('p_report', _MD_NEWBB_REPORT); |
|
| 621 | + $thread_buttons['report']['link'] = XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . "/report.php?{$page_query}"; |
|
| 622 | + $thread_buttons['report']['name'] = _MD_NEWBB_REPORT; |
|
| 623 | + } |
|
| 624 | + |
|
| 625 | + $thread_action = []; |
|
| 626 | + // irmtfan add pdf permission |
|
| 627 | + if (file_exists(XOOPS_ROOT_PATH . '/class/libraries/vendor/tecnickcom/tcpdf/tcpdf.php') |
|
| 628 | + && $topicHandler->getPermission($forum_id, $topic_status, 'pdf')) { |
|
| 629 | + $thread_action['pdf']['image'] = newbbDisplayImage('pdf', _MD_NEWBB_PDF); |
|
| 630 | + $thread_action['pdf']['link'] = XOOPS_URL . '/modules/newbb/makepdf.php?type=post&pageid=0'; |
|
| 631 | + $thread_action['pdf']['name'] = _MD_NEWBB_PDF; |
|
| 632 | + $thread_action['pdf']['target'] = '_blank'; |
|
| 633 | + } |
|
| 634 | + // irmtfan add print permission |
|
| 635 | + if ($topicHandler->getPermission($forum_id, $topic_status, 'print')) { |
|
| 636 | + $thread_action['print']['image'] = newbbDisplayImage('printer', _MD_NEWBB_PRINT); |
|
| 637 | + $thread_action['print']['link'] = XOOPS_URL . '/modules/newbb/print.php?form=2&forum=' . $forum_id . '&topic_id=' . $topic_id; |
|
| 638 | + $thread_action['print']['name'] = _MD_NEWBB_PRINT; |
|
| 639 | + $thread_action['print']['target'] = '_blank'; |
|
| 640 | + } |
|
| 641 | + |
|
| 642 | + if ($GLOBALS['xoopsModuleConfig']['show_sociallinks']) { |
|
| 643 | + $full_title = $this->getVar('subject'); |
|
| 644 | + $clean_title = preg_replace('/[^A-Za-z0-9-]+/', '+', $this->getVar('subject')); |
|
| 645 | + $full_link = XOOPS_URL . '/modules/newbb/viewtopic.php?post_id=' . $post_id; |
|
| 646 | + |
|
| 647 | + $thread_action['social_twitter']['image'] = newbbDisplayImage('twitter', _MD_NEWBB_SHARE_TWITTER); |
|
| 648 | + $thread_action['social_twitter']['link'] = 'http://twitter.com/share?text=' . $clean_title . '&url=' . $full_link; |
|
| 649 | + $thread_action['social_twitter']['name'] = _MD_NEWBB_SHARE_TWITTER; |
|
| 650 | + $thread_action['social_twitter']['target'] = '_blank'; |
|
| 651 | + |
|
| 652 | + $thread_action['social_facebook']['image'] = newbbDisplayImage('facebook', _MD_NEWBB_SHARE_FACEBOOK); |
|
| 653 | + $thread_action['social_facebook']['link'] = 'http://www.facebook.com/sharer.php?u=' . $full_link; |
|
| 654 | + $thread_action['social_facebook']['name'] = _MD_NEWBB_SHARE_FACEBOOK; |
|
| 655 | + $thread_action['social_facebook']['target'] = '_blank'; |
|
| 656 | + |
|
| 657 | + $thread_action['social_gplus']['image'] = newbbDisplayImage('googleplus', _MD_NEWBB_SHARE_GOOGLEPLUS); |
|
| 658 | + $thread_action['social_gplus']['link'] = 'https://plusone.google.com/_/+1/confirm?hl=en&url=' . $full_link; |
|
| 659 | + $thread_action['social_gplus']['name'] = _MD_NEWBB_SHARE_GOOGLEPLUS; |
|
| 660 | + $thread_action['social_gplus']['target'] = '_blank'; |
|
| 661 | + |
|
| 662 | + $thread_action['social_linkedin']['image'] = newbbDisplayImage('linkedin', _MD_NEWBB_SHARE_LINKEDIN); |
|
| 663 | + $thread_action['social_linkedin']['link'] = 'http://www.linkedin.com/shareArticle?mini=true&title=' . $full_title . '&url=' . $full_link; |
|
| 664 | + $thread_action['social_linkedin']['name'] = _MD_NEWBB_SHARE_LINKEDIN; |
|
| 665 | + $thread_action['social_linkedin']['target'] = '_blank'; |
|
| 666 | + |
|
| 667 | + $thread_action['social_delicious']['image'] = newbbDisplayImage('delicious', _MD_NEWBB_SHARE_DELICIOUS); |
|
| 668 | + $thread_action['social_delicious']['link'] = 'http://del.icio.us/post?title=' . $full_title . '&url=' . $full_link; |
|
| 669 | + $thread_action['social_delicious']['name'] = _MD_NEWBB_SHARE_DELICIOUS; |
|
| 670 | + $thread_action['social_delicious']['target'] = '_blank'; |
|
| 671 | + |
|
| 672 | + $thread_action['social_digg']['image'] = newbbDisplayImage('digg', _MD_NEWBB_SHARE_DIGG); |
|
| 673 | + $thread_action['social_digg']['link'] = 'http://digg.com/submit?phase=2&title=' . $full_title . '&url=' . $full_link; |
|
| 674 | + $thread_action['social_digg']['name'] = _MD_NEWBB_SHARE_DIGG; |
|
| 675 | + $thread_action['social_digg']['target'] = '_blank'; |
|
| 676 | + |
|
| 677 | + $thread_action['social_reddit']['image'] = newbbDisplayImage('reddit', _MD_NEWBB_SHARE_REDDIT); |
|
| 678 | + $thread_action['social_reddit']['link'] = 'http://reddit.com/submit?title=' . $full_title . '&url=' . $full_link; |
|
| 679 | + $thread_action['social_reddit']['name'] = _MD_NEWBB_SHARE_REDDIT; |
|
| 680 | + $thread_action['social_reddit']['target'] = '_blank'; |
|
| 681 | + |
|
| 682 | + $thread_action['social_wong']['image'] = newbbDisplayImage('wong', _MD_NEWBB_SHARE_MRWONG); |
|
| 683 | + $thread_action['social_wong']['link'] = 'http://www.mister-wong.de/index.php?action=addurl&bm_url=' . $full_link; |
|
| 684 | + $thread_action['social_wong']['name'] = _MD_NEWBB_SHARE_MRWONG; |
|
| 685 | + $thread_action['social_wong']['target'] = '_blank'; |
|
| 686 | + } |
|
| 687 | + |
|
| 688 | + $post = [ |
|
| 689 | + 'post_id' => $post_id, |
|
| 690 | + 'post_parent_id' => $this->getVar('pid'), |
|
| 691 | + 'post_date' => newbbFormatTimestamp($this->getVar('post_time')), |
|
| 692 | + 'post_image' => $post_image, |
|
| 693 | + 'post_title' => $post_title, |
|
| 694 | + // irmtfan $post_title to add highlight keywords |
|
| 695 | + 'post_text' => $post_text, |
|
| 696 | + 'post_attachment' => $post_attachment, |
|
| 697 | + 'post_edit' => $this->displayPostEdit(), |
|
| 698 | + 'post_no' => $post_no, |
|
| 699 | + 'post_signature' => $this->getVar('attachsig') ? @$poster['signature'] : '', |
|
| 700 | + // 'poster_ip' => ($isAdmin && $GLOBALS['xoopsModuleConfig']['show_ip']) ? long2ip($this->getVar('poster_ip')) : '', |
|
| 701 | + 'poster_ip' => ($isAdmin |
|
| 702 | + && $GLOBALS['xoopsModuleConfig']['show_ip']) ? $this->getVar('poster_ip') : '', |
|
| 703 | + 'thread_action' => $thread_action, |
|
| 704 | + 'thread_buttons' => $thread_buttons, |
|
| 705 | + 'mod_buttons' => $mod_buttons, |
|
| 706 | + 'poster' => $poster, |
|
| 707 | + 'post_permalink' => '<a href="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/viewtopic.php?post_id=' . $post_id . '"></a>' |
|
| 708 | + ]; |
|
| 709 | + |
|
| 710 | + unset($thread_buttons, $mod_buttons, $eachposter); |
|
| 711 | + |
|
| 712 | + return $post; |
|
| 713 | + } |
|
| 714 | 714 | } |