index.html 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287
  1. {include file="common/header"/}
  2. <style>
  3. .yourclass {
  4. display: block;
  5. }
  6. .canel {
  7. display: none;
  8. }
  9. </style>
  10. <div class="LM-container">
  11. <div class="LM-main">
  12. <fieldset class="layui-elem-field layui-field-title">
  13. <legend>{:lang('user')}{:lang('list')}</legend>
  14. <blockquote class="layui-elem-quote">
  15. <div class="LM-table">
  16. <div class="layui-inline">
  17. <input type="text" id='keys' name="keys" lay-verify="required"
  18. placeholder="{:lang('pleaseEnter')}" autocomplete="off" class="layui-input">
  19. </div>
  20. <a href="javascript:;" class="layui-btn data-add-btn layui-btn-sm" lay-submit="" lay-filter="add"
  21. id="search">
  22. {:lang('search')}
  23. </a>
  24. <!-- <a href="{:url('add')}" class="layui-btn layui-btn-sm layui-btn-warm">{:lang('add')}{:lang('user')}</a>-->
  25. <!-- <a href="javascript:;" class="layui-btn layui-btn-sm layui-btn-danger" id="delAll">{:lang('delete checked')}</a>-->
  26. </div>
  27. </blockquote>
  28. </fieldset>
  29. <table class="layui-table" id="list" lay-filter="list"></table>
  30. </div>
  31. </div>
  32. <script type="text/html" id="action">
  33. <!-- <a href="{:url('edit')}?id={{d.id}}" class="layui-btn layui-btn-xs" lay-event="edit">{:lang('edit')}</a>-->
  34. <a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="vip_level">设置会员等级</a>
  35. <a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除账号</a>
  36. <a href="{:url('certificateshow')}?user_id={{d.id}}" class="layui-btn layui-btn-xs" lay-event="tzlg">通证记录</a>
  37. <a href="{:url('agent/xiaji')}?user_id={{d.id}}&type=1" class="layui-btn layui-btn-xs" >下级会员列表</a>
  38. <a class="layui-btn layui-btn-xs" lay-event="update_pwd">重置密码</a>
  39. <a href="{:url('usermessage')}?user_id={{d.id}}" class="layui-btn layui-btn-xs" >查看收款信息</a>
  40. <a href="{:url('push')}?user_id={{d.id}}" class="layui-btn layui-btn-xs" >交易记录</a>
  41. </script>
  42. <script type="text/html" id="status">
  43. <input type="checkbox" name="status" value="{{d.id}}" lay-skin="switch" lay-text="正常|禁止" lay-filter="status" {{ d.status== 0 ? 'checked' : '' }}>
  44. </script>
  45. <script type="text/html" id="daili">
  46. <input type="checkbox" name="is_admin" value="{{d.id}}" lay-skin="switch" lay-text="是|否" lay-filter="is_admin" {{ d.is_admin== 1 ? 'checked' : '' }}>
  47. </script>
  48. <script type="text/html" id="avatar">
  49. {{d.image}}<img src="/static/admin/images/image.gif"
  50. onmouseover="layer.tips('<img src={{d.image}}>',this,{tips: [1, '#fff']});"
  51. onmouseout="layer.closeAll();">
  52. </script>
  53. <div id="red" style="background-color: white; border-radius: 10px; text-align: center;display: none">
  54. <div class="layui-form-item">
  55. <label class="layui-form-label">设置vip等级</label>
  56. <div class="layui-input-block">
  57. <select name="vip_levels" lay-verify="required" id="vip_levels">
  58. {volist name="$vip" id="vs"}
  59. <option class="option-{$vs.id}" value="{$vs.id}">{$vs.level}级</option>
  60. {/volist}
  61. </select>
  62. </div>
  63. </div>
  64. <div style="height: 1px; background-color: #d5d5d5; margin-top: 10px;"></div>
  65. <div style="width: 100%; text-align: center;">
  66. <div style="float: left; width: 49.75%; height: 41px; padding-top: 10px;" lay-event="cancel" onclick="cancel()">取消</div>
  67. <div style="float: left; width: 1px; height: 41px; background-color: #d5d5d5;"></div>
  68. <div style="float: right; width: 49.75%; height: 41px; padding-top: 10px;" lay-event="sendRedpacket" onclick="sendRedpacket()">确定</div>
  69. <div style="clear: both;"></div>
  70. </div>
  71. </div>
  72. {include file="common/footer"/}
  73. <script>
  74. let redIndex=0;
  75. let user_id=0;
  76. let vip_level=0;
  77. layui.use(['form', 'table'], function () {
  78. var $ = layui.jquery,
  79. form = layui.form,
  80. table = layui.table;
  81. var tableIn = table.render({
  82. elem: '#list',
  83. url: '{:url("index")}',
  84. method: 'post',
  85. title: '用户数据表',
  86. // toolbar: '#toolbar', //开启头部工具栏,并为其绑定左侧模板
  87. defaultToolbar: ['filter', 'exports', 'print', { //自定义头部工具栏右侧图标。如无需自定义,去除该参数即可
  88. title: '提示'
  89. , layEvent: 'LAYTABLE_TIPS'
  90. , icon: 'layui-icon-tips'
  91. }],
  92. cols: [[
  93. // {checkbox: true, fixed: true},
  94. {field: 'id', title: 'ID', width: 80, sort: true},
  95. {field: 'name', title: '名字', width: 120,},
  96. {field: 'maild', title: '邮箱', width: 120,},
  97. {field: 'phone', title: '手机', width: 120,},
  98. {field: 'sex', title: '性别', width: 120},
  99. {field: 'vip_level', title: '会员等级', width: 120,},
  100. {field: 'image', title: '头像', width: 120, templet: "#avatar"},
  101. {field: 'status', title: '状态', width: 180, templet: '#status'},
  102. {field: 'pid', title: '上级id', width: 180},
  103. {field: 'code', title: '邀请码', width: 180},
  104. {field: 'money', title: '通证余额', width: 180,edit:"text"},
  105. {field: 'ensure_money', title: '保证金', width: 180,edit:"text"},
  106. {field: 'push_money', title: '可售额度', width: 180,edit:"text"},
  107. {field: 'pool_money', title: '矿池矿金', width: 180},
  108. {field: 'is_admin', title: '是否代理商账号', width: 180, templet: '#daili'},
  109. {field: 'add_time', title: '注册时间', width: 180},
  110. {field: 'update_time', title: '更新时间', width: 180},
  111. {title: '操作', width: 700, toolbar: '#action', align: "center"},
  112. ]],
  113. limits: [10, 15, 20, 25, 50, 100],
  114. limit: 15,
  115. page: true
  116. });
  117. //监听单元格编辑
  118. table.on('edit(list)', function(obj){
  119. var value = obj.value //得到修改后的值
  120. ,data = obj.data //得到所在行所有键值
  121. ,field = obj.field; //得到字段
  122. let da={
  123. id:data.id,
  124. field:field,
  125. value:value
  126. }
  127. // layer.msg('[ID: '+ data.id +'] ' + field + ' 字段更改为:'+ value);
  128. // console.log(da)
  129. $.post("{:url('update_user_money')}", da, function (res) {
  130. if (res.code ==200) {
  131. layer.msg(res.msg, {time: 1000, icon: 1});
  132. } else {
  133. tableIn.reload()
  134. layer.msg(res.msg, {time: 1000, icon: 2});
  135. }
  136. },"json");
  137. });
  138. table.on('tool(list)', function (obj) {
  139. var data = obj.data;
  140. if (obj.event === 'del') {
  141. layer.confirm('您确定要删除该账号吗', function (index) {
  142. loading = layer.load(1, {shade: [0.1, '#fff']});
  143. $.post("{:url('delete_user')}", {id: data.id}, function (res) {
  144. layer.close(loading);
  145. layer.close(index);
  146. if (res.code ==200) {
  147. layer.msg(res.msg, {time: 1000, icon: 1});
  148. obj.del();
  149. } else {
  150. layer.msg(res.msg, {time: 1000, icon: 2});
  151. }
  152. },"json");
  153. });
  154. }
  155. if (obj.event === 'update_pwd') {
  156. layer.prompt({title: '请填写新密码', formType: 3}, function(text, index){
  157. layer.close(index);
  158. if (!text){
  159. layer.msg("请填写新密码", {time: 1000, icon: 1});
  160. return ;
  161. }
  162. let datas={
  163. id:data.id,
  164. pwd:text
  165. }
  166. loading = layer.load(1, {shade: [0.1, '#fff']});
  167. $.post("{:url('update_pwd')}", datas, function (res) {
  168. layer.close(loading);
  169. if (res.code ==200) {
  170. layer.msg(res.msg, {time: 1000, icon: 1});
  171. // obj.del();
  172. } else {
  173. layer.msg(res.msg, {time: 1000, icon: 2});
  174. }
  175. },"json");
  176. });
  177. }
  178. // 弹出框
  179. if (obj.event === "vip_level") {
  180. user_id=data.id;
  181. vip_level=data.vip_level;
  182. $(".option-"+vip_level).attr("selected",true);
  183. redIndex = layer.open({
  184. type: 1,
  185. title: false,
  186. area: ['80%', ''], //宽高
  187. closeBtn: 0,
  188. shadeClose: false,
  189. skin: $(".yourclass"),
  190. content: $("#red"),
  191. });
  192. }
  193. });
  194. form.on('switch(status)', function (data) {
  195. // 修改状态
  196. loading = layer.load(1, {shade: [0.1, '#fff']});
  197. $.post("{:url('fenhao')}", {id: data.value}, function (res) {
  198. layer.close(loading);
  199. if (res.code == 200) {
  200. layer.msg(res.msg, {time: 1000, icon: 1});
  201. } else {
  202. layer.msg(res.msg, {time: 1000, icon: 2});
  203. }
  204. }, "json");
  205. });
  206. form.on('switch(is_admin)', function (data) {
  207. // 修改状态
  208. loading = layer.load(1, {shade: [0.1, '#fff']});
  209. $.post("{:url('is_admin')}", {id: data.value}, function (res) {
  210. layer.close(loading);
  211. if (res.code == 200) {
  212. layer.msg(res.msg, {time: 1000, icon: 1});
  213. } else {
  214. layer.msg(res.msg, {time: 1000, icon: 2});
  215. }
  216. }, "json");
  217. });
  218. $('#search').click(function () {
  219. var $keys = $('#keys').val();
  220. if (!$keys) {
  221. return layer.msg('请输入关键词');
  222. }
  223. tableIn.reload({page: {page: 1}, where: {keys: $keys}});
  224. })
  225. });
  226. // 取消
  227. function cancel() {
  228. $("#red").addClass("canel")
  229. layer.close(redIndex);
  230. }
  231. // 确定
  232. function sendRedpacket() {
  233. let vip_levels=$("#vip_levels").val()
  234. let loading = layer.load(1, {shade: [0.1, '#fff']});
  235. let data={
  236. id:user_id,
  237. level:vip_levels
  238. }
  239. $.post("{:url('update_leve')}", data, function (res) {
  240. layer.close(loading);
  241. layer.close(redIndex);
  242. if (res.code == 200) {
  243. window.location.reload()
  244. layer.msg(res.msg, {time: 1000, icon: 1});
  245. } else {
  246. layer.msg(res.msg, {time: 1000, icon: 2});
  247. }
  248. },"json");
  249. }
  250. </script>