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

143 lines
6.3KB

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1">
  6. <title>添加自定义表单字段</title>
  7. <link rel="stylesheet" href="../static/web/font/css/font-awesome.min.css">
  8. <link rel="stylesheet" href="../static/web/css/bootstrap.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.min.js"></script>
  12. <script src="js/main.js"></script>
  13. <style>.nw{float:left;width:160px}.cls{clear:both}</style>
  14. </head>
  15. <body>
  16. <form name="form1" action="diy_field_add.php" method="post" onSubmit="return GetFields();">
  17. <input type="hidden" name="action" value="save">
  18. <input type="hidden" name="diyid" value="<?php echo $diyid?>">
  19. <input type="hidden" name="fieldstring" value="">
  20. <table align="center" class="table maintable my-3">
  21. <tr>
  22. <td bgcolor="#f5f5f5" colspan="2">自定义表单管理</a> - 自定义表单添加字段</td>
  23. </tr>
  24. <tr>
  25. <td colspan="2">
  26. <div class="alert alert-danger mb-0">所有填写的文档不允许包含双引号["],否则配置无法写入</div>
  27. </td>
  28. </tr>
  29. <tr>
  30. <td width="260">提示文字:</td>
  31. <td>
  32. <input type="text" name="itemname" id="itemname" class="admin-input-sm">
  33. <span>(发布表单时显示的提示文字)</span>
  34. </td>
  35. </tr>
  36. <tr>
  37. <td>字段名称:</td>
  38. <td>
  39. <input type="text" name="fieldname" id="fieldname" class="admin-input-sm">
  40. <span>(只能用英文字母或数字,数据表的真实字段名,如果数据类型是联动类型,该项应该填写联动类型的组名称)</span>
  41. </td>
  42. </tr>
  43. <tr>
  44. <td>文档是否需要分页符:</td>
  45. <td>
  46. <input type="hidden" name="isnull" value="1">
  47. <label><input type="radio" name="spage" value="split"> 是</label>
  48. <label><input type="radio" name="spage" value="no" checked="1"> 否</label>
  49. <span>(如果文档需要分页符,不论何种文档,都可以用#p#副标题#e#作为分页符号实现文档分页,但一个模型里仅允许一个这样的字段)</span>
  50. </td>
  51. </tr>
  52. <tr>
  53. <td>数据类型:</td>
  54. <td>
  55. <div class="nw"><label><input type="radio" name="dtype" id="dtype1" value="text" checked="1"> 单行文本(varchar)</label></div>
  56. <div class="nw"><label><input type="radio" name="dtype" id="dtype2" value="textchar"> 单行文本(char)</label></div>
  57. <div class="nw"><label><input type="radio" name="dtype" id="dtype3" value="multitext"> 多行文本</label></div>
  58. <div class="nw"><label><input type="radio" name="dtype" id="dtype4" value="htmltext"> 网页文本</label></div>
  59. <br class="cls">
  60. <div class="nw"><label><input type="radio" name="dtype" id="dtype6" value="int"> 整数类型</label></div>
  61. <div class="nw"><label><input type="radio" name="dtype" id="dtype7" value="float"> 小数类型</label></div>
  62. <div class="nw"><label><input type="radio" name="dtype" id="dtype8" value="datetime"> 时间类型</label></div>
  63. <div class="nw"><label><input type="radio" name="dtype" id="dtype13" value="select"> option下拉框</label></div>
  64. <br class="cls">
  65. <div class="nw"><label><input type="radio" name="dtype" id="dtype14" value="radio"> radio选项卡</label></div>
  66. <div class="nw"><label><input type="radio" name="dtype" id="dtype15" value="checkbox"> checkbox多选框</label></div>
  67. </td>
  68. </tr>
  69. <tr>
  70. <td>默认值:</td>
  71. <td>
  72. <p>(如果定义数据类型为select、radio、checkbox时,此处填写被选择的项目,英文逗号分开,如“DedeBIZ,得德”)</p>
  73. <textarea name="vdefault" id="vdefault" class="admin-textarea-xl"></textarea>
  74. </td>
  75. </tr>
  76. <tr>
  77. <td>自定义网页表单:</td>
  78. <td>
  79. <p>(自定义网页表单用~name~表示提示文字,~form~表示表单元素)</p>
  80. <textarea name="vinnertext" id="vinnertext" class="admin-textarea-xl"></textarea>
  81. </td>
  82. </tr>
  83. <tr>
  84. <td>最大长度:</td>
  85. <td>
  86. <input type="text" name="maxlength" id="maxlength" value="255" class="admin-input-xs">
  87. <span>(文本数据必须填写,大于255为text类型)</span>
  88. </td>
  89. </tr>
  90. <tr>
  91. <td bgcolor="#f5f5f5" colspan="2" align="center">
  92. <button type="submit" class="btn btn-success btn-sm">保存</button>
  93. <button type="reset" class="btn btn-outline-success btn-sm">重置</button>
  94. </td>
  95. </tr>
  96. </table>
  97. </form>
  98. <script>
  99. var notAllow = "<?php echo $f;?>";
  100. function GetFields()
  101. {
  102. var theform = document.form1;
  103. var fieldname = theform.fieldname.value;
  104. var itemname = theform.itemname.value;
  105. var dtype = 'text';
  106. var enums = document.getElementsByName('dtype');
  107. for (i=0;i<enums.length;i++)
  108. {
  109. if (enums[i].checked) dtype = enums[i].value;
  110. }
  111. var isnull = theform.isnull.value;
  112. var vdefault = theform.vdefault.value;
  113. var maxlength = theform.maxlength.value;
  114. var vinnertext = theform.vinnertext.value;
  115. var spage = (theform.spage[0].checked ? theform.spage[0].value : theform.spage[1].value);
  116. var sisnull = (isnull==0 ? "false" : "true");
  117. if (itemname=="") {
  118. ShowMsg("表单提示名称不能为空");
  119. theform.itemname.focus();
  120. return false;
  121. }
  122. if (fieldname=="") {
  123. ShowMsg("字段名称不能为空");
  124. theform.fieldname.focus();
  125. return false;
  126. }
  127. if (notAllow.indexOf(" "+fieldname+" ") >-1 ) {
  128. ShowMsg("字段名称不合法,如下字段名已经存在,建议在名称后加上数字以区分:\n"+notAllow);
  129. return false;
  130. }
  131. if ((dtype=="radio" || dtype=="select" || dtype=="checkbox") && vdefault=="") {
  132. ShowMsg("您选择的select或radio、checkbox类型,必须默认值设置选择的项目(用英文逗号)");
  133. return false;
  134. }
  135. if (spage=="no") spage = "";
  136. revalue = "<field:"+fieldname+" itemname=\""+itemname+"\" autofield=\"1\" type=\""+dtype+"\" isnull=\""+sisnull+"\" default=\""+vdefault+"\" ";
  137. revalue += " maxlength=\""+maxlength+"\" page=\""+spage+"\">"+vinnertext+"</field:"+fieldname+">";
  138. document.form1.fieldstring.value = revalue;
  139. return true;
  140. }
  141. </script>
  142. </body>
  143. </html>