www.gusucode.com > 迪恩育儿亲子4商城商家+手机版【整站带测试数据】源码程序 > web/source/admincp/admincp_comment.php
<?php /** * [Discuz!] (C)2001-2099 Comsenz Inc. * This is NOT a freeware, use is subject to license terms * * $Id: admincp_comment.php 28774 2012-03-12 10:09:50Z chenmengshu $ */ if(!defined('IN_DISCUZ') || !defined('IN_ADMINCP')) { exit('Access Denied'); } $detail = $_GET['detail']; $idtype = $_GET['idtype']; $id = $_GET['id']; $author = $_GET['author']; $authorid = $_GET['authorid']; $uid = $_GET['uid']; $message = $_GET['message']; $ip = $_GET['ip']; $users = $_GET['users']; $starttime = $_GET['starttime']; $endtime = $_GET['endtime']; $searchsubmit = $_GET['searchsubmit']; $cids = $_GET['cids']; $page = max(1, $_GET['page']); $fromumanage = $_GET['fromumanage'] ? 1 : 0; cpheader(); if(empty($operation)) { if(!submitcheck('commentsubmit')) { if($fromumanage) { $starttime = !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $starttime) ? '' : $starttime; $endtime = $_G['adminid'] == 3 || !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $endtime) ? '' : $endtime; } else { $starttime = !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $starttime) ? dgmdate(TIMESTAMP - 86400 * 7, 'Y-n-j') : $starttime; $endtime = $_G['adminid'] == 3 || !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $endtime) ? dgmdate(TIMESTAMP, 'Y-n-j') : $endtime; } shownav('topic', 'nav_comment'); showsubmenu('nav_comment', array( array('comment_comment', 'comment', 1), array('comment_article_comment', 'comment&operation=article', 0), array('comment_topic_comment', 'comment&operation=topic', 0) )); showtips('comment_tips'); echo <<<EOT <script type="text/javascript" src="static/js/calendar.js"></script> <script type="text/JavaScript"> function page(number) { $('commentforum').page.value=number; $('commentforum').searchsubmit.click(); } </script> EOT; showtagheader('div', 'searchposts', !$searchsubmit); showformheader("comment", '', 'commentforum'); showhiddenfields(array('page' => $page, 'pp' => $_GET['pp'] ? $_GET['pp'] : $_GET['perpage'])); showtableheader(); showsetting('comment_search_detail', 'detail', $detail, 'radio'); showsetting('comment_search_perpage', '', $_GET['perpage'], "<select name='perpage'><option value='20'>$lang[perpage_20]</option><option value='50'>$lang[perpage_50]</option><option value='100'>$lang[perpage_100]</option></select>"); showsetting('comment_idtype', array('idtype', array( array('', $lang['all']), array('uid', $lang['comment_uid']), array('blogid', $lang['comment_blogid']), array('picid', $lang['comment_picid']), array('sid', $lang['comment_sid']), )), 'comment_idtype', 'select'); showsetting('comment_search_id', 'id', $id, 'text'); showsetting('comment_search_author', 'author', $author, 'text'); showsetting('comment_search_authorid', 'authorid', $authorid, 'text'); showsetting('comment_search_uid', 'uid', $uid, 'text'); showsetting('comment_search_message', 'message', $message, 'text'); showsetting('comment_search_ip', 'ip', $ip, 'text'); showsetting('comment_search_time', array('starttime', 'endtime'), array($starttime, $endtime), 'daterange'); echo '<input type="hidden" name="fromumanage" value="'.$fromumanage.'">'; showsubmit('searchsubmit'); showtablefooter(); showformfooter(); showtagfooter('div'); } else { $cids = authcode($cids, 'DECODE'); $cidsadd = $cids ? explode(',', $cids) : $_GET['delete']; include_once libfile('function/delete'); $deletecount = count(deletecomments($cidsadd)); $cpmsg = cplang('comment_succeed', array('deletecount' => $deletecount)); ?> <script type="text/JavaScript">alert('<?php echo $cpmsg;?>');parent.$('commentforum').searchsubmit.click();</script> <?php } if(submitcheck('searchsubmit', 1)) { $comments = $commentcount = '0'; $sql = $error = ''; $authorids = array(); $author = trim($author); if($id !='') { $id = explode(',', $id); } if($author != '') { $authorids = C::t('common_member')->fetch_all_uid_by_username(array_map('trim', explode(',', $author))); if (!$authorids) { $authorids = array(-1); } } $authorid = trim($authorid, ', '); if($authorid != '') { if (!$authorids) { $authorids = explode(',', $authorid); } else { $authorids = array_intersect($authorids, explode(',', $authorid)); } if (!$authorids) { $authorids = array(-1); } } if($_G['adminid'] == 1 && $endtime != dgmdate(TIMESTAMP, 'Y-n-j')) { if($endtime != '') { $endtime = strtotime($endtime); } } else { $endtime = TIMESTAMP; } if(($_G['adminid'] == 2 && $endtime - $starttime > 86400 * 16) || ($_G['adminid'] == 3 && $endtime - $starttime > 86400 * 8)) { $error = 'comment_mod_range_illegal'; } $uid = trim($uid, ', '); if($uid !='') { $uid = explode(',', $uid); } if(!$error) { if($commentcount = C::t('home_comment')->fetch_all_search(3, $id, $authorids, $uid, $ip, $message, $idtype, $starttime, $endtime)) { if($detail) { $_GET['perpage'] = intval($_GET['perpage']) < 1 ? 20 : intval($_GET['perpage']); $perpage = $_GET['pp'] ? $_GET['pp'] : $_GET['perpage']; $query = C::t('home_comment')->fetch_all_search(1, $id, $authorids, $uid, $ip, $message, $idtype, $starttime, $endtime, (($page - 1) * $perpage), $perpage); $comments = ''; foreach ($query as $comment) { $comment['dateline'] = dgmdate($comment['dateline']); switch($comment['idtype']) { case 'picid': $address = "<a href=\"home.php?mod=space&uid=$comment[uid]&do=album&picid=$comment[id]\" target=\"_blank\">$comment[message]</a>"; break; case 'uid': $address = "<a href=\"home.php?mod=space&uid=$comment[uid]&do=wall\" target=\"_blank\">$comment[message]</a>"; break; case 'sid': $address = "<a href=\"home.php?mod=space&uid=1&do=share&id=$comment[id]\" target=\"_blank\">$comment[message]</a>"; break; case 'blogid': $address = "<a href=\"home.php?mod=space&uid=$comment[uid]&do=blog&id=$comment[id]\" target=\"_blank\">$comment[message]</a>"; break; } $comments .= showtablerow('', '', array( "<input class=\"checkbox\" type=\"checkbox\" name=\"delete[]\" value=\"$comment[cid]\" />", $address, "<a href=\"home.php?mod=space&uid=$comment[uid]\" target=\"_blank\">$comment[author]</a>", $comment['ip'], $comment['idtype'], $comment['dateline'] ), TRUE); } $multi = multi($commentcount, $perpage, $page, ADMINSCRIPT."?action=comment"); $multi = preg_replace("/href=\"".ADMINSCRIPT."\?action=comment&page=(\d+)\"/", "href=\"javascript:page(\\1)\"", $multi); $multi = str_replace("window.location='".ADMINSCRIPT."?action=comment&page='+this.value", "page(this.value)", $multi); } else { $query = C::t('home_comment')->fetch_all_search(2, $id, $authorids, $uid, $ip, $message, $idtype, $starttime, $endtime); foreach ($query as $comment) { $cids .= ','.$comment['cid']; } } } else $error = 'comment_post_nonexistence'; } showtagheader('div', 'postlist', $searchsubmit); showformheader('comment&frame=no', 'target="commentframe"'); showhiddenfields(array('cids' => authcode($cids, 'ENCODE'))); showtableheader(cplang('comment_result').' '.$commentcount.' <a href="###" onclick="$(\'searchposts\').style.display=\'\';$(\'postlist\').style.display=\'none\';$(\'commentforum\').pp.value=\'\';$(\'commentforum\').page.value=\'\';" class="act lightlink normal">'.cplang('research').'</a>', 'fixpadding'); if($error) { echo "<tr><td class=\"lineheight\" colspan=\"15\">$lang[$error]</td></tr>"; } else { if($detail) { showsubtitle(array('', 'message', 'author', 'ip', 'comment_idtype', 'time')); echo $comments; } } showsubmit('commentsubmit', 'delete', $detail ? 'del' : '', '', $multi); showtablefooter(); showformfooter(); echo '<iframe name="commentframe" style="display:none"></iframe>'; showtagfooter('div'); } } if($operation == 'article' || $operation == 'topic') { $aid = $_GET['aid']; $subject = $_GET['subject']; $idtype = $operation == 'article' ? 'aid' : 'topicid'; $tablename = $idtype == 'aid' ? 'portal_article_title' : 'portal_topic'; if(!submitcheck('articlesubmit')) { $starttime = !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $starttime) ? dgmdate(TIMESTAMP - 86400 * 7, 'Y-n-j') : $starttime; $endtime = $_G['adminid'] == 3 || !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $endtime) ? dgmdate(TIMESTAMP, 'Y-n-j') : $endtime; shownav('topic', 'nav_comment'); showsubmenu('nav_comment', array( array('comment_comment', 'comment', 0), array('comment_article_comment', 'comment&operation=article', $operation == 'article' ? 1 : 0), array('comment_topic_comment', 'comment&operation=topic', $operation == 'topic' ? 1 : 0) )); showtips('comment_'.$operation.'_tips'); echo <<<EOT <script type="text/javascript" src="static/js/calendar.js"></script> <script type="text/JavaScript"> function page(number) { $('articleforum').page.value=number; $('articleforum').searchsubmit.click(); } </script> EOT; showtagheader('div', 'searchposts', !$searchsubmit); showformheader("comment&operation=$operation", '', 'articleforum'); showhiddenfields(array('page' => $page, 'pp' => $_GET['pp'] ? $_GET['pp'] : $_GET['perpage'])); showtableheader(); showsetting('comment_search_perpage', '', $_GET['perpage'], "<select name='perpage'><option value='20'>$lang[perpage_20]</option><option value='50'>$lang[perpage_50]</option><option value='100'>$lang[perpage_100]</option></select>"); showsetting("comment_{$operation}_subject", 'subject', $subject, 'text'); showsetting("comment_{$operation}_id", 'aid', $aid, 'text'); showsetting('comment_search_message', 'message', $message, 'text'); showsetting('comment_search_author', 'author', $author, 'text'); showsetting('comment_search_authorid', 'authorid', $authorid, 'text'); showsetting('comment_search_time', array('starttime', 'endtime'), array($starttime, $endtime), 'daterange'); showsubmit('searchsubmit'); showtablefooter(); showformfooter(); showtagfooter('div'); } else { $commentnum = array(); foreach(C::t('portal_comment')->fetch_all($_GET['delete']) as $value) { $commentnum[$value['idtype']][$value['id']] = $value['id']; } if($commentnum['aid']) { C::t('portal_article_count')->increase($commentnum['aid'], array('commentnum' => -1)); } elseif($commentnum['topicid']) { C::t('portal_topic')->increase($commentnum['topicid'], array('commentnum' => -1)); } C::t('portal_comment')->delete($_GET['delete']); $cpmsg = cplang('comment_article_delete'); ?> <script type="text/JavaScript">alert('<?php echo $cpmsg;?>');parent.$('articleforum').searchsubmit.click();</script> <?php } if(submitcheck('searchsubmit')) { $comments = $commentcount = '0'; $sql = $error = ''; $author = trim($author); $queryAId = $aid ? array($aid) : array(); if($subject != '') { $ids = array(); $query = C::t($tablename)->fetch_all_by_title($idtype, $subject); foreach($query as $value) { $ids[] = intval($value[$idtype]); } $queryAId = array_merge($queryAId, $ids); } $queryAuthorIDs = $authorid ? array($authorid) : array(); if($author != '') { $authorids = C::t('common_member')->fetch_all_uid_by_username(array_map('trim', explode(',', $author))); $queryAuthorIDs = array_merge($queryAuthorIDs, $authorids); } if($starttime != '0') { $starttime = strtotime($starttime); } $sqlendtime = ''; if($_G['adminid'] == 1 && $endtime != dgmdate(TIMESTAMP, 'Y-n-j')) { if($endtime != '0') { $sqlendtime = $endtime = strtotime($endtime); } } else { $endtime = TIMESTAMP; } if(($_G['adminid'] == 2 && $endtime - $starttime > 86400 * 16) || ($_G['adminid'] == 3 && $endtime - $starttime > 86400 * 8)) { $error = 'comment_mod_range_illegal'; } if(!$error) { $commentcount = C::t('portal_comment')->count_all_by_search($queryAId, $queryAuthorIDs, $starttime, $sqlendtime, $idtype, $message); if($commentcount) { $_GET['perpage'] = intval($_GET['perpage']) < 1 ? 20 : intval($_GET['perpage']); $perpage = $_GET['pp'] ? $_GET['pp'] : $_GET['perpage']; $query = C::t('portal_comment')->fetch_all_by_search($queryAId, $queryAuthorIDs, $starttime, $sqlendtime, $idtype, $message, (($page - 1) * $perpage), $perpage); $comments = ''; $mod = $idtype == 'aid' ? 'view' : 'topic'; foreach($query as $comment) { $comment['dateline'] = dgmdate($comment['dateline']); $comments .= showtablerow('', '', array( "<input class=\"checkbox\" type=\"checkbox\" name=\"delete[]\" value=\"$comment[cid]\" />", "<a href=\"portal.php?mod=$mod&$idtype=$comment[id]\" target=\"_blank\">$comment[title]</a>", $comment[message], "<a href=\"home.php?mod=space&uid=$comment[uid]\" target=\"_blank\">$comment[username]</a>", $comment['dateline'] ), TRUE); } $multi = multi($commentcount, $perpage, $page, ADMINSCRIPT."?action=comment&operation=$operation"); $multi = preg_replace("/href=\"".ADMINSCRIPT."\?action=comment&operation=$operation&page=(\d+)\"/", "href=\"javascript:page(\\1)\"", $multi); $multi = str_replace("window.location='".ADMINSCRIPT."?action=comment&operation=$operation&page='+this.value", "page(this.value)", $multi); } else { $error = 'comment_post_nonexistence'; } } showtagheader('div', 'postlist', $searchsubmit); showformheader('comment&operation='.$operation.'&frame=no', 'target="articleframe"'); showtableheader(cplang('comment_result').' '.$commentcount.' <a href="###" onclick="$(\'searchposts\').style.display=\'\';$(\'postlist\').style.display=\'none\';$(\'articleforum\').pp.value=\'\';$(\'articleforum\').page.value=\'\';" class="act lightlink normal">'.cplang('research').'</a>', 'fixpadding'); if($error) { echo "<tr><td class=\"lineheight\" colspan=\"15\">$lang[$error]</td></tr>"; } else { showsubtitle(array('', 'article_title', 'message', 'author', 'time')); echo $comments; } showsubmit('articlesubmit', 'delete', 'del', '', $multi); showtablefooter(); showformfooter(); echo '<iframe name="articleframe" style="display:none"></iframe>'; showtagfooter('div'); } } ?>