list.blade.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>网站用户</title>
  6. <meta name="renderer" content="webkit">
  7. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  8. <meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
  9. <link rel="stylesheet" href="/layuiadmin/layui/css/layui.css" media="all">
  10. <link rel="stylesheet" href="/layuiadmin/style/admin.css" media="all">
  11. </head>
  12. <body>
  13. <div class="layui-fluid">
  14. <div class="layui-card">
  15. <div class="layui-form layui-card-header layuiadmin-card-header-auto">
  16. <div class="layui-form-item">
  17. <div class="layui-inline">
  18. <label class="layui-form-label">昵称</label>
  19. <div class="layui-input-block">
  20. <input type="text" name="first_name" placeholder="请输入" autocomplete="off" class="layui-input">
  21. </div>
  22. </div>
  23. <div class="layui-inline">
  24. <label class="layui-form-label">telegram ID</label>
  25. <div class="layui-input-block">
  26. <input type="text" name="member_id" placeholder="请输入" autocomplete="off" class="layui-input">
  27. </div>
  28. </div>
  29. <div class="layui-inline">
  30. <label class="layui-form-label">游戏ID</label>
  31. <div class="layui-input-block">
  32. <input type="text" name="game_id" placeholder="请输入" autocomplete="off" class="layui-input">
  33. </div>
  34. </div>
  35. <div class="layui-inline">
  36. <button class="layui-btn layuiadmin-btn-useradmin" lay-submit lay-filter="LAY-user-front-search">
  37. <i class="layui-icon layui-icon-search layuiadmin-button-btn"></i>
  38. </button>
  39. </div>
  40. </div>
  41. </div>
  42. <div class="layui-card-body">
  43. <div style="padding-bottom: 10px;"></div>
  44. <table id="LAY-user-manage" lay-filter="LAY-user-manage"></table>
  45. </div>
  46. </div>
  47. </div>
  48. <script type="text/html" id="toolbar">
  49. <a class="layui-btn layui-btn-xs" lay-event="buy">充值</a>
  50. </script>
  51. <script src="/layuiadmin/layui/layui.js"></script>
  52. <script src="/static/js/alpha_2.js"></script>
  53. <script>
  54. layui.config({
  55. base: '/layuiadmin/'
  56. }).extend({
  57. index: 'lib/index'
  58. }).use(['index', 'form', 'table', 'layer'], function () {
  59. const $ = layui.$, form = layui.form, table = layui.table, layer = layui.layer;
  60. const token = localStorage.getItem('token');
  61. //用户管理
  62. let tableList = table.render({
  63. elem: '#LAY-user-manage',
  64. url: "{{url('/admin/user')}}", //模拟接口
  65. headers: {Authorization: token},
  66. // toolbar: true,
  67. // lineStyle: 'maxHeight: 95px;',
  68. // defaultToolbar: ['filter'],
  69. cols: [[
  70. {field: 'id', width: 80, title: 'ID', align: 'center'},
  71. {field: 'member_id', title: 'telegram ID'},
  72. {field: 'first_name', title: '昵称'},
  73. {field: 'usdt', title: '钱包地址'},
  74. {field: "game_id", title: "游戏ID"},
  75. {title: '操作', toolbar: '#toolbar', minWidth: 100, hide: true}
  76. ]],
  77. page: true,
  78. limit: 50,
  79. limits: [50, 100, 200, 300],
  80. where: {lang: 'zh-CN'},
  81. height: 'full-137',
  82. text: {none: '无数据'},
  83. parseData(res) {
  84. return {
  85. code: res.code,
  86. msg: res.msg,
  87. count: res.data.total,
  88. data: res.data.data
  89. };
  90. }
  91. });
  92. table.on('tool(LAY-user-manage)', function (obj) {
  93. switch (obj.event) {
  94. case "buy":
  95. layer.prompt({
  96. title: "钱包余额充值",
  97. formType: 0,
  98. placeholder: '请输入要充值的金额'
  99. }, (value, index, elem) => {
  100. const priceRegex = /^\d+(\.\d{1,2})?$/;
  101. if (!priceRegex.test(value)) return false;
  102. if (parseFloat(value) === 0) return false;
  103. $.ajax({
  104. url: "",
  105. method: 'post',
  106. headers: {'X-CSRF-TOKEN': ""},
  107. data: {userId: obj.data.id, wallet: value},
  108. success(res) {
  109. if (res.code === 0) {
  110. tableList.reloadData();
  111. layer.close(index);
  112. } else {
  113. layer.msg(res.msg);
  114. }
  115. }
  116. });
  117. });
  118. break;
  119. case "img":
  120. let start = this.dataset.index - 1;
  121. let data = [];
  122. for (let i = 1; i < obj.data.photo.length; i++) {
  123. if (obj.data.photo[i]) {
  124. data.push({
  125. "alt": `个人自拍_${i}`,
  126. "pid": (i - 1),
  127. "src": obj.data.photo[i],
  128. "thumb": obj.data.photo[i],
  129. });
  130. }
  131. }
  132. layer.photos({
  133. toolbar: false,
  134. photos: {
  135. title: "个人自拍",
  136. id: obj.data.id,
  137. start: start,
  138. data: data
  139. }
  140. });
  141. break;
  142. }
  143. console.log(this.src);
  144. // console.log(obj)
  145. });
  146. form.on('submit(LAY-user-front-search)', function (data) {
  147. let field = data.field;
  148. table.reload('LAY-user-manage', {
  149. where: field
  150. });
  151. });
  152. });
  153. </script>
  154. </body>
  155. </html>