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

411 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 GNU GPL v2 (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. return $filename;
  222. } else if ($dtype == 'img' || $dtype == 'imgfile') {
  223. return addslashes($dvalue);
  224. } else if ($dtype == 'addon' && $admintype == 'diy') {
  225. if ($admintype == 'diy') {
  226. return addslashes($dvalue);
  227. }
  228. $dvalue = MemberUploads($fieldname, '', 0, 'addon', '', -1, -1, false);
  229. return $dvalue;
  230. } else {
  231. if ($admintype == 'member' || $admintype == 'diy') {
  232. $dvalue = HtmlReplace($dvalue, 1);
  233. }
  234. return $dvalue;
  235. }
  236. }
  237. /**
  238. * 获得带值的表单修改时用
  239. *
  240. * @access public
  241. * @param object $ctag 标签
  242. * @param mixed $fvalue 变量值
  243. * @param string $admintype 会员类型
  244. * @param string $fieldname 变量名称
  245. * @return string
  246. */
  247. function GetFormItemValue($ctag, $fvalue, $admintype = 'admin', $fieldname = '')
  248. {
  249. global $cfg_basedir;
  250. $fieldname = $ctag->GetName();
  251. $formitem = $formitem = GetSysTemplets("custom_fields_{$admintype}.htm");
  252. $innertext = trim($ctag->GetInnerText());
  253. if ($innertext != '') {
  254. $formitem = $innertext;
  255. }
  256. $ftype = $ctag->GetAtt('type');
  257. $myformItem = '';
  258. if (preg_match("/select|radio|checkbox/i", $ftype)) {
  259. $items = explode(',', $ctag->GetAtt('default'));
  260. }
  261. if ($ftype == 'select') {
  262. $myformItem = "<select name='$fieldname' class='form-control admin-input-sm'>";
  263. if (is_array($items)) {
  264. foreach ($items as $v) {
  265. $v = trim($v);
  266. if ($v == '') {
  267. continue;
  268. }
  269. $myformItem .= ($fvalue == $v ? "<option value='$v' selected>$v</option>" : "<option value='$v'>$v</option>");
  270. }
  271. }
  272. $myformItem .= "</select>";
  273. $innertext = $myformItem;
  274. } else if ($ctag->GetAtt("type") == 'stepselect') {
  275. global $hasSetEnumJs, $cfg_cmspath;
  276. $cmspath = ((empty($cfg_cmspath) || preg_match('/[/$]/', $cfg_cmspath)) ? $cfg_cmspath.'/' : $cfg_cmspath);
  277. $myformItem = '';
  278. $myformItem .= "<input type='hidden' id='hidden_{$fieldname}' name='{$fieldname}' value='{$fvalue}'>";
  279. $myformItem .= "<span id='span_{$fieldname}'></span>";
  280. $myformItem .= "<span id='span_{$fieldname}_son'></span>";
  281. $myformItem .= "<span id='span_{$fieldname}_sec'></span>";
  282. if ($hasSetEnumJs != 'hasset') {
  283. $myformItem .= '<script src="'.$cmspath.'static/web/js/enums.js"></script>'."";
  284. $GLOBALS['hasSetEnumJs'] = 'hasset';
  285. }
  286. $myformItem .= "<script>
  287. var em_{$fieldname}s = [];
  288. fetch('{$cmspath}static/enums/{$fieldname}.json').then((resp)=>resp.json()).then((d)=>{
  289. Object.entries(d).forEach(v=>{
  290. em_{$fieldname}s[parseFloat(v[0])]= v[1];
  291. });
  292. MakeTopSelect('$fieldname', $fvalue);
  293. })
  294. </script>";
  295. $formitem = str_replace('~name~', $ctag->GetAtt('itemname'), $formitem);
  296. $formitem = str_replace('~form~', $myformItem, $formitem);
  297. return $formitem;
  298. } else if ($ftype == 'radio') {
  299. if (is_array($items)) {
  300. foreach ($items as $v) {
  301. $v = trim($v);
  302. if ($v == '') continue;
  303. $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>");
  304. }
  305. }
  306. $innertext = $myformItem;
  307. }
  308. //checkbox
  309. else if ($ftype == 'checkbox') {
  310. $myformItem = '';
  311. $fvalues = explode(',', $fvalue);
  312. if (is_array($items)) {
  313. foreach ($items as $v) {
  314. $v = trim($v);
  315. if ($v == '') {
  316. continue;
  317. }
  318. if (in_array($v, $fvalues)) {
  319. $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>";
  320. } else {
  321. $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>";
  322. }
  323. }
  324. }
  325. $innertext = $myformItem;
  326. }
  327. //文本数据的特殊处理
  328. else if ($ftype == "textdata") {
  329. if (is_file($cfg_basedir.$fvalue)) {
  330. $fp = fopen($cfg_basedir.$fvalue, 'r');
  331. $okfvalue = '';
  332. while (!feof($fp)) {
  333. $okfvalue .= fgets($fp, 1024);
  334. }
  335. fclose($fp);
  336. } else {
  337. $okfvalue = '';
  338. }
  339. if ($admintype == 'admin') {
  340. $myformItem = GetEditor($fieldname, $okfvalue, 360, 'Basic', 'string')." <input type='hidden' name='{$fieldname}_file' value='{$fvalue}'> ";
  341. } else {
  342. $myformItem = GetEditor($fieldname, $okfvalue, 360, 'Member', 'string')." <input type='hidden' name='{$fieldname}_file' value='{$fvalue}'> ";
  343. }
  344. $innertext = $myformItem;
  345. } else if ($ftype == "htmltext") {
  346. if ($admintype == 'admin') {
  347. $myformItem = GetEditor($fieldname, $fvalue, 360, 'Basic', 'string')." ";
  348. } else {
  349. $myformItem = GetEditor($fieldname, $fvalue, 360, 'Member', 'string')." ";
  350. }
  351. $innertext = $myformItem;
  352. } else if ($ftype == "multitext") {
  353. $innertext = "<textarea name='$fieldname' id='$fieldname' class='form-control admin-textarea-sm'>$fvalue</textarea>";
  354. } else if ($ftype == "datetime") {
  355. $nowtime = GetDateTimeMk($fvalue);
  356. $innertext = "<input type='text' name='$fieldname' value='$nowtime' id='$fieldname' class='form-control admin-input-lg'>";
  357. } else if ($ftype == "img") {
  358. $tmpValue = $fvalue;
  359. $ndtp = new DedeTagParse();
  360. $ndtp->LoadSource($fvalue);
  361. if (!is_array($ndtp->CTags)) {
  362. $ndtp->Clear();
  363. $fvalue = "";
  364. } else {
  365. $ntag = $ndtp->GetTag("img");
  366. if (!empty($ntag)) {
  367. $fvalue = trim($ntag->GetInnerText());
  368. }
  369. }
  370. $fvalue = empty($fvalue)? $tmpValue : $fvalue;
  371. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  372. $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')\">";
  373. } else if ($ftype == "imgfile") {
  374. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  375. $innertext = "<input type='text' name='$fieldname' value='$fvalue' id='$fieldname' class='form-control admin-input-lg'>";
  376. } else if ($ftype == "media") {
  377. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  378. $selectStr = "<input type='button' name='".$fieldname."_bt' class='btn btn-success btn-sm' value='选择' onclick=\"SelectMedia('$fname.$fieldname')\">";
  379. $innertext = "<input type='text' name='$fieldname' value='$fvalue' id='$fieldname' class='form-control admin-input-lg'> $selectStr";
  380. } else if ($ftype == "addon") {
  381. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  382. $selectStr = "<input type='button' name='".$fieldname."_bt' class='btn btn-success btn-sm' value='选择' onclick=\"SelectSoft('$fname.$fieldname')\">";
  383. $innertext = "<input type='text' name='$fieldname' id='$fieldname' value='$fvalue' class='form-control admin-input-lg'> $selectStr";
  384. } else if ($ftype == "int" || $ftype == "float") {
  385. $innertext = "<input type='text' name='$fieldname' id='$fieldname' class='form-control admin-input-xs' value='$fvalue'>";
  386. } else if ($ftype == "relation") {
  387. $fname = defined('DEDEADMIN')? 'form1' : 'addcontent';
  388. $channel = ($ctag->GetAtt('channel') == "") ? "1" : $ctag->GetAtt('channel');
  389. $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>";
  390. if ($ctag->GetAtt('automake') == 1) {
  391. $innertext .= "<input type='hidden' name='automake[$fieldname]' value='1'>";
  392. }
  393. $innertext .= <<<EOT
  394. <script>
  395. if (typeof SelectArcList === "undefined") {
  396. function SelectArcList(fname,cid) {
  397. var posLeft = 10;
  398. var posTop = 10;
  399. 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);
  400. }
  401. }
  402. </script>
  403. EOT;
  404. } else {
  405. $innertext = "<input type='text' name='$fieldname' id='$fieldname' class='form-control admin-input-lg' value='$fvalue'>";
  406. }
  407. $formitem = str_replace('~name~', $ctag->GetAtt('itemname'), $formitem);
  408. $formitem = str_replace('~form~', $innertext, $formitem);
  409. return $formitem;
  410. }
  411. ?>