国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

201 lines
8.2KB

  1. <?php
  2. /**
  3. * 修改专题
  4. *
  5. * @version $id:spec_edit.php 16:22 2010年7月20日 tianya $
  6. * @package DedeBIZ.Administrator
  7. * @copyright Copyright (c) 2022 DedeBIZ.COM
  8. * @license https://www.dedebiz.com/license
  9. * @link https://www.dedebiz.com
  10. */
  11. require_once(dirname(__FILE__)."/config.php");
  12. CheckPurview('a_Edit,a_AccEdit,a_MyEdit');
  13. require_once(DEDEINC."/customfields.func.php");
  14. require_once(DEDEADMIN."/inc/inc_archives_functions.php");
  15. if (empty($dopost)) $dopost = '';
  16. if ($dopost != 'save') {
  17. require_once(DEDEADMIN."/inc/inc_catalog_options.php");
  18. require_once(DEDEINC."/dedetag.class.php");
  19. ClearMyAddon();
  20. $aid = intval($aid);
  21. $channelid = -1;
  22. //读取归档信息
  23. $arcQuery = "SELECT ch.typename as channelname,ar.membername as rankname,arc.* FROM `#@__archives` arc LEFT JOIN `#@__channeltype` ch ON ch.id=arc.channel LEFT JOIN `#@__arcrank` ar ON ar.`rank`=arc.arcrank WHERE arc.id='$aid' ";
  24. $arcRow = $dsql->GetOne($arcQuery);
  25. if (!is_array($arcRow)) {
  26. ShowMsg("读取文档信息出错", "-1");
  27. exit();
  28. }
  29. $query = "SELECT * FROM `#@__channeltype` WHERE id='-1'";
  30. $cInfos = $dsql->GetOne($query);
  31. if (!is_array($cInfos)) {
  32. ShowMsg("读取栏目信息出错", "javascript:;");
  33. exit();
  34. }
  35. $addRow = $dsql->GetOne("SELECT * FROM `#@__addonspec` WHERE aid='$aid'");
  36. $tags = GetTags($aid);
  37. include DedeInclude("templets/spec_edit.htm");
  38. } else if ($dopost == 'save') {
  39. require_once(DEDEINC.'/image.func.php');
  40. require_once(DEDEINC.'/libraries/oxwindow.class.php');
  41. $flag = isset($flags) ? join(',', $flags) : '';
  42. $notpost = isset($notpost) && $notpost == 1 ? 1 : 0;
  43. if (!isset($tags)) $tags = '';
  44. $channelid = -1;
  45. //处理自定义字段会用到这些变量
  46. if (!isset($autokey)) $autokey = 0;
  47. if (!isset($remote)) $remote = 0;
  48. if (!isset($dellink)) $dellink = 0;
  49. if (!isset($autolitpic)) $autolitpic = 0;
  50. //对保存的文档进行处理
  51. $pubdate = GetMkTime($pubdate);
  52. $sortrank = AddDay($pubdate, $sortup);
  53. if ($ishtml == 0) $ismake = -1;
  54. else $ismake = 0;
  55. $title = cn_substrR($title, $cfg_title_maxlen);
  56. $shorttitle = cn_substrR($shorttitle, 36);
  57. $color = cn_substrR($color, 7);
  58. $writer = cn_substrR($writer, 20);
  59. $source = cn_substrR($source, 30);
  60. $description = cn_substrR($description, $cfg_auot_description);
  61. $keywords = trim(cn_substrR($keywords, 60));
  62. $filename = trim(cn_substrR($filename, 40));
  63. $isremote = 0;
  64. $serviterm = empty($serviterm) ? "" : $serviterm;
  65. if (!TestPurview('a_Check,a_AccCheck,a_MyCheck')) {
  66. $arcrank = -1;
  67. }
  68. $adminid = $cuserLogin->getUserID();
  69. //处理上传的缩略图
  70. if (empty($ddisremote)) {
  71. $ddisremote = 0;
  72. }
  73. $litpic = GetDDImage('none', $picname, $ddisremote);
  74. //分析处理附加表数据
  75. $inadd_f = '';
  76. $inadd_v = '';
  77. if (!empty($dede_addonfields)) {
  78. $addonfields = explode(';', $dede_addonfields);
  79. $inadd_f = '';
  80. $inadd_v = '';
  81. if (is_array($addonfields)) {
  82. foreach ($addonfields as $v) {
  83. if ($v == '') {
  84. continue;
  85. }
  86. $vs = explode(',', $v);
  87. if ($vs[1] == 'htmltext' || $vs[1] == 'textdata') //网页文本特殊处理
  88. {
  89. ${$vs[0]} = AnalyseHtmlBody(${$vs[0]}, $description, $litpic, $keywords, $vs[1]);
  90. } else {
  91. if (!isset(${$vs[0]})) {
  92. ${$vs[0]} = '';
  93. }
  94. ${$vs[0]} = GetFieldValueA(${$vs[0]}, $vs[1], $arcID);
  95. }
  96. $inadd_f .= ",`{$vs[0]}` = '".${$vs[0]}."'";
  97. }
  98. }
  99. }
  100. //处理图片文档的自定义属性
  101. if ($litpic != '' && !preg_match('#p#', $flag)) {
  102. $flag = ($flag == '' ? 'p' : $flag.',p');
  103. }
  104. $inQuery = "UPDATE `#@__archives` SET typeid='$typeid',sortrank='$sortrank',flag='$flag',ismake='$ismake',arcrank='$arcrank',click='$click',title='$title',color='$color',writer='$writer',source='$source',litpic='$litpic',pubdate='$pubdate',notpost='$notpost',description='$description',keywords='$keywords',shorttitle='$shorttitle',filename='$filename' WHERE id='$id'; ";
  105. if (!$dsql->ExecuteNoneQuery($inQuery)) {
  106. ShowMsg("数据保存到数据库文档主表出错,请检查数据库字段", "-1");
  107. exit();
  108. }
  109. //专题节点列表
  110. $arcids = array();
  111. $notelist = '';
  112. for ($i = 1; $i <= $cfg_specnote; $i++) {
  113. if (!empty(${'notename'.$i})) {
  114. $notename = str_replace("'", "", trim(${'notename'.$i}));
  115. $arcid = trim(${'arcid'.$i});
  116. $col = trim(${'col'.$i});
  117. $imgwidth = trim(${'imgwidth'.$i});
  118. $imgheight = trim(${'imgheight'.$i});
  119. $titlelen = trim(${'titlelen'.$i});
  120. $infolen = trim(${'infolen'.$i});
  121. $listtmp = trim(${'listtmp'.$i});
  122. if (isset(${'noteid'.$i})) {
  123. $noteid = trim(${'noteid'.$i});
  124. } else {
  125. $noteid = $i;
  126. }
  127. if (isset(${'isauto'.$i})) {
  128. $isauto = trim(${'isauto'.$i});
  129. } else {
  130. $isauto = 0;
  131. }
  132. if (isset(${'keywords'.$i})) {
  133. $keywords = str_replace("'", "", trim(${'keywords'.$i}));
  134. } else {
  135. $keywords = "";
  136. }
  137. if (!empty(${'typeid'.$i})) {
  138. $ttypeid = trim(${'typeid'.$i});
  139. } else {
  140. $ttypeid = 0;
  141. }
  142. if (!empty(${'rownum'.$i})) {
  143. $rownum = trim(${'rownum'.$i});
  144. } else {
  145. $rownum = 0;
  146. }
  147. $arcid = preg_replace("#[^0-9,]#", "", $arcid);
  148. $ids = explode(",", $arcid);
  149. $okids = "";
  150. if (is_array($ids)) {
  151. foreach ($ids as $mid) {
  152. $mid = trim($mid);
  153. if ($mid == "") continue;
  154. if (!isset($arcids[$mid])) {
  155. if ($okids == "") {
  156. $okids .= $mid;
  157. } else {
  158. $okids .= ",".$mid;
  159. }
  160. $arcids[$mid] = 1;
  161. }
  162. }
  163. }
  164. $notelist .= "{dede:specnote imgheight=\\'$imgheight\\' imgwidth=\\'$imgwidth\\' infolen=\\'$infolen\\' titlelen=\\'$titlelen\\' col=\\'$col\\' idlist=\\'$okids\\' name=\\'$notename\\' noteid=\\'$noteid\\' isauto=\'$isauto\' rownum=\\'$rownum\\' keywords=\\'$keywords\\' typeid=\\'$ttypeid\\'} $listtmp {/dede:specnote}\r\n";
  165. }
  166. }
  167. //更新附加表
  168. $inQuery = "UPDATE `#@__addonspec` SET typeid ='$typeid',note='$notelist'{$inadd_f},templet='$templet' WHERE aid='$id';";
  169. if (!$dsql->ExecuteNoneQuery($inQuery)) {
  170. ShowMsg("数据保存到数据库附加表出错,请检查数据库字段", "-1");
  171. exit();
  172. }
  173. //生成网页
  174. UpIndexKey($id, $arcrank, $typeid, $sortrank, $tags);
  175. $artUrl = MakeArt($id, TRUE, TRUE, $isremote);
  176. if ($artUrl == '') {
  177. $artUrl = $cfg_phpurl."/view.php?aid=$id";
  178. }
  179. ClearMyAddon($id, $title);
  180. //自动更新关联文档
  181. if (is_array($automake)) {
  182. foreach ($automake as $key => $value) {
  183. if (isset(${$key}) && !empty(${$key})) {
  184. $ids = explode(",", ${$key});
  185. foreach ($ids as $id) {
  186. MakeArt($id, true, true, $isremote);
  187. }
  188. }
  189. }
  190. }
  191. //返回成功信息
  192. $msg = "请选择后续操作:<a href='spec_add.php?cid=$typeid' class='btn btn-success btn-sm'>发布专题</a><a href='archives_do.php?aid=".$id."&dopost=editArchives' class='btn btn-success btn-sm'>修改专题</a><a href='$artUrl' target='_blank' class='btn btn-success btn-sm'>浏览专题</a><a href='content_s_list.php' class='btn btn-success btn-sm'>管理专题</a> ";
  193. $wintitle = "成功修改专题";
  194. $wecome_info = "专题管理 - 修改专题";
  195. $win = new OxWindow();
  196. $win->AddTitle("成功修改专题");
  197. $win->AddMsgItem($msg);
  198. $winform = $win->GetWindow("hand", FALSE);
  199. $win->Display();
  200. }
  201. ?>