国内流行的内容管理系统(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.

414 lines
20KB

  1. <?php
  2. if (!defined('DEDEINC')) exit ('dedebiz');
  3. /**
  4. * 系统核心函数
  5. * @version $id:customfields.func.php 2 20:50 2010年7月7日 tianya $
  6. * @package DedeBIZ.Libraries
  7. * @copyright Copyright (c) 2022 DedeBIZ.COM
  8. * @license https://www.dedebiz.com/license
  9. * @link https://www.dedebiz.com
  10. */
  11. /**
  12. * 获得一个附加表单发布时用
  13. *
  14. * @access public
  15. * @param object $ctag 标签
  16. * @param string $admintype 管理员类型
  17. * @return string
  18. */
  19. function GetFormItem($ctag, $admintype = 'admin')
  20. {
  21. $fieldname = $ctag->GetName();
  22. $fieldType = $ctag->GetAtt('type');
  23. $formitem = $formitem = GetSysTemplets("custom_fields_{$admintype}.htm");
  24. $innertext = trim($ctag->GetInnerText());
  25. if ($innertext != '') {
  26. $formitem = $innertext;
  27. }
  28. if ($fieldType == 'select') {
  29. $myformItem = '';
  30. $items = explode(',', $ctag->GetAtt("default"));
  31. $myformItem = "<select name='$fieldname' class='form-control admin-input-sm'>";
  32. foreach ($items as $v) {
  33. $v = trim($v);
  34. if ($v != '') {
  35. $myformItem .= "<option value='$v'>$v</option>";
  36. }
  37. }
  38. $myformItem .= "</select>";
  39. $innertext = $myformItem;
  40. } else if ($fieldType == 'stepselect') {
  41. global $hasSetEnumJs, $cfg_cmspath;
  42. $cmspath = ((empty($cfg_cmspath) || !preg_match('/[/$]/', $cfg_cmspath)) ? $cfg_cmspath.'/' : $cfg_cmspath);
  43. $myformItem = '';
  44. $myformItem .= "<input type='hidden' id='hidden_{$fieldname}' name='{$fieldname}' value='0'>";
  45. $myformItem .= "<span id='span_{$fieldname}'></span>";
  46. $myformItem .= "<span id='span_{$fieldname}_son'></span>";
  47. $myformItem .= "<span id='span_{$fieldname}_sec'></span>";
  48. if ($hasSetEnumJs != 'hasset') {
  49. $myformItem .= '<script src="'.$cmspath.'static/web/js/enums.js"></script>'."";
  50. $GLOBALS['hasSetEnumJs'] = 'hasset';
  51. }
  52. $myformItem .= "<script>
  53. var em_{$fieldname}s = [];
  54. fetch('{$cmspath}static/enums/{$fieldname}.json').then((resp)=>resp.json()).then((d)=>{
  55. Object.entries(d).forEach(v=>{
  56. em_{$fieldname}s[parseFloat(v[0])]= v[1];
  57. });
  58. MakeTopSelect('$fieldname', 0);
  59. })
  60. </script>";
  61. $formitem = str_replace('~name~', $ctag->GetAtt('itemname'), $formitem);
  62. $formitem = str_replace('~form~', $myformItem, $formitem);
  63. return $formitem;
  64. } else if ($fieldType == 'radio') {
  65. $myformItem = '';
  66. $items = explode(',', $ctag->GetAtt("default"));
  67. $i = 0;
  68. foreach ($items as $v) {
  69. $v = trim($v);
  70. if ($v != '') {
  71. $myformItem .= ($i == 0 ? "<div class='form-check form-check-inline'><label class='form-check-label'><input type='radio' name='$fieldname' class='form-check-input' value='$v' checked> $v</label></div>" : "<div class='form-check form-check-inline'><label class='form-check-label'><input type='radio' name='$fieldname' class='form-check-input' value='$v'> $v</label></div>");
  72. $i++;
  73. }
  74. }
  75. $innertext = $myformItem;
  76. } else if ($fieldType == 'checkbox') {
  77. $myformItem = '';
  78. $items = explode(',', $ctag->GetAtt("default"));
  79. foreach ($items as $v) {
  80. $v = trim($v);
  81. if ($v != '') {
  82. if ($admintype == 'membermodel') {
  83. $myformItem .= "<div class='form-check form-check-inline'><label class='form-check-label'><input type='checkbox' name='{$fieldname}[]' class='form-check-input' value='$v'> $v</label></div>";
  84. } else {
  85. $myformItem .= "<div class='form-check form-check-inline'><label class='form-check-label'><input type='checkbox' name='{$fieldname}[]' class='form-check-input' value='$v'> $v</label></div>";
  86. }
  87. }
  88. }
  89. $innertext = $myformItem;
  90. } else if ($fieldType == 'htmltext' || $fieldType == 'textdata') {
  91. $dfvalue = ($ctag->GetAtt('default') != '' ? $ctag->GetAtt('default') : '');
  92. $dfvalue = str_replace('{{', '<', $dfvalue);
  93. $dfvalue = str_replace('}}', '>', $dfvalue);
  94. if ($admintype == 'admin') {
  95. $innertext = GetEditor($fieldname, $dfvalue, 360, 'Basic', 'string');
  96. } else if ($admintype == 'diy') {
  97. $innertext = GetEditor($fieldname, $dfvalue, 360, 'Diy', 'string');
  98. } else {
  99. $innertext = GetEditor($fieldname, $dfvalue, 360, 'Member', 'string');
  100. }
  101. } else if ($fieldType == "multitext") {
  102. $innertext = "<textarea name='$fieldname' id='$fieldname' class='form-control admin-textarea-sm'></textarea>";
  103. } else if ($fieldType == "datetime") {
  104. $nowtime = GetDateTimeMk(time());
  105. $innertext = "<input type='text' name='$fieldname' value='$nowtime' id='$fieldname' class='form-control admin-input-lg'>";
  106. } else if ($fieldType == 'img' || $fieldType == 'imgfile') {
  107. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  108. $sstr = $fieldType == 'imgfile'? '' : "<input type='button' name='".$fieldname."_bt' class='btn btn-success btn-sm' value='选择' onClick=\"SelectImage('$fname.$fieldname','big')\">";
  109. $pstr = $fieldType == 'imgfile'? '请填写图片地址' : '请选择图片上传或填写图片地址';
  110. $innertext = "<input type='text' name='$fieldname' id='$fieldname' class='form-control admin-input-lg' placeholder='$pstr'> $sstr";
  111. } else if ($fieldType == 'media') {
  112. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  113. $innertext = "<input type='text' name='$fieldname' id='$fieldname' class='form-control admin-input-lg' placeholder='请选择多媒体上传或填写多媒体地址'> <input type='button' name='".$fieldname."_bt' class='btn btn-success btn-sm' value='选择' onClick=\"SelectMedia('$fname.$fieldname')\">";
  114. } else if ($fieldType == 'addon') {
  115. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  116. $innertext = "<input type='text' name='$fieldname' id='$fieldname' class='form-control admin-input-lg' placeholder='请选择附件上传或填写附件地址'> <input type='button' name='".$fieldname."_bt' class='btn btn-success btn-sm' value='选择' onClick=\"SelectSoft('$fname.$fieldname')\">";
  117. } else if ($fieldType == 'int' || $fieldType == 'float') {
  118. $dfvalue = ($ctag->GetAtt('default') != '' ? $ctag->GetAtt('default') : '0');
  119. $innertext = "<input type='text' name='$fieldname' id='$fieldname' class='form-control admin-input-xs' value='$dfvalue'>";
  120. } else if ($fieldType == 'relation') {
  121. $dfvalue = ($ctag->GetAtt('default') != '' ? $ctag->GetAtt('default') : '');
  122. $channel = ($ctag->GetAtt('channel') == "") ? "1" : $ctag->GetAtt('channel');
  123. $innertext = "<textarea name='$fieldname' id='$fieldname' class='form-control admin-textarea-sm'>$dfvalue</textarea><br><button type='button' class='btn btn-success btn-sm' onclick='SelectArcList(\"form1.$fieldname\", $channel);'>选择关联文档</button>";
  124. if ($ctag->GetAtt('automake') == 1) {
  125. $innertext .= "<input type='hidden' name='automake[$fieldname]' value='1'>";
  126. }
  127. $innertext .= <<<EOT
  128. <script>
  129. if (typeof SelectArcList === "undefined") {
  130. function SelectArcList(fname,cid) {
  131. var posLeft = 10;
  132. var posTop = 10;
  133. window.open("content_select_list.php?f=" + fname+"&channelid="+cid, "selArcList", "scrollbars=yes,resizable=yes,statebar=no,width=800,height=500,left=" + posLeft + ", top=" + posTop);
  134. }
  135. }
  136. </script>
  137. EOT;
  138. } else {
  139. $dfvalue = ($ctag->GetAtt('default') != '' ? $ctag->GetAtt('default') : '');
  140. $innertext = "<input type='text' name='$fieldname' id='$fieldname' class='form-control admin-input-lg' value='$dfvalue'>
  141. ";
  142. }
  143. $formitem = str_replace("~name~", $ctag->GetAtt('itemname'), $formitem);
  144. $formitem = str_replace("~form~", $innertext, $formitem);
  145. return $formitem;
  146. }
  147. /**
  148. * 处理不同类型的数据
  149. *
  150. * @access public
  151. * @param string $dvalue 默认值
  152. * @param string $dtype 默认类型
  153. * @param int $aid 文档id
  154. * @param string $job 操作类型
  155. * @param string $addvar 值
  156. * @param string $admintype 管理类型
  157. * @param string $fieldname 变量类型
  158. * @return string
  159. */
  160. function GetFieldValue($dvalue, $dtype, $aid = 0, $job = 'add', $addvar = '', $admintype = 'admin', $fieldname = '')
  161. {
  162. global $cfg_basedir, $cfg_cmspath, $adminid, $cfg_ml, $cfg_cookie_encode;
  163. if (!empty($adminid)) {
  164. $adminid = $adminid;
  165. } else {
  166. $adminid = isset($cfg_ml) ? $cfg_ml->M_ID : 1;
  167. }
  168. if ($dtype == 'int') {
  169. if ($dvalue == '') {
  170. return 0;
  171. }
  172. return GetAlabNum($dvalue);
  173. } else if ($dtype == 'relation') {
  174. $dvalue = trim(preg_replace("#[^0-9,]#", "", $dvalue));
  175. return $dvalue;
  176. } else if ($dtype == 'stepselect') {
  177. $dvalue = trim(preg_replace("#[^0-9\.]#", "", $dvalue));
  178. return $dvalue;
  179. } else if ($dtype == 'float') {
  180. if ($dvalue == '') {
  181. return 0;
  182. }
  183. return GetAlabNum($dvalue);
  184. } else if ($dtype == 'datetime') {
  185. if ($dvalue == '') {
  186. return 0;
  187. }
  188. return GetMkTime($dvalue);
  189. } else if ($dtype == 'checkbox') {
  190. $okvalue = '';
  191. if (is_array($dvalue)) {
  192. $okvalue = join(',', $dvalue);
  193. }
  194. return $okvalue;
  195. } else if ($dtype == "htmltext") {
  196. if ($admintype == 'member' || $admintype == 'diy') {
  197. $dvalue = HtmlReplace($dvalue, -1);
  198. }
  199. return $dvalue;
  200. } else if ($dtype == "multitext") {
  201. if ($admintype == 'member' || $admintype == 'diy') {
  202. $dvalue = HtmlReplace($dvalue, 0);
  203. }
  204. return $dvalue;
  205. } else if ($dtype == "textdata") {
  206. $ipath = $cfg_cmspath."/data/textdata";
  207. $tpath = ceil($aid / 5000);
  208. if (!is_dir($cfg_basedir.$ipath)) {
  209. MkdirAll($cfg_basedir.$ipath, $GLOBALS['cfg_dir_purview']);
  210. }
  211. if (!is_dir($cfg_basedir.$ipath.'/'.$tpath)) {
  212. MkdirAll($cfg_basedir.$ipath.'/'.$tpath, $GLOBALS['cfg_dir_purview']);
  213. }
  214. $ipath = $ipath.'/'.$tpath;
  215. $filename = "{$ipath}/{$aid}-".cn_substr(md5($cfg_cookie_encode), 0, 16).".txt";
  216. //会员投稿文档安全处理
  217. if ($admintype == 'member' || $admintype == 'diy') {
  218. $dvalue = HtmlReplace($dvalue, -1);
  219. }
  220. $fp = fopen($cfg_basedir.$filename, "w");
  221. fwrite($fp, stripslashes($dvalue));
  222. fclose($fp);
  223. CloseFtp();
  224. return $filename;
  225. } else if ($dtype == 'img' || $dtype == 'imgfile') {
  226. return addslashes($dvalue);
  227. } else if ($dtype == 'addon' && $admintype == 'diy') {
  228. if ($admintype == 'diy') {
  229. return addslashes($dvalue);
  230. }
  231. $dvalue = MemberUploads($fieldname, '', 0, 'addon', '', -1, -1, false);
  232. return $dvalue;
  233. } else {
  234. if ($admintype == 'member' || $admintype == 'diy') {
  235. $dvalue = HtmlReplace($dvalue, 1);
  236. }
  237. return $dvalue;
  238. }
  239. }
  240. /**
  241. * 获得带值的表单修改时用
  242. *
  243. * @access public
  244. * @param object $ctag 标签
  245. * @param mixed $fvalue 变量值
  246. * @param string $admintype 会员类型
  247. * @param string $fieldname 变量名称
  248. * @return string
  249. */
  250. function GetFormItemValue($ctag, $fvalue, $admintype = 'admin', $fieldname = '')
  251. {
  252. global $cfg_basedir;
  253. $fieldname = $ctag->GetName();
  254. $formitem = $formitem = GetSysTemplets("custom_fields_{$admintype}.htm");
  255. $innertext = trim($ctag->GetInnerText());
  256. if ($innertext != '') {
  257. $formitem = $innertext;
  258. }
  259. $ftype = $ctag->GetAtt('type');
  260. $myformItem = '';
  261. if (preg_match("/select|radio|checkbox/i", $ftype)) {
  262. $items = explode(',', $ctag->GetAtt('default'));
  263. }
  264. if ($ftype == 'select') {
  265. $myformItem = "<select name='$fieldname' class='form-control admin-input-sm'>";
  266. if (is_array($items)) {
  267. foreach ($items as $v) {
  268. $v = trim($v);
  269. if ($v == '') {
  270. continue;
  271. }
  272. $myformItem .= ($fvalue == $v ? "<option value='$v' selected>$v</option>" : "<option value='$v'>$v</option>");
  273. }
  274. }
  275. $myformItem .= "</select>";
  276. $innertext = $myformItem;
  277. } else if ($ctag->GetAtt("type") == 'stepselect') {
  278. global $hasSetEnumJs, $cfg_cmspath;
  279. $cmspath = ((empty($cfg_cmspath) || preg_match('/[/$]/', $cfg_cmspath)) ? $cfg_cmspath.'/' : $cfg_cmspath);
  280. $myformItem = '';
  281. $myformItem .= "<input type='hidden' id='hidden_{$fieldname}' name='{$fieldname}' value='{$fvalue}'>";
  282. $myformItem .= "<span id='span_{$fieldname}'></span>";
  283. $myformItem .= "<span id='span_{$fieldname}_son'></span>";
  284. $myformItem .= "<span id='span_{$fieldname}_sec'></span>";
  285. if ($hasSetEnumJs != 'hasset') {
  286. $myformItem .= '<script src="'.$cmspath.'static/web/js/enums.js"></script>'."";
  287. $GLOBALS['hasSetEnumJs'] = 'hasset';
  288. }
  289. $myformItem .= "<script>
  290. var em_{$fieldname}s = [];
  291. fetch('{$cmspath}static/enums/{$fieldname}.json').then((resp)=>resp.json()).then((d)=>{
  292. Object.entries(d).forEach(v=>{
  293. em_{$fieldname}s[parseFloat(v[0])]= v[1];
  294. });
  295. MakeTopSelect('$fieldname', $fvalue);
  296. })
  297. </script>";
  298. $formitem = str_replace('~name~', $ctag->GetAtt('itemname'), $formitem);
  299. $formitem = str_replace('~form~', $myformItem, $formitem);
  300. return $formitem;
  301. } else if ($ftype == 'radio') {
  302. if (is_array($items)) {
  303. foreach ($items as $v) {
  304. $v = trim($v);
  305. if ($v == '') continue;
  306. $myformItem .= ($fvalue == $v ? "<div class='form-check form-check-inline'><label class='form-check-label'><input type='radio' name='$fieldname' class='form-check-input' value='$v' checked='checked'> $v</label></div>" : "<div class='form-check form-check-inline'><label class='form-check-label'><input type='radio' name='$fieldname' class='form-check-input' value='$v'> $v</label></div>");
  307. }
  308. }
  309. $innertext = $myformItem;
  310. }
  311. //checkbox
  312. else if ($ftype == 'checkbox') {
  313. $myformItem = '';
  314. $fvalues = explode(',', $fvalue);
  315. if (is_array($items)) {
  316. foreach ($items as $v) {
  317. $v = trim($v);
  318. if ($v == '') {
  319. continue;
  320. }
  321. if (in_array($v, $fvalues)) {
  322. $myformItem .= "<div class='form-check form-check-inline'><label class='form-check-label'><input type='checkbox' name='{$fieldname}[]' class='form-check-input' value='$v' checked='checked'> $v</label></div>";
  323. } else {
  324. $myformItem .= "<div class='form-check form-check-inline'><label class='form-check-label'><input type='checkbox' name='{$fieldname}[]' class='form-check-input' value='$v'> $v</label></div>";
  325. }
  326. }
  327. }
  328. $innertext = $myformItem;
  329. }
  330. //文本数据的特殊处理
  331. else if ($ftype == "textdata") {
  332. if (is_file($cfg_basedir.$fvalue)) {
  333. $fp = fopen($cfg_basedir.$fvalue, 'r');
  334. $okfvalue = '';
  335. while (!feof($fp)) {
  336. $okfvalue .= fgets($fp, 1024);
  337. }
  338. fclose($fp);
  339. } else {
  340. $okfvalue = '';
  341. }
  342. if ($admintype == 'admin') {
  343. $myformItem = GetEditor($fieldname, $okfvalue, 360, 'Basic', 'string')." <input type='hidden' name='{$fieldname}_file' value='{$fvalue}'> ";
  344. } else {
  345. $myformItem = GetEditor($fieldname, $okfvalue, 360, 'Member', 'string')." <input type='hidden' name='{$fieldname}_file' value='{$fvalue}'> ";
  346. }
  347. $innertext = $myformItem;
  348. } else if ($ftype == "htmltext") {
  349. if ($admintype == 'admin') {
  350. $myformItem = GetEditor($fieldname, $fvalue, 360, 'Basic', 'string')." ";
  351. } else {
  352. $myformItem = GetEditor($fieldname, $fvalue, 360, 'Member', 'string')." ";
  353. }
  354. $innertext = $myformItem;
  355. } else if ($ftype == "multitext") {
  356. $innertext = "<textarea name='$fieldname' id='$fieldname' class='form-control admin-textarea-sm'>$fvalue</textarea>";
  357. } else if ($ftype == "datetime") {
  358. $nowtime = GetDateTimeMk($fvalue);
  359. $innertext = "<input type='text' name='$fieldname' value='$nowtime' id='$fieldname' class='form-control admin-input-lg'>";
  360. } else if ($ftype == "img") {
  361. $tmpValue = $fvalue;
  362. $ndtp = new DedeTagParse();
  363. $ndtp->LoadSource($fvalue);
  364. if (!is_array($ndtp->CTags)) {
  365. $ndtp->Clear();
  366. $fvalue = "";
  367. } else {
  368. $ntag = $ndtp->GetTag("img");
  369. if (!empty($ntag)) {
  370. $fvalue = trim($ntag->GetInnerText());
  371. }
  372. }
  373. $fvalue = empty($fvalue)? $tmpValue : $fvalue;
  374. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  375. $innertext = "<input type='text' name='$fieldname' value='$fvalue' id='$fieldname' class='form-control admin-input-lg'> <input type='button' name='".$fieldname."_bt' class='btn btn-success btn-sm' value='选择' onClick=\"SelectImage('$fname.$fieldname','big')\">";
  376. } else if ($ftype == "imgfile") {
  377. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  378. $innertext = "<input type='text' name='$fieldname' value='$fvalue' id='$fieldname' class='form-control admin-input-lg'>";
  379. } else if ($ftype == "media") {
  380. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  381. $selectStr = "<input type='button' name='".$fieldname."_bt' class='btn btn-success btn-sm' value='选择' onClick=\"SelectMedia('$fname.$fieldname')\">";
  382. $innertext = "<input type='text' name='$fieldname' value='$fvalue' id='$fieldname' class='form-control admin-input-lg'> $selectStr";
  383. } else if ($ftype == "addon") {
  384. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  385. $selectStr = "<input type='button' name='".$fieldname."_bt' class='btn btn-success btn-sm' value='选择' onClick=\"SelectSoft('$fname.$fieldname')\">";
  386. $innertext = "<input type='text' name='$fieldname' id='$fieldname' value='$fvalue' class='form-control admin-input-lg'> $selectStr";
  387. } else if ($ftype == "int" || $ftype == "float") {
  388. $innertext = "<input type='text' name='$fieldname' id='$fieldname' class='form-control admin-input-xs' value='$fvalue'>";
  389. } else if ($ftype == "relation") {
  390. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  391. $channel = ($ctag->GetAtt('channel') == "") ? "1" : $ctag->GetAtt('channel');
  392. $innertext = "<textarea name='$fieldname' id='$fieldname' class='form-control admin-textarea-sm'>$fvalue</textarea><br><button type='button' class='btn btn-success btn-sm' onclick='SelectArcList(\"$fname.$fieldname\", $channel);'>选择关联文档</button>";
  393. if ($ctag->GetAtt('automake') == 1) {
  394. $innertext .= "<input type='hidden' name='automake[$fieldname]' value='1'>";
  395. }
  396. $innertext .= <<<EOT
  397. <script>
  398. if (typeof SelectArcList === "undefined") {
  399. function SelectArcList(fname,cid) {
  400. var posLeft = 10;
  401. var posTop = 10;
  402. window.open("content_select_list.php?f=" + fname+"&channelid="+cid, "selArcList", "scrollbars=yes,resizable=yes,statebar=no,width=800,height=500,left=" + posLeft + ", top=" + posTop);
  403. }
  404. }
  405. </script>
  406. EOT;
  407. } else {
  408. $innertext = "<input type='text' name='$fieldname' id='$fieldname' class='form-control admin-input-lg' value='$fvalue'>";
  409. }
  410. $formitem = str_replace('~name~', $ctag->GetAtt('itemname'), $formitem);
  411. $formitem = str_replace('~form~', $innertext, $formitem);
  412. return $formitem;
  413. }
  414. ?>