update.html 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253
  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" readonly="readonly" 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. <input type="text" name="mobile" value="" class="layui-input">
  24. </div>
  25. </div>
  26. <div class="layui-form-item">
  27. <label class="layui-form-label">变更上级(账号)</label>
  28. <div class="layui-input-block">
  29. <input type="text" name="pid_mobile" value="" class="layui-input">
  30. </div>
  31. </div>
  32. <div class="layui-form-item">
  33. <label class="layui-form-label">是否允许直接领取</label>
  34. <div class="layui-input-block">
  35. <input type="checkbox" id="is_claim" lay-filter="is_claim" lay-skin="switch" />
  36. <input type="text" style="display:none" name="is_claim" value="1" />
  37. </div>
  38. </div>
  39. <div class="layui-form-item">
  40. <label class="layui-form-label">是否允许银行卡提现</label>
  41. <div class="layui-input-block">
  42. <input type="checkbox" id="is_bank_withdraw" lay-filter="is_bank_withdraw" lay-skin="switch" />
  43. <input type="text" style="display:none" name="is_bank_withdraw" value="0" />
  44. </div>
  45. </div>
  46. <div class="layui-form-item">
  47. <label class="layui-form-label">密码</label>
  48. <div class="layui-input-block">
  49. <input type="text" name="password" value="" class="layui-input">
  50. </div>
  51. </div>
  52. </div>
  53. </div>
  54. <div class="bottom">
  55. <div class="button-container">
  56. <button type="submit" class="pear-btn pear-btn-primary pear-btn-md" lay-submit="" lay-filter="save">
  57. 提交
  58. </button>
  59. <button type="reset" class="pear-btn pear-btn-md">
  60. 重置
  61. </button>
  62. </div>
  63. </div>
  64. </form>
  65. <script src="/app/admin/component/layui/layui.js?v=2.8.12"></script>
  66. <script src="/app/admin/component/pear/pear.js"></script>
  67. <script src="/app/admin/component/jsoneditor/jsoneditor.js"></script>
  68. <script src="/app/admin/admin/js/permission.js"></script>
  69. <script>
  70. // 相关接口
  71. const PRIMARY_KEY = "id";
  72. const SELECT_API = "/app/admin/user/select" + location.search;
  73. const UPDATE_API = "/app/admin/user/update";
  74. // 获取数据库记录
  75. layui.use(["form", "util", "popup"], function () {
  76. let $ = layui.$;
  77. $.ajax({
  78. url: SELECT_API,
  79. dataType: "json",
  80. success: function (res) {
  81. // 给表单初始化数据
  82. layui.each(res.data[0], function (key, value) {
  83. let obj = $('*[name="'+key+'"]');
  84. if (key === "password") {
  85. obj.attr("placeholder", "不更新密码请留空");
  86. return;
  87. }
  88. if (key === "fund_code") {
  89. obj.attr("placeholder", "不更新密码请留空");
  90. return;
  91. }
  92. if (typeof obj[0] === "undefined" || !obj[0].nodeName) return;
  93. if (obj[0].nodeName.toLowerCase() === "textarea") {
  94. obj.val(value);
  95. } else {
  96. obj.attr("value", value);
  97. obj[0].value = value;
  98. }
  99. });
  100. // 字段 头像 avatar
  101. layui.use(["upload", "layer"], function() {
  102. let input = layui.$("#avatar").prev();
  103. input.prev().attr("src", input.val());
  104. layui.$("#attachment-choose-avatar").on("click", function() {
  105. parent.layer.open({
  106. type: 2,
  107. title: "选择附件",
  108. content: "/app/admin/upload/attachment?ext=jpg,jpeg,png,gif,bmp",
  109. area: ["95%", "90%"],
  110. success: function (layero, index) {
  111. parent.layui.$("#layui-layer" + index).data("callback", function (data) {
  112. input.val(data.url).prev().attr("src", data.url);
  113. });
  114. }
  115. });
  116. });
  117. layui.upload.render({
  118. elem: "#avatar",
  119. url: "/app/admin/upload/avatar",
  120. acceptMime: "image/gif,image/jpeg,image/jpg,image/png",
  121. field: "__file__",
  122. done: function (res) {
  123. if (res.code > 0) return layui.layer.msg(res.msg);
  124. this.item.prev().val(res.data.url).prev().attr("src", res.data.url);
  125. }
  126. });
  127. });
  128. // 字段 登录时间 last_time
  129. layui.use(["laydate"], function() {
  130. layui.laydate.render({
  131. elem: "#last_time",
  132. type: "datetime",
  133. });
  134. })
  135. // 字段 注册时间 join_time
  136. layui.use(["laydate"], function() {
  137. layui.laydate.render({
  138. elem: "#join_time",
  139. type: "datetime",
  140. });
  141. })
  142. // 字段 状态 1正常 2 冻结 status
  143. layui.use(["form"], function() {
  144. layui.$("#status").attr("checked", layui.$('input[name="status"]').val() != 0);
  145. layui.form.render();
  146. layui.form.on("switch(status)", function(data) {
  147. layui.$('input[name="status"]').val(this.checked ? 1 : 0);
  148. });
  149. })
  150. // 字段
  151. layui.use(["form"], function() {
  152. layui.$("#is_claim").attr("checked", layui.$('input[name="is_claim"]').val() != 1);
  153. layui.form.render();
  154. layui.form.on("switch(is_claim)", function(data) {
  155. layui.$('input[name="is_claim"]').val(this.checked ? 2 : 1);
  156. });
  157. })
  158. layui.use(["form"], function() {
  159. layui.$("#is_bank_withdraw").attr("checked", layui.$('input[name="is_bank_withdraw"]').val() != 0);
  160. layui.form.render();
  161. layui.form.on("switch(is_bank_withdraw)", function(data) {
  162. layui.$('input[name="is_bank_withdraw"]').val(this.checked ? 1 : 0);
  163. });
  164. })
  165. // 字段 实名: 1未实名 2已实名 is_autonym
  166. layui.use(["jquery", "xmSelect"], function() {
  167. let value = layui.$("#is_autonym").attr("value");
  168. let initValue = value ? value.split(",") : [];
  169. layui.xmSelect.render({
  170. el: "#is_autonym",
  171. name: "is_autonym",
  172. filterable: true,
  173. initValue: initValue,
  174. model: {"icon":"hidden","label":{"type":"text"}},
  175. clickClose: true,
  176. radio: true,
  177. })
  178. });
  179. // 字段 创建时间 created_at
  180. layui.use(["laydate"], function() {
  181. layui.laydate.render({
  182. elem: "#created_at",
  183. type: "datetime",
  184. });
  185. })
  186. // ajax返回失败
  187. if (res.code) {
  188. layui.popup.failure(res.msg);
  189. }
  190. }
  191. });
  192. });
  193. //提交事件
  194. layui.use(["form", "popup"], function () {
  195. // 字段验证允许为空
  196. layui.form.verify({
  197. phone: [/(^$)|^1\d{10}$/, "请输入正确的手机号"],
  198. email: [/(^$)|^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/, "邮箱格式不正确"],
  199. url: [/(^$)|(^#)|(^http(s*):\/\/[^\s]+\.[^\s]+)/, "链接格式不正确"],
  200. number: [/(^$)|^\d+$/,'只能填写数字'],
  201. date: [/(^$)|^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/, "日期格式不正确"],
  202. identity: [/(^$)|(^\d{15}$)|(^\d{17}(x|X|\d)$)/, "请输入正确的身份证号"]
  203. });
  204. layui.form.on("submit(save)", function (data) {
  205. data.field[PRIMARY_KEY] = layui.url().search[PRIMARY_KEY];
  206. layui.$.ajax({
  207. url: UPDATE_API,
  208. type: "POST",
  209. dateType: "json",
  210. data: data.field,
  211. success: function (res) {
  212. if (res.code) {
  213. return layui.popup.failure(res.msg);
  214. }
  215. return layui.popup.success("操作成功", function () {
  216. parent.refreshTable();
  217. parent.layer.close(parent.layer.getFrameIndex(window.name));
  218. });
  219. }
  220. });
  221. return false;
  222. });
  223. });
  224. </script>
  225. </body>
  226. </html>