admincp_feed.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339
  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_feed.php 31634 2012-09-17 06:43:39Z monkey $
  7. */
  8. if(!defined('IN_DISCUZ') || !defined('IN_ADMINCP')) {
  9. exit('Access Denied');
  10. }
  11. cpheader();
  12. $operation = $operation ? $operation : 'search';
  13. shownav('topic', 'nav_feed');
  14. $anchor = in_array($operation, array('search', 'global')) ? $operation : 'search';
  15. $current = array($anchor => 1);
  16. showsubmenu('nav_feed', array(
  17. array('nav_feed', 'feed', $current['search']),
  18. array('feed_global', 'feed&operation=global', $current['global']),
  19. ));
  20. if($operation == 'global') {
  21. if(!submitcheck('globalsubmit')) {
  22. $feedid = intval($_GET['feedid']);
  23. $feed = array();
  24. if($feedid) {
  25. $feed = C::t('home_feed')->fetch('', '', '', $feedid);
  26. if($feed['uid']) {
  27. require_once libfile('function/feed');
  28. $feed = mkfeed($feed);
  29. }
  30. $feed['body_template'] = dhtmlspecialchars($feed['body_template']);
  31. $feed['body_general'] = dhtmlspecialchars($feed['body_general']);
  32. $feed['dateline'] = dgmdate($feed['dateline'], 'Y-m-d H:i');
  33. }
  34. if(empty($feed['dateline'])) {
  35. $feed['dateline'] = dgmdate($_G['timestamp'], 'Y-m-d H:i');
  36. }
  37. showformheader('feed&operation=global', $feed['uid'] ? '' : 'onsubmit="edit_save();"');
  38. echo '<script type="text/javascript" src="'.STATICURL.'image/editor/editor_function.js"></script>';
  39. echo "<input type=\"hidden\" name=\"feednew[feedid]\" value=\"$feed[feedid]\" /><input type=\"hidden\" name=\"feednew[feeduid]\" value=\"$feed[uid]\" />";
  40. showtableheader();
  41. if(empty($feed['uid'])) {
  42. showsetting('feed_global_title', 'feednew[title_template]', $feed['title_template'], 'text');
  43. $src = 'home.php?mod=editor&charset='.CHARSET.'&allowhtml=1&doodle=0';
  44. print <<<EOF
  45. <tr><td>{$lang['message']}</td><td></td></tr>
  46. <tr>
  47. <td colspan="2">
  48. <textarea class="userData" name="feednew[body_template]" id="uchome-ttHtmlEditor" style="height:100%;width:100%;display:none;border:0px" onkeydown="textareakey(this, event)">$feed[body_template]</textarea>
  49. <iframe src="$src" name="uchome-ifrHtmlEditor" id="uchome-ifrHtmlEditor" scrolling="no" border="0" frameborder="0" style="width:100%;border: 1px solid #C5C5C5;" height="400"></iframe>
  50. <td>
  51. </tr>
  52. EOF;
  53. showsetting('feed_global_body_general', 'feednew[body_general]', $feed['body_general'], 'text');
  54. } else {
  55. print <<<EOF
  56. <tr><td class="td27">$lang[feed_global_title]</td><td></td></tr>
  57. <tr class="noborder"><td colspan="2">$feed[title_template]&nbsp;<td></tr>
  58. <tr><td class="td27">$lang[message]</td><td></td></tr>
  59. <tr class="noborder"><td colspan="2">$feed[body_template]&nbsp;<td></tr>
  60. <tr><td class="td27">$lang[feed_global_body_general]</td><td></td></tr>
  61. <tr class="noborder"><td colspan="2">$feed[body_general]&nbsp;<td></tr>
  62. EOF;
  63. }
  64. showsetting('feed_global_image_1', 'feednew[image_1]', $feed['image_1'], 'text');
  65. showsetting('feed_global_image_1_link', 'feednew[image_1_link]', $feed['image_1_link'], 'text');
  66. showsetting('feed_global_image_2', 'feednew[image_2]', $feed['image_2'], 'text');
  67. showsetting('feed_global_image_2_link', 'feednew[image_2_link]', $feed['image_2_link'], 'text');
  68. showsetting('feed_global_image_3', 'feednew[image_3]', $feed['image_3'], 'text');
  69. showsetting('feed_global_image_3_link', 'feednew[image_3_link]', $feed['image_3_link'], 'text');
  70. showsetting('feed_global_image_4', 'feednew[image_4]', $feed['image_4'], 'text');
  71. showsetting('feed_global_image_4_link', 'feednew[image_4_link]', $feed['image_4_link'], 'text');
  72. showsetting('feed_global_dateline', 'feednew[dateline]', $feed['dateline'], 'text');
  73. if($feed['id']) {
  74. showsetting('feed_global_hot', 'feednew[hot]', $feed['hot'], 'text');
  75. }
  76. showsubmit('globalsubmit');
  77. showtablefooter();
  78. showformfooter();
  79. } else {
  80. $feednew = getgpc('feednew');
  81. $feedid = intval($feednew['feedid']);
  82. if(empty($feednew['feeduid']) || empty($feedid)) {
  83. $setarr = array(
  84. 'title_template' => trim($feednew['title_template']),
  85. 'body_template' => trim($feednew['body_template'])
  86. );
  87. if(empty($setarr['title_template']) && empty($setarr['body_template'])) {
  88. cpmsg('sitefeed_error', '', 'error');
  89. }
  90. } else {
  91. $setarr = array();
  92. }
  93. $feednew['dateline'] = trim($feednew['dateline']);
  94. if($feednew['dateline']) {
  95. require_once libfile('function/home');
  96. $newtimestamp = strtotime($feednew['dateline']);
  97. if($newtimestamp > $_G['timestamp']) {
  98. $_G['timestamp'] = $newtimestamp;
  99. }
  100. }
  101. if(empty($feedid)) {
  102. $_G['uid'] = 0;
  103. require_once libfile('function/feed');
  104. $feedid = feed_add('sitefeed',
  105. trim($feednew['title_template']),array(),
  106. trim($feednew['body_template']),array(),
  107. trim($feednew['body_general']),
  108. array(trim($feednew['image_1']),trim($feednew['image_2']),trim($feednew['image_3']),trim($feednew['image_4'])),
  109. array(trim($feednew['image_1_link']),trim($feednew['image_2_link']),trim($feednew['image_3_link']),trim($feednew['image_4_link'])),
  110. '','','',1
  111. );
  112. } else {
  113. if(empty($feednew['feeduid'])) {
  114. $setarr['body_general'] = trim($feednew['body_general']);
  115. }
  116. $setarr['image_1'] = trim($feednew['image_1']);
  117. $setarr['image_1_link'] = trim($feednew['image_1_link']);
  118. $setarr['image_2'] = trim($feednew['image_2']);
  119. $setarr['image_2_link'] = trim($feednew['image_2_link']);
  120. $setarr['image_3'] = trim($feednew['image_3']);
  121. $setarr['image_3_link'] = trim($feednew['image_3_link']);
  122. $setarr['image_4'] = trim($feednew['image_4']);
  123. $setarr['image_4_link'] = trim($feednew['image_4_link']);
  124. $setarr['dateline'] = $newtimestamp;
  125. $setarr['hot'] = intval($feednew['hot']);
  126. C::t('home_feed')->update('', $setarr, '', '', $feedid);
  127. }
  128. cpmsg('feed_global_add_success', '', 'succeed');
  129. }
  130. } else {
  131. $detail = $_GET['detail'];
  132. $uid = $_GET['uid'];
  133. $users = $_GET['users'];
  134. $feedid = $_GET['feedid'];
  135. $icon = $_GET['icon'];
  136. $hot1 = $_GET['hot1'];
  137. $hot2 = $_GET['hot2'];
  138. $starttime = $_GET['starttime'];
  139. $endtime = $_GET['endtime'];
  140. $searchsubmit = $_GET['searchsubmit'];
  141. $feedids = $_GET['feedids'];
  142. $fromumanage = $_GET['fromumanage'] ? 1 : 0;
  143. showtips('feed_tips');
  144. if(!submitcheck('feedsubmit')) {
  145. if($fromumanage) {
  146. $starttime = !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $starttime) ? '' : $starttime;
  147. $endtime = $_G['adminid'] == 3 || !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $endtime) ? '' : $endtime;
  148. } else {
  149. $starttime = !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $starttime) ? dgmdate(TIMESTAMP - 86400 * 7, 'Y-n-j') : $starttime;
  150. $endtime = $_G['adminid'] == 3 || !preg_match("/^(0|\d{4}\-\d{1,2}\-\d{1,2})$/", $endtime) ? dgmdate(TIMESTAMP, 'Y-n-j') : $endtime;
  151. }
  152. echo <<<EOT
  153. <script type="text/javascript" src="static/js/calendar.js"></script>
  154. <script type="text/JavaScript">
  155. function page(number) {
  156. $('feedforum').page.value=number;
  157. $('feedforum').searchsubmit.click();
  158. }
  159. </script>
  160. EOT;
  161. showtagheader('div', 'searchposts', !$searchsubmit);
  162. showformheader("feed", '', 'feedforum');
  163. showhiddenfields(array('page' => $page, 'pp' => $_GET['pp'] ? $_GET['pp'] : $_GET['perpage']));
  164. showtableheader();
  165. showsetting('feed_search_detail', 'detail', $detail, 'radio');
  166. showsetting('feed_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>");
  167. $selected[$icon] = $icon ? 'selected="selected"' : '';
  168. showsetting('feed_search_icon', '', $icon, "<select name='icon'><option value=''>$lang[all]</option><option value='blog' $selected[blog]>$lang[feed_blog]</option>
  169. <option value='thread' $selected[thread]>$lang[feed_thread]</option><option value='album' $selected[album]>$lang[feed_album]</option><option value='doing' $selected[doing]>$lang[doing]</option>
  170. <option value='share' $selected[share]>$lang[shares]</option><option value='friend' $selected[friend]>$lang[feed_friend]</option><option value='poll' $selected[poll]>$lang[feed_poll]</option>
  171. <option value='comment' $selected[comment]>$lang[feed_comment]</option><option value='click' $selected[click]>$lang[feed_click]</option>
  172. <option value='show' $selected[show]>$lang[feed_show]</option><option value='profile' $selected[profile]>$lang[feed_profile]</option><option value='sitefeed' $selected[sitefeed]>$lang[feed_sitefeed]</option></select>");
  173. showsetting('feed_search_uid', 'uid', $uid, 'text');
  174. showsetting('feed_search_user', 'users', $users, 'text');
  175. showsetting('feed_search_feedid', 'feedid', $feedid, 'text');
  176. showsetting('feed_search_hot', array('hot1', 'hot2'), array('', ''), 'range');
  177. showsetting('feed_search_time', array('starttime', 'endtime'), array($starttime, $endtime), 'daterange');
  178. echo '<input type="hidden" name="fromumanage" value="'.$fromumanage.'">';
  179. showsubmit('searchsubmit');
  180. showtablefooter();
  181. showformfooter();
  182. showtagfooter('div');
  183. } else {
  184. $feedids = authcode($feedids, 'DECODE');
  185. $feedidsadd = $feedids ? explode(',', $feedids) : $_GET['delete'];
  186. include_once libfile('function/delete');
  187. $deletecount = count(deletefeeds($feedidsadd));
  188. $cpmsg = cplang('feed_succeed', array('deletecount' => $deletecount));
  189. ?>
  190. <script type="text/JavaScript">alert('<?php echo $cpmsg;?>');parent.$('feedforum').searchsubmit.click();</script>
  191. <?php
  192. }
  193. if(submitcheck('searchsubmit', 1)) {
  194. $feedids = $feedcount = '0';
  195. $sql = $error = '';
  196. $users = trim($users);
  197. if($users != '') {
  198. $uids = array(-1);
  199. $query = C::t('home_feed')->fetch_uid_by_username(explode(',', $users));
  200. $uids = array_keys($query) + $uids;
  201. }
  202. if($icon != '') {
  203. $feedarr = C::t('home_feed')->fetch_icon_by_icon($icon);
  204. $icon = $feedarr['icon'];
  205. if($icon == '') {
  206. $icon = '-1';
  207. }
  208. }
  209. if($starttime != '') {
  210. $starttime = strtotime($starttime);
  211. }
  212. if($_G['adminid'] == 1 && $endtime != dgmdate(TIMESTAMP, 'Y-n-j')) {
  213. if($endtime != '') {
  214. $endtime = strtotime($endtime);
  215. }
  216. } else {
  217. $endtime = TIMESTAMP;
  218. }
  219. if($feedid != '') {
  220. $feedids = array(-1);
  221. $query = C::t('home_feed')->fetch_feedid_by_feedid(explode(',', $feedid));
  222. $feedids = array_keys($query) + $feedids;
  223. }
  224. if($uid != '') {
  225. $query = C::t('home_feed')->fetch_uid_by_uid(explode(',', $uid));
  226. if(!$uids) {
  227. $uids = array_keys($query);
  228. } else {
  229. $uids = array_intersect(array_keys($query), $uids);
  230. }
  231. if(!$uids) {
  232. $uids = array(-1);
  233. }
  234. }
  235. if(($_G['adminid'] == 2 && $endtime - $starttime > 86400 * 16) || ($_G['adminid'] == 3 && $endtime - $starttime > 86400 * 8)) {
  236. $error = 'feed_mod_range_illegal';
  237. }
  238. if(!$error) {
  239. if($detail) {
  240. $_GET['perpage'] = intval($_GET['perpage']) < 1 ? 20 : intval($_GET['perpage']);
  241. $perpage = $_GET['pp'] ? $_GET['pp'] : $_GET['perpage'];
  242. $query = C::t('home_feed')->fetch_all_by_search(1, $uids, $icon, $starttime, $endtime, $feedids, $hot1, $hot2, (($page - 1) * $perpage), $perpage);
  243. $feeds = '';
  244. include_once libfile('function/feed');
  245. foreach ($query as $feed) {
  246. $feed['dateline'] = dgmdate($feed['dateline']);
  247. $feed = mkfeed($feed);
  248. $feeds .= showtablerow('', array('style="width:20px;"', 'style="width:260px;"', '', 'style="width:120px;"', 'style="width:60px;"'), array(
  249. "<input class=\"checkbox\" type=\"checkbox\" name=\"delete[]\" value=\"$feed[feedid]\" />",
  250. $feed['title_template'],
  251. $feed['body_template'],
  252. $feed['dateline'],
  253. '<a href="'.ADMINSCRIPT.'?action=feed&operation=global&feedid='.$feed['feedid'].'">'.$lang['edit'].'</a>'
  254. ), TRUE);
  255. }
  256. $feedcount = C::t('home_feed')->fetch_all_by_search(3, $uids, $icon, $starttime, $endtime, $feedids, $hot1, $hot2);
  257. $multi = multi($feedcount, $perpage, $page, ADMINSCRIPT."?action=feed");
  258. $multi = preg_replace("/href=\"".ADMINSCRIPT."\?action=feed&amp;page=(\d+)\"/", "href=\"javascript:page(\\1)\"", $multi);
  259. $multi = str_replace("window.location='".ADMINSCRIPT."?action=feed&amp;page='+this.value", "page(this.value)", $multi);
  260. } else {
  261. $feedcount = 0;
  262. $query = C::t('home_feed')->fetch_all_by_search(2, $uids, $icon, $starttime, $endtime, $feedids, $hot1, $hot2);
  263. foreach ($query as $feed) {
  264. $feedids .= ','.$feed['feedid'];
  265. $feedcount++;
  266. }
  267. $multi = '';
  268. }
  269. if(!$feedcount) {
  270. $error = 'feed_post_nonexistence';
  271. }
  272. }
  273. showtagheader('div', 'postlist', $searchsubmit);
  274. showformheader('feed&frame=no', 'target="feedframe"');
  275. showhiddenfields(array('feedids' => authcode($feedids, 'ENCODE')));
  276. showtableheader(cplang('feed_result').' '.$feedcount.' <a href="###" onclick="$(\'searchposts\').style.display=\'\';$(\'postlist\').style.display=\'none\';$(\'feedforum\').pp.value=\'\';$(\'feedforum\').page.value=\'\';" class="act lightlink normal">'.cplang('research').'</a>', 'fixpadding');
  277. if($error) {
  278. echo "<tr><td class=\"lineheight\" colspan=\"15\">$lang[$error]</td></tr>";
  279. } else {
  280. if($detail) {
  281. showsubtitle(array('', 'feed_title', 'feed_body', 'time', ''));
  282. echo $feeds;
  283. }
  284. }
  285. showsubmit('feedsubmit', 'delete', $detail ? 'del' : '', '', $multi);
  286. showtablefooter();
  287. showformfooter();
  288. echo '<iframe name="feedframe" style="display:none"></iframe>';
  289. showtagfooter('div');
  290. }
  291. }
  292. ?>