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

275 lines
12KB

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=<?php echo $cfg_soft_lang; ?>">
  5. <title>增加字段</title>
  6. <link rel="stylesheet" href="../static/web/css/bootstrap.min.css">
  7. <link rel="stylesheet" href="../static/web/font/css/font-awesome.min.css">
  8. <link rel="stylesheet" href="../static/web/css/admin.css">
  9. <script language="javascript" src="../static/web/js/jquery.min.js"></script>
  10. <script src="../static/web/js/bootstrap.bundle.min.js"></script>
  11. <script language="javascript" src="js/main.js"></script>
  12. <script language="javascript">
  13. var notAllow = " <?php echo $f; ?> ";
  14. function GetFields()
  15. {
  16. var theform = document.form1;
  17. var fieldname = theform.fieldname.value;
  18. var itemname = theform.itemname.value;
  19. var dtype = 'text';
  20. var enums = document.getElementsByName('dtype');
  21. for(i=0;i<enums.length;i++)
  22. {
  23. if(enums[i].checked) dtype = enums[i].value;
  24. }
  25. var isnull = theform.isnull.value;
  26. var vdefault = theform.vdefault.value;
  27. var maxlength = theform.maxlength.value;
  28. var vinnertext = theform.vinnertext.value;
  29. var spage = (theform.spage[0].checked ? theform.spage[0].value : theform.spage[1].value);
  30. var sisnull = (isnull==0 ? "false" : "true");
  31. var autofield = (theform.autofield[0].checked ? theform.autofield[0].value : theform.autofield[1].value);
  32. var islist = (theform.islist.checked ? 1 : 0);
  33. var notsend = (theform.notsend.checked ? 1 : 0);
  34. var automake = theform.relation_automake.checked ? 1 : 0;
  35. if(itemname=="")
  36. {
  37. ShowMsg("表单提示名称不能为空");
  38. theform.itemname.focus();
  39. return false;
  40. }
  41. if(fieldname=="")
  42. {
  43. ShowMsg("字段名称不能为空");
  44. theform.fieldname.focus();
  45. return false;
  46. }
  47. if(notAllow.indexOf(" "+fieldname+" ") >-1 )
  48. {
  49. ShowMsg("字段名称不合法,如下字段名已经存在,建议在名称后加上数字以区分:\n"+notAllow);
  50. return false;
  51. }
  52. if((dtype=="radio" || dtype=="select" || dtype=="checkbox") && vdefault=="")
  53. {
  54. ShowMsg("您选择的select或radio、checkbox类型,必须默认值设置选择的项目(用逗号[,]分开)");
  55. return false;
  56. }
  57. if(spage=="no") spage = "";
  58. relstr = "";
  59. if (dtype==="relation") {
  60. relstr = " automake=\""+automake+"\" channel=\""+$("#channeltype").val()+"\"";
  61. }
  62. revalue = "<field:"+fieldname+" itemname=\""+itemname+"\" autofield=\""+autofield+"\" notsend=\""+notsend+"\" type=\""+dtype+"\"";
  63. revalue += relstr + " isnull=\""+sisnull+"\" islist=\""+islist+"\" default=\""+vdefault+"\" ";
  64. revalue += " maxlength=\""+maxlength+"\" page=\""+spage+"\">\r\n"+vinnertext+"</field:"+fieldname+">\r\n";
  65. document.form1.fieldstring.value = revalue;
  66. return true;
  67. }
  68. $(document).ready(function () {
  69. $("#dataType input").click(function(ele){
  70. if ($(ele.currentTarget).val() === "relation") {
  71. $("#_relation").show();
  72. } else {
  73. $("#_relation").hide();
  74. }
  75. })
  76. });
  77. </script>
  78. <style>
  79. td{ padding:6px; padding-left:6px; line-height:26px }
  80. .STYLE1 {color: #FF3300}
  81. .STYLE2 {color: #424b51}
  82. .nw { float:left; width:150px; }
  83. .cls { clear:both; }
  84. </style>
  85. </head>
  86. <body>
  87. <form name="form1" action="mychannel_field_add.php" method="post" onSubmit="return GetFields();">
  88. <input type='hidden' name='action' value='save' />
  89. <input type='hidden' name='id' value='<?php echo $id?>' />
  90. <input type='hidden' name='fieldstring' value='' />
  91. <table width="98%" border="0" cellpadding="1" cellspacing="1" align="center" class="table maintable mt-3">
  92. <tr>
  93. <td colspan="2" background="../static/web/img/tbg.gif">
  94. <table width="98%" border="0" cellspacing="0" cellpadding="0" class="table table-borderless">
  95. <tr>
  96. <td width="30%" style="padding-left:10px"><a href="mychannel_main.php">频道管理</a> &gt; 增加新字段</td>
  97. <td align="right">
  98. <button type="button" name="ss1" onClick="location='mychannel_edit.php?id=<?php echo $id?>&dopost=edit';" class="btn btn-success btn-sm">当前模型信息</button>
  99. <button type="button" name="ss12" onClick="location='mychannel_main.php';" class="btn btn-success btn-sm">内容模型管理</button>
  100. </td>
  101. </tr>
  102. </table>
  103. </td>
  104. </tr>
  105. <tr>
  106. <td colspan="2" bgcolor="#ffffff">
  107. <div class="alert alert-danger mb-0">所有填写的内容不允许包含双引号[&quot;],否则配置将无法写入</div>
  108. </td>
  109. </tr>
  110. <tr>
  111. <td bgcolor="#ffffff">表单提示文字:<br>
  112. <span class="STYLE2">发布内容时显示的提示文字</span></td>
  113. <td bgcolor="#ffffff">
  114. <input name="itemname" type="text" id="itemname" class="pubinputs"> *
  115. </td>
  116. </tr>
  117. <tr>
  118. <td width="28%" bgcolor="#ffffff">字段名称:<br>
  119. <span class="STYLE2">
  120. 只能用英文字母或数字,数据表的真实字段名,如果数据类型是联动类型,该项应该填写联动类型的<a href='stepselect_main.php' target='_blank'>[组名称]</a>
  121. </span>
  122. </td>
  123. <td width="72%" bgcolor="#ffffff">
  124. <input name="fieldname" type="text" id="fieldname" class="pubinputs"> *
  125. </td>
  126. </tr>
  127. <tr>
  128. <td bgcolor="#ffffff">字段类型:</td>
  129. <td bgcolor="#ffffff">
  130. <label><input name="autofield" type="radio" value="1" class="np" checked="checked">
  131. 系统自动生成表单字段</label>
  132. <label><input type="radio" name="autofield" class="np" value="0">
  133. 已经固化在发布表单中字段</label>
  134. </td>
  135. </tr>
  136. <tr>
  137. <td bgcolor="#ffffff">
  138. 前台参数:
  139. </td>
  140. <td bgcolor="#ffffff">
  141. <label><input name="islist" type="checkbox" class="np" id="islist" value="1">
  142. 使字段可以在列表的底层模板中获得(自定义字段默认仅能在文档模板显示,启用此选项将使列表查询变慢,如无必要请不要选择)</label><br>
  143. <label><input name="notsend" type="checkbox" class="np" id="notsend" value="1">
  144. 前台投稿及采集规则禁用本字段</label>
  145. </td>
  146. </tr>
  147. <tr>
  148. <td bgcolor="#ffffff">
  149. 内容是否需要分页符:<br>
  150. <span class="STYLE2">如果内容需要分页符,不论何种内容,都可以用#P#副标题#e#作为分页符号实现内容分页,但一个模型里仅允许一个这样的字段!</span>
  151. </td>
  152. <td bgcolor="#ffffff">
  153. <input name="isnull" type="hidden" value="1">
  154. <label><input name="spage" type="radio" value="split" class='np' />
  155. 是</label>
  156. &nbsp;
  157. <label><input name="spage" type="radio" value="no" class='np' checked='1' />
  158. 否</label>
  159. </td>
  160. </tr>
  161. <tr>
  162. <td bgcolor="#ffffff">
  163. 数据类型:
  164. </td>
  165. <td bgcolor="#ffffff" id="dataType">
  166. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype1' value="text" checked='1'> 单行文本(varchar) </label></div>
  167. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype2' value="textchar"> 单行文本(char) </label></div>
  168. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype3' value="multitext"> 多行文本 </label></div>
  169. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype4' value="htmltext"> HTML文本 </label></div>
  170. <br class='cls' />
  171. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype5' value="textdata"> 文本保存HTML数据 </label></div>
  172. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype6' value="int"> 整数类型 </label></div>
  173. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype7' value="float"> 小数类型 </label></div>
  174. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype8' value="datetime"> 时间类型 </label></div>
  175. <br class='cls' />
  176. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype9' value="img"> 图片 </label></div>
  177. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype10' value="imgfile"> 图片(仅网址) </label></div>
  178. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype11' value="media"> 多媒体文件 </label></div>
  179. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype12' value="addon"> 附件类型 </label></div>
  180. <br class='cls' />
  181. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype13' value="select"> 使用option下拉框 </label></div>
  182. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype14' value="radio"> 使用radio选项卡 </label></div>
  183. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype15' value="checkbox"> Checkbox多选框 </label></div>
  184. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype16' value="stepselect"> 联动类型 </label></div>
  185. <br class='cls' />
  186. <div class='nw'><label><input type='radio' class='np' name='dtype' id='dtype16' value="relation"> 关联内容 </label></div>
  187. </td>
  188. </tr>
  189. <tr id="_relation" style="display:none">
  190. <td bgcolor="#ffffff">内容模型:<br>
  191. <span class="STYLE2">
  192. 选择关联内容对应的内容模型
  193. </span>
  194. </td>
  195. <td bgcolor="#ffffff">
  196. <select name="channeltype" id="channeltype" style="width:260px">
  197. <?php
  198. $channelid = 1;
  199. foreach($channelArray as $k=>$arr)
  200. {
  201. if($k==$channelid) {
  202. $nid = $arr['nid'];
  203. echo "<option value='{$k}' selected>{$arr['typename']}|{$arr['nid']}</option>\r\n";
  204. }
  205. else
  206. {
  207. echo "<option value='{$k}'>{$arr['typename']}|{$arr['nid']}</option>\r\n";
  208. }
  209. }
  210. ?>
  211. </select>
  212. <label><input name="relation_automake" type="checkbox" class="np" id="relation_automake" value="1">
  213. 发布时候自动更新关联内容HTML</label>
  214. </td>
  215. </tr>
  216. <tr>
  217. <td bgcolor="#ffffff">默认值:<br>
  218. <span class="STYLE2">
  219. 如果定义数据类型为select、radio、checkbox时,此处填写被选择的项目(用“,”分开,如“男,女,人妖”)
  220. </span>
  221. </td>
  222. <td bgcolor="#ffffff">
  223. <textarea name="vdefault" type="text" id="vdefault" style="width:70%;height:60px"></textarea>
  224. </td>
  225. </tr>
  226. <tr>
  227. <td bgcolor="#ffffff">最大长度:<br>
  228. <span class="STYLE2">
  229. 文本数据必须填写,大于255为text类型
  230. </span>
  231. </td>
  232. <td bgcolor="#ffffff">
  233. <input name="maxlength" type="text" id="maxlength" class="pubinputs" value="250" style="width:80px">
  234. </td>
  235. </tr>
  236. <tr>
  237. <td bgcolor="#ffffff">自定义表单HTML:</td>
  238. <td bgcolor="#ffffff">
  239. 自定义表单HTML模板中用~name~表示提示文字,~form~表示表单元素
  240. </td>
  241. </tr>
  242. <tr>
  243. <td align="center" bgcolor="#ffffff"></td>
  244. <td bgcolor="#ffffff">
  245. <textarea name="vinnertext" cols="45" rows="5" id="vinnertext" style="width:70%;height:120px"></textarea>
  246. </td>
  247. </tr>
  248. <tr>
  249. <td height="26" colspan="2" bgcolor="#f8f8f8">
  250. <table width="100%" border="0" cellspacing="0" cellpadding="0" class="table table-borderless">
  251. <tr>
  252. <td align="center" class="py-3">
  253. <button type="submit" name="button1" id="button1" class="btn btn-success">保存</button>
  254. <button type="reset" name="button2" id="button2" class="btn btn-success">重置</button>
  255. </td>
  256. </tr>
  257. </table>
  258. </td>
  259. </tr>
  260. </table>
  261. </form>
  262. </body>
  263. </html>