update.html 9.2 KB

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