admincp_doing.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. <?php
  2. /**
  3. * [Discuz!] (C)2001-2099 Comsenz Inc.
  4. * This is NOT a freeware, use is subject to license terms
  5. *
  6. * $Id: admincp_doing.php 27696 2012-02-10 03:39:50Z svn_project_zhangjie $
  7. */
  8. if(!defined('IN_DISCUZ') || !defined('IN_ADMINCP')) {
  9. exit('Access Denied');
  10. }
  11. $detail = $_GET['detail'];
  12. $users = $_GET['users'];
  13. $userip = $_GET['userip'];
  14. $keywords = $_GET['keywords'];
  15. $lengthlimit = $_GET['lengthlimit'];
  16. $starttime = $_GET['starttime'];
  17. $endtime = $_GET['endtime'];
  18. $searchsubmit = $_GET['searchsubmit'];
  19. $doids = $_GET['doids'];
  20. $fromumanage = $_GET['fromumanage'] ? 1 : 0;
  21. cpheader();
  22. if(!submitcheck('doingsubmit')) {
  23. if(empty($_GET['search'])) {
  24. $newlist = 1;
  25. $detail = 1;
  26. }
  27. if($fromumanage) {
  28. $starttime = !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $starttime) ? '' : $starttime;
  29. $endtime = $_G['adminid'] == 3 || !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $endtime) ? '' : $endtime;
  30. } else {
  31. $starttime = !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $starttime) ? dgmdate(TIMESTAMP - 86400 * 7, 'Y-n-j') : $starttime;
  32. $endtime = $_G['adminid'] == 3 || !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $endtime) ? dgmdate(TIMESTAMP, 'Y-n-j') : $endtime;
  33. }
  34. shownav('topic', 'nav_doing');
  35. showsubmenu('nav_doing', array(
  36. array('newlist', 'doing', !empty($newlist)),
  37. array('search', 'doing&search=true', empty($newlist)),
  38. ));
  39. empty($newlist) && showsubmenusteps('', array(
  40. array('doing_search', !$searchsubmit),
  41. array('nav_doing', $searchsubmit)
  42. ));
  43. if(empty($newlist)) {
  44. $search_tips = 1;
  45. showtips('doing_tips');
  46. }
  47. echo <<<EOT
  48. <script type="text/javascript" src="static/js/calendar.js"></script>
  49. <script type="text/JavaScript">
  50. function page(number) {
  51. $('doingforum').page.value=number;
  52. $('doingforum').searchsubmit.click();
  53. }
  54. </script>
  55. EOT;
  56. showtagheader('div', 'searchposts', !$searchsubmit && empty($newlist));
  57. showformheader("doing".(!empty($_GET['search']) ? '&search=true' : ''), '', 'doingforum');
  58. showhiddenfields(array('page' => $page, 'pp' => $_GET['pp'] ? $_GET['pp'] : $_GET['perpage']));
  59. showtableheader();
  60. showsetting('doing_search_detail', 'detail', $detail, 'radio');
  61. showsetting('doing_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>");
  62. showsetting('doing_search_user', 'users', $users, 'text');
  63. showsetting('doing_search_ip', 'userip', $userip, 'text');
  64. showsetting('doing_search_keyword', 'keywords', $keywords, 'text');
  65. showsetting('doing_search_lengthlimit', 'lengthlimit', $lengthlimit, 'text');
  66. showsetting('doing_search_time', array('starttime', 'endtime'), array($starttime, $endtime), 'daterange');
  67. echo '<input type="hidden" name="fromumanage" value="'.$fromumanage.'">';
  68. showsubmit('searchsubmit');
  69. showtablefooter();
  70. showformfooter();
  71. showtagfooter('div');
  72. } else {
  73. $doids = authcode($doids, 'DECODE');
  74. $doidsadd = $doids ? explode(',', $doids) : $_GET['delete'];
  75. include_once libfile('function/delete');
  76. $deletecount = count(deletedoings($doidsadd));
  77. $cpmsg = cplang('doing_succeed', array('deletecount' => $deletecount));
  78. ?>
  79. <script type="text/JavaScript">alert('<?php echo $cpmsg;?>');parent.$('doingforum').searchsubmit.click();</script>
  80. <?php
  81. }
  82. if(submitcheck('searchsubmit', 1) || $newlist) {
  83. $doids = $doingcount = '0';
  84. $sql = $error = '';
  85. $keywords = trim($keywords);
  86. $users = trim($users);
  87. if($users != '') {
  88. $uids = C::t('common_member')->fetch_all_uid_by_username(array_map('trim', explode(',', $users)));
  89. if(!$uids) {
  90. $uids = array(-1);
  91. }
  92. }
  93. if(($_G['adminid'] == 2 && $endtime - $starttime > 86400 * 16) || ($_G['adminid'] == 3 && $endtime - $starttime > 86400 * 8)) {
  94. $error = 'prune_mod_range_illegal';
  95. }
  96. if(!($_G['adminid'] == 1 && $endtime != dgmdate(TIMESTAMP, 'Y-n-j'))) {
  97. $endtime = TIMESTAMP;
  98. }
  99. if(!$error) {
  100. if($detail) {
  101. $_GET['perpage'] = intval($_GET['perpage']) < 1 ? 20 : intval($_GET['perpage']);
  102. $perpage = $_GET['pp'] ? $_GET['pp'] : $_GET['perpage'];
  103. $query = C::t('home_doing')->fetch_all_search((($page - 1) * $perpage), $perpage, 1, $uids, $userip, $keywords, $lengthlimit, $starttime, $endtime);
  104. $doings = '';
  105. foreach ($query as $doing) {
  106. $doing['dateline'] = dgmdate($doing['dateline']);
  107. $doings .= showtablerow('', '', array(
  108. "<input class=\"checkbox\" type=\"checkbox\" name=\"delete[]\" value=\"$doing[doid]\" />",
  109. "<a href=\"home.php?mod=space&uid=$doing[uid]\" target=\"_blank\">$doing[username]</a>",
  110. $doing['message'],
  111. $doing['ip'],
  112. $doing['dateline']
  113. ), TRUE);
  114. }
  115. $doingcount = C::t('home_doing')->fetch_all_search((($page - 1) * $perpage), $perpage, 3, $uids, $userip, $keywords, $lengthlimit, $starttime, $endtime);
  116. $multi = multi($doingcount, $perpage, $page, ADMINSCRIPT."?action=doing");
  117. $multi = preg_replace("/href=\"".ADMINSCRIPT."\?action=doing&amp;page=(\d+)\"/", "href=\"javascript:page(\\1)\"", $multi);
  118. $multi = str_replace("window.location='".ADMINSCRIPT."?action=doing&amp;page='+this.value", "page(this.value)", $multi);
  119. } else {
  120. $doingcount = 0;
  121. $query = C::t('home_doing')->fetch_all_search((($page - 1) * $perpage), $perpage, 2, $uids, $userip, $keywords, $lengthlimit, $starttime, $endtime);
  122. foreach ($query as $doing) {
  123. $doids .= ','.$doing['doid'];
  124. $doingcount++;
  125. }
  126. $multi = '';
  127. }
  128. if(!$doingcount) {
  129. $error = 'doing_post_nonexistence';
  130. }
  131. }
  132. showtagheader('div', 'postlist', $searchsubmit || $newlist);
  133. showformheader('doing&frame=no', 'target="doingframe"');
  134. showhiddenfields(array('doids' => authcode($doids, 'ENCODE')));
  135. if(!$search_tips) {
  136. showtableheader(cplang('doing_new_result').' '.$doingcount, 'fixpadding');
  137. } else {
  138. showtableheader(cplang('doing_result').' '.$doingcount.(empty($newlist) ? ' <a href="###" onclick="$(\'searchposts\').style.display=\'\';$(\'postlist\').style.display=\'none\';$(\'doingforum\').pp.value=\'\';$(\'doingforum\').page.value=\'\';" class="act lightlink normal">'.cplang('research').'</a>' : ''), 'fixpadding');
  139. }
  140. if($error) {
  141. echo "<tr><td class=\"lineheight\" colspan=\"15\">$lang[$error]</td></tr>";
  142. } else {
  143. if($detail) {
  144. showsubtitle(array('', 'author', 'message', 'ip', 'time'));
  145. echo $doings;
  146. }
  147. }
  148. showsubmit('doingsubmit', 'delete', $detail ? 'del' : '', '', $multi);
  149. showtablefooter();
  150. showformfooter();
  151. echo '<iframe name="doingframe" style="display:none"></iframe>';
  152. showtagfooter('div');
  153. }
  154. ?>