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

218 lines
10KB

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