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

412 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='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 datepicker'>";
  106. } else if ($fieldType == 'img') {
  107. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  108. $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=\"SelectImage('$fname.$fieldname','big')\">";
  109. } else if ($fieldType == 'media') {
  110. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  111. $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')\">";
  112. } else if ($fieldType == 'addon') {
  113. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  114. $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')\">";
  115. } else if ($fieldType == 'int' || $fieldType == 'float') {
  116. $dfvalue = ($ctag->GetAtt('default') != '' ? $ctag->GetAtt('default') : '0');
  117. $innertext = "<input type='text' name='$fieldname' id='$fieldname' class='form-control admin-input-xs' value='$dfvalue'>";
  118. } else if ($fieldType == 'relation') {
  119. $dfvalue = ($ctag->GetAtt('default') != '' ? $ctag->GetAtt('default') : '');
  120. $channel = ($ctag->GetAtt('channel') == "") ? "1" : $ctag->GetAtt('channel');
  121. $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>";
  122. if ($ctag->GetAtt('automake') == 1) {
  123. $innertext .= "<input type='hidden' name='automake[$fieldname]' value='1'>";
  124. }
  125. $innertext .= <<<EOT
  126. <script>
  127. if (typeof SelectArcList === "undefined") {
  128. function SelectArcList(fname,cid) {
  129. var posLeft = 10;
  130. var posTop = 10;
  131. 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);
  132. }
  133. }
  134. </script>
  135. EOT;
  136. } else {
  137. $dfvalue = ($ctag->GetAtt('default') != '' ? $ctag->GetAtt('default') : '');
  138. $innertext = "<input type='text' name='$fieldname' id='$fieldname' class='form-control admin-input-lg' value='$dfvalue'>
  139. ";
  140. }
  141. $formitem = str_replace("~name~", $ctag->GetAtt('itemname'), $formitem);
  142. $formitem = str_replace("~form~", $innertext, $formitem);
  143. return $formitem;
  144. }
  145. /**
  146. * 处理不同类型的数据
  147. *
  148. * @access public
  149. * @param string $dvalue 默认值
  150. * @param string $dtype 默认类型
  151. * @param int $aid 文档id
  152. * @param string $job 操作类型
  153. * @param string $addvar 值
  154. * @param string $admintype 管理类型
  155. * @param string $fieldname 变量类型
  156. * @return string
  157. */
  158. function GetFieldValue($dvalue, $dtype, $aid = 0, $job = 'add', $addvar = '', $admintype = 'admin', $fieldname = '')
  159. {
  160. global $cfg_basedir, $cfg_cmspath, $adminid, $cfg_ml, $cfg_cookie_encode;
  161. if (!empty($adminid)) {
  162. $adminid = $adminid;
  163. } else {
  164. $adminid = isset($cfg_ml) ? $cfg_ml->M_ID : 1;
  165. }
  166. if ($dtype == 'int') {
  167. if ($dvalue == '') {
  168. return 0;
  169. }
  170. return GetAlabNum($dvalue);
  171. } else if ($dtype == 'relation') {
  172. $dvalue = trim(preg_replace("#[^0-9,]#", "", $dvalue));
  173. return $dvalue;
  174. } else if ($dtype == 'stepselect') {
  175. $dvalue = trim(preg_replace("#[^0-9\.]#", "", $dvalue));
  176. return $dvalue;
  177. } else if ($dtype == 'float') {
  178. if ($dvalue == '') {
  179. return 0;
  180. }
  181. return GetAlabNum($dvalue);
  182. } else if ($dtype == 'datetime') {
  183. if ($dvalue == '') {
  184. return 0;
  185. }
  186. return GetMkTime($dvalue);
  187. } else if ($dtype == 'checkbox') {
  188. $okvalue = '';
  189. if (is_array($dvalue)) {
  190. $okvalue = join(',', $dvalue);
  191. }
  192. return $okvalue;
  193. } else if ($dtype == "htmltext") {
  194. if ($admintype == 'member' || $admintype == 'diy') {
  195. $dvalue = HtmlReplace($dvalue, -1);
  196. }
  197. return $dvalue;
  198. } else if ($dtype == "multitext") {
  199. if ($admintype == 'member' || $admintype == 'diy') {
  200. $dvalue = HtmlReplace($dvalue, 0);
  201. }
  202. return $dvalue;
  203. } else if ($dtype == "textdata") {
  204. $ipath = $cfg_cmspath."/data/textdata";
  205. $tpath = ceil($aid / 5000);
  206. if (!is_dir($cfg_basedir.$ipath)) {
  207. MkdirAll($cfg_basedir.$ipath, $GLOBALS['cfg_dir_purview']);
  208. }
  209. if (!is_dir($cfg_basedir.$ipath.'/'.$tpath)) {
  210. MkdirAll($cfg_basedir.$ipath.'/'.$tpath, $GLOBALS['cfg_dir_purview']);
  211. }
  212. $ipath = $ipath.'/'.$tpath;
  213. $filename = "{$ipath}/{$aid}-".cn_substr(md5($cfg_cookie_encode), 0, 16).".txt";
  214. //会员投稿文档安全处理
  215. if ($admintype == 'member' || $admintype == 'diy') {
  216. $dvalue = HtmlReplace($dvalue, -1);
  217. }
  218. $fp = fopen($cfg_basedir.$filename, "w");
  219. fwrite($fp, stripslashes($dvalue));
  220. fclose($fp);
  221. CloseFtp();
  222. return $filename;
  223. } else if ($dtype == 'img' || $dtype == 'imgfile') {
  224. return addslashes($dvalue);
  225. } else if ($dtype == 'addon' && $admintype == 'diy') {
  226. if ($admintype == 'diy') {
  227. return addslashes($dvalue);
  228. }
  229. $dvalue = MemberUploads($fieldname, '', 0, 'addon', '', -1, -1, false);
  230. return $dvalue;
  231. } else {
  232. if ($admintype == 'member' || $admintype == 'diy') {
  233. $dvalue = HtmlReplace($dvalue, 1);
  234. }
  235. return $dvalue;
  236. }
  237. }
  238. /**
  239. * 获得带值的表单修改时用
  240. *
  241. * @access public
  242. * @param object $ctag 标签
  243. * @param mixed $fvalue 变量值
  244. * @param string $admintype 会员类型
  245. * @param string $fieldname 变量名称
  246. * @return string
  247. */
  248. function GetFormItemValue($ctag, $fvalue, $admintype = 'admin', $fieldname = '')
  249. {
  250. global $cfg_basedir;
  251. $fieldname = $ctag->GetName();
  252. $formitem = $formitem = GetSysTemplets("custom_fields_{$admintype}.htm");
  253. $innertext = trim($ctag->GetInnerText());
  254. if ($innertext != '') {
  255. $formitem = $innertext;
  256. }
  257. $ftype = $ctag->GetAtt('type');
  258. $myformItem = '';
  259. if (preg_match("/select|radio|checkbox/i", $ftype)) {
  260. $items = explode(',', $ctag->GetAtt('default'));
  261. }
  262. if ($ftype == 'select') {
  263. $myformItem = "<select name='$fieldname' class='form-control admin-input-sm'>";
  264. if (is_array($items)) {
  265. foreach ($items as $v) {
  266. $v = trim($v);
  267. if ($v == '') {
  268. continue;
  269. }
  270. $myformItem .= ($fvalue == $v ? "<option value='$v' selected>$v</option>" : "<option value='$v'>$v</option>");
  271. }
  272. }
  273. $myformItem .= "</select>";
  274. $innertext = $myformItem;
  275. } else if ($ctag->GetAtt("type") == 'stepselect') {
  276. global $hasSetEnumJs, $cfg_cmspath;
  277. $cmspath = ((empty($cfg_cmspath) || preg_match('/[/$]/', $cfg_cmspath)) ? $cfg_cmspath.'/' : $cfg_cmspath);
  278. $myformItem = '';
  279. $myformItem .= "<input type='hidden' id='hidden_{$fieldname}' name='{$fieldname}' value='{$fvalue}'>";
  280. $myformItem .= "<span id='span_{$fieldname}'></span>";
  281. $myformItem .= "<span id='span_{$fieldname}_son'></span>";
  282. $myformItem .= "<span id='span_{$fieldname}_sec'></span>";
  283. if ($hasSetEnumJs != 'hasset') {
  284. $myformItem .= '<script src="'.$cmspath.'static/web/js/enums.js"></script>'."";
  285. $GLOBALS['hasSetEnumJs'] = 'hasset';
  286. }
  287. $myformItem .= "<script>
  288. var em_{$fieldname}s = [];
  289. fetch('{$cmspath}static/enums/{$fieldname}.json').then((resp)=>resp.json()).then((d)=>{
  290. Object.entries(d).forEach(v=>{
  291. em_{$fieldname}s[parseFloat(v[0])]= v[1];
  292. });
  293. MakeTopSelect('$fieldname', $fvalue);
  294. })
  295. </script>";
  296. $formitem = str_replace('~name~', $ctag->GetAtt('itemname'), $formitem);
  297. $formitem = str_replace('~form~', $myformItem, $formitem);
  298. return $formitem;
  299. } else if ($ftype == 'radio') {
  300. if (is_array($items)) {
  301. foreach ($items as $v) {
  302. $v = trim($v);
  303. if ($v == '') continue;
  304. $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>");
  305. }
  306. }
  307. $innertext = $myformItem;
  308. }
  309. //checkbox
  310. else if ($ftype == 'checkbox') {
  311. $myformItem = '';
  312. $fvalues = explode(',', $fvalue);
  313. if (is_array($items)) {
  314. foreach ($items as $v) {
  315. $v = trim($v);
  316. if ($v == '') {
  317. continue;
  318. }
  319. if (in_array($v, $fvalues)) {
  320. $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>";
  321. } else {
  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'> $v</label></div>";
  323. }
  324. }
  325. }
  326. $innertext = $myformItem;
  327. }
  328. //文本数据的特殊处理
  329. else if ($ftype == "textdata") {
  330. if (is_file($cfg_basedir.$fvalue)) {
  331. $fp = fopen($cfg_basedir.$fvalue, 'r');
  332. $okfvalue = '';
  333. while (!feof($fp)) {
  334. $okfvalue .= fgets($fp, 1024);
  335. }
  336. fclose($fp);
  337. } else {
  338. $okfvalue = '';
  339. }
  340. if ($admintype == 'admin') {
  341. $myformItem = GetEditor($fieldname, $okfvalue, 360, 'Basic', 'string')." <input type='hidden' name='{$fieldname}_file' value='{$fvalue}'> ";
  342. } else {
  343. $myformItem = GetEditor($fieldname, $okfvalue, 360, 'Member', 'string')." <input type='hidden' name='{$fieldname}_file' value='{$fvalue}'> ";
  344. }
  345. $innertext = $myformItem;
  346. } else if ($ftype == "htmltext") {
  347. if ($admintype == 'admin') {
  348. $myformItem = GetEditor($fieldname, $fvalue, 360, 'Basic', 'string')." ";
  349. } else {
  350. $myformItem = GetEditor($fieldname, $fvalue, 360, 'Member', 'string')." ";
  351. }
  352. $innertext = $myformItem;
  353. } else if ($ftype == "multitext") {
  354. $innertext = "<textarea name='$fieldname' id='$fieldname' class='form-control admin-textarea-sm'>$fvalue</textarea>";
  355. } else if ($ftype == "datetime") {
  356. $nowtime = GetDateTimeMk($fvalue);
  357. $innertext = "<input type='text' name='$fieldname' value='$nowtime' id='$fieldname' class='form-control admin-input-lg'>";
  358. } else if ($ftype == "img") {
  359. $tmpValue = $fvalue;
  360. $ndtp = new DedeTagParse();
  361. $ndtp->LoadSource($fvalue);
  362. if (!is_array($ndtp->CTags)) {
  363. $ndtp->Clear();
  364. $fvalue = "";
  365. } else {
  366. $ntag = $ndtp->GetTag("img");
  367. if (!empty($ntag)) {
  368. $fvalue = trim($ntag->GetInnerText());
  369. }
  370. }
  371. $fvalue = empty($fvalue)? $tmpValue : $fvalue;
  372. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  373. $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')\">";
  374. } else if ($ftype == "imgfile") {
  375. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  376. $innertext = "<input type='text' name='$fieldname' value='$fvalue' id='$fieldname' class='form-control admin-input-lg'>";
  377. } else if ($ftype == "media") {
  378. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  379. $selectStr = "<input type='button' name='".$fieldname."_bt' class='btn btn-success btn-sm' value='选择' onClick=\"SelectMedia('$fname.$fieldname')\">";
  380. $innertext = "<input type='text' name='$fieldname' value='$fvalue' id='$fieldname' class='form-control admin-input-lg'> $selectStr";
  381. } else if ($ftype == "addon") {
  382. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  383. $selectStr = "<input type='button' name='".$fieldname."_bt' class='btn btn-success btn-sm' value='选择' onClick=\"SelectSoft('$fname.$fieldname')\">";
  384. $innertext = "<input type='text' name='$fieldname' id='$fieldname' value='$fvalue' class='form-control admin-input-lg'> $selectStr";
  385. } else if ($ftype == "int" || $ftype == "float") {
  386. $innertext = "<input type='text' name='$fieldname' id='$fieldname' class='form-control admin-input-xs' value='$fvalue'>";
  387. } else if ($ftype == "relation") {
  388. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  389. $channel = ($ctag->GetAtt('channel') == "") ? "1" : $ctag->GetAtt('channel');
  390. $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>";
  391. if ($ctag->GetAtt('automake') == 1) {
  392. $innertext .= "<input type='hidden' name='automake[$fieldname]' value='1'>";
  393. }
  394. $innertext .= <<<EOT
  395. <script>
  396. if (typeof SelectArcList === "undefined") {
  397. function SelectArcList(fname,cid) {
  398. var posLeft = 10;
  399. var posTop = 10;
  400. 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);
  401. }
  402. }
  403. </script>
  404. EOT;
  405. } else {
  406. $innertext = "<input type='text' name='$fieldname' id='$fieldname' class='form-control admin-input-lg' value='$fvalue'>";
  407. }
  408. $formitem = str_replace('~name~', $ctag->GetAtt('itemname'), $formitem);
  409. $formitem = str_replace('~form~', $innertext, $formitem);
  410. return $formitem;
  411. }
  412. ?>