update.html 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287
  1. <!DOCTYPE html>
  2. <html lang="zh-cn">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>更新页面</title>
  6. <link rel="stylesheet" href="/app/admin/component/pear/css/pear.css" />
  7. <link rel="stylesheet" href="/app/admin/component/jsoneditor/css/jsoneditor.css" />
  8. <link rel="stylesheet" href="/app/admin/admin/css/reset.css" />
  9. </head>
  10. <body>
  11. <form class="layui-form">
  12. <div class="mainBox">
  13. <div class="main-container mr-5">
  14. <div class="layui-form-item">
  15. <label class="layui-form-label">标题</label>
  16. <div class="layui-input-block">
  17. <input type="text" name="name" value="" class="layui-input">
  18. </div>
  19. </div>
  20. <div class="layui-form-item">
  21. <label class="layui-form-label">图片</label>
  22. <div class="layui-input-block">
  23. <img class="img-3" src=""/>
  24. <input type="text" style="display:none" name="img" value="" />
  25. <button type="button" class="pear-btn pear-btn-primary pear-btn-sm" id="img" permission="app.admin.upload.image">
  26. <i class="layui-icon layui-icon-upload"></i>上传图片
  27. </button>
  28. <button type="button" class="pear-btn pear-btn-primary pear-btn-sm" id="attachment-choose-img" permission="app.admin.upload.attachment">
  29. <i class="layui-icon layui-icon-align-left"></i>选择图片
  30. </button>
  31. </div>
  32. </div>
  33. <div class="layui-form-item">
  34. <label class="layui-form-label">抵扣金额</label>
  35. <div class="layui-input-block">
  36. <input type="number" name="deduction_price" value="" class="layui-input">
  37. </div>
  38. </div>
  39. <div class="layui-form-item">
  40. <label class="layui-form-label">支付usd</label>
  41. <div class="layui-input-block">
  42. <input type="number" name="payment_usd" value="" class="layui-input">
  43. </div>
  44. </div>
  45. <div class="layui-form-item">
  46. <label class="layui-form-label">支付金额</label>
  47. <div class="layui-input-block">
  48. <input type="number" name="pay_price" value="" class="layui-input">
  49. </div>
  50. </div>
  51. <div class="layui-form-item">
  52. <label class="layui-form-label">原价-支付金额</label>
  53. <div class="layui-input-block">
  54. <input type="number" name="original_price" value="" class="layui-input">
  55. </div>
  56. </div>
  57. <div class="layui-form-item">
  58. <label class="layui-form-label">每日利息</label>
  59. <div class="layui-input-block">
  60. <input type="number" name="bonus" value="" class="layui-input">
  61. </div>
  62. </div>
  63. <div class="layui-form-item">
  64. <label class="layui-form-label">原--每日利息</label>
  65. <div class="layui-input-block">
  66. <input type="number" name="original_bonus" value="" class="layui-input">
  67. </div>
  68. </div>
  69. <div class="layui-form-item">
  70. <label class="layui-form-label">解冻usd(每日交易世界币)</label>
  71. <div class="layui-input-block">
  72. <input type="number" name="balance" value="" class="layui-input">
  73. </div>
  74. </div>
  75. <div class="layui-form-item">
  76. <label class="layui-form-label">原--解冻usd(每日交易世界币)</label>
  77. <div class="layui-input-block">
  78. <input type="number" name="original_balancs" value="" class="layui-input">
  79. </div>
  80. </div>
  81. <div class="layui-form-item">
  82. <label class="layui-form-label">每日交易USD</label>
  83. <div class="layui-input-block">
  84. <input type="number" name="usd_quota" value="" class="layui-input">
  85. </div>
  86. </div>
  87. <div class="layui-form-item">
  88. <label class="layui-form-label">原--每日交易USD</label>
  89. <div class="layui-input-block">
  90. <input type="number" name="original_usd_quota" value="" class="layui-input">
  91. </div>
  92. </div>
  93. <div class="layui-form-item">
  94. <label class="layui-form-label">提升排名数</label>
  95. <div class="layui-input-block">
  96. <input type="number" name="ranking" value="" class="layui-input">
  97. </div>
  98. </div>
  99. <div class="layui-form-item">
  100. <label class="layui-form-label">剩余数量</label>
  101. <div class="layui-input-block">
  102. <input type="number" name="num" value="" class="layui-input">
  103. </div>
  104. </div>
  105. <div class="layui-form-item">
  106. <label class="layui-form-label">排序</label>
  107. <div class="layui-input-block">
  108. <input type="number" name="sort" value="" class="layui-input">
  109. </div>
  110. </div>
  111. <div class="layui-form-item">
  112. <label class="layui-form-label">状态</label>
  113. <div class="layui-input-block">
  114. <input type="checkbox" id="state" lay-filter="state" lay-skin="switch" />
  115. <input type="text" style="display:none" name="state" value="0" />
  116. </div>
  117. </div>
  118. <div class="layui-form-item">
  119. <label class="layui-form-label">描述</label>
  120. <div class="layui-input-block">
  121. <input type="text" name="describe" value="" class="layui-input">
  122. </div>
  123. </div>
  124. </div>
  125. </div>
  126. <div class="bottom">
  127. <div class="button-container">
  128. <button type="submit" class="pear-btn pear-btn-primary pear-btn-md" lay-submit="" lay-filter="save">
  129. 提交
  130. </button>
  131. <button type="reset" class="pear-btn pear-btn-md">
  132. 重置
  133. </button>
  134. </div>
  135. </div>
  136. </form>
  137. <script src="/app/admin/component/layui/layui.js?v=2.8.12"></script>
  138. <script src="/app/admin/component/pear/pear.js"></script>
  139. <script src="/app/admin/component/jsoneditor/jsoneditor.js"></script>
  140. <script src="/app/admin/admin/js/permission.js"></script>
  141. <script>
  142. // 相关接口
  143. const PRIMARY_KEY = "id";
  144. const SELECT_API = "/app/admin/good/select" + location.search;
  145. const UPDATE_API = "/app/admin/good/update";
  146. // 获取数据库记录
  147. layui.use(["form", "util", "popup"], function () {
  148. let $ = layui.$;
  149. $.ajax({
  150. url: SELECT_API,
  151. dataType: "json",
  152. success: function (res) {
  153. // 给表单初始化数据
  154. layui.each(res.data[0], function (key, value) {
  155. let obj = $('*[name="'+key+'"]');
  156. if (key === "password") {
  157. obj.attr("placeholder", "不更新密码请留空");
  158. return;
  159. }
  160. if (typeof obj[0] === "undefined" || !obj[0].nodeName) return;
  161. if (obj[0].nodeName.toLowerCase() === "textarea") {
  162. obj.val(value);
  163. } else {
  164. obj.attr("value", value);
  165. obj[0].value = value;
  166. }
  167. });
  168. // 字段 图片 img
  169. layui.use(["upload", "layer"], function() {
  170. let input = layui.$("#img").prev();
  171. input.prev().attr("src", input.val());
  172. layui.$("#attachment-choose-img").on("click", function() {
  173. parent.layer.open({
  174. type: 2,
  175. title: "选择附件",
  176. content: "/app/admin/upload/attachment?ext=jpg,jpeg,png,gif,bmp",
  177. area: ["95%", "90%"],
  178. success: function (layero, index) {
  179. parent.layui.$("#layui-layer" + index).data("callback", function (data) {
  180. input.val(data.url).prev().attr("src", data.url);
  181. });
  182. }
  183. });
  184. });
  185. layui.upload.render({
  186. elem: "#img",
  187. acceptMime: "image/gif,image/jpeg,image/jpg,image/png",
  188. url: "/app/admin/upload/image",
  189. field: "__file__",
  190. done: function (res) {
  191. if (res.code > 0) return layui.layer.msg(res.msg);
  192. this.item.prev().val(res.data.url).prev().attr("src", res.data.url);
  193. }
  194. });
  195. });
  196. // 字段 状态 0禁用1正常 state
  197. layui.use(["form"], function() {
  198. layui.$("#state").attr("checked", layui.$('input[name="state"]').val() != 0);
  199. layui.form.render();
  200. layui.form.on("switch(state)", function(data) {
  201. layui.$('input[name="state"]').val(this.checked ? 1 : 0);
  202. });
  203. })
  204. // 字段 产品类型 type
  205. layui.use(["jquery", "xmSelect"], function() {
  206. let value = layui.$("#type").attr("value");
  207. let initValue = value ? value.split(",") : [];
  208. layui.xmSelect.render({
  209. el: "#type",
  210. name: "type",
  211. filterable: true,
  212. initValue: initValue,
  213. data:[{'value':1,'name':'政策'},{'value':2,'name':'汽车'},{'value':3,'name':'手机'},{'value':4,'name':'生活'}],
  214. model: {"icon":"hidden","label":{"type":"text"}},
  215. clickClose: true,
  216. radio: true,
  217. })
  218. });
  219. // ajax返回失败
  220. if (res.code) {
  221. layui.popup.failure(res.msg);
  222. }
  223. }
  224. });
  225. });
  226. //提交事件
  227. layui.use(["form", "popup"], function () {
  228. // 字段验证允许为空
  229. layui.form.verify({
  230. phone: [/(^$)|^1\d{10}$/, "请输入正确的手机号"],
  231. email: [/(^$)|^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/, "邮箱格式不正确"],
  232. url: [/(^$)|(^#)|(^http(s*):\/\/[^\s]+\.[^\s]+)/, "链接格式不正确"],
  233. number: [/(^$)|^\d+$/,'只能填写数字'],
  234. date: [/(^$)|^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/, "日期格式不正确"],
  235. identity: [/(^$)|(^\d{15}$)|(^\d{17}(x|X|\d)$)/, "请输入正确的身份证号"]
  236. });
  237. layui.form.on("submit(save)", function (data) {
  238. data.field[PRIMARY_KEY] = layui.url().search[PRIMARY_KEY];
  239. layui.$.ajax({
  240. url: UPDATE_API,
  241. type: "POST",
  242. dateType: "json",
  243. data: data.field,
  244. success: function (res) {
  245. if (res.code) {
  246. return layui.popup.failure(res.msg);
  247. }
  248. return layui.popup.success("操作成功", function () {
  249. parent.refreshTable();
  250. parent.layer.close(parent.layer.getFrameIndex(window.name));
  251. });
  252. }
  253. });
  254. return false;
  255. });
  256. });
  257. </script>
  258. </body>
  259. </html>