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

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