index.html 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364
  1. <style type="text/css">
  2. .xm-label-block {
  3. background-color: #287bd2
  4. }
  5. .usertb .layui-table-view .layui-table-body tbody > tr > td > .layui-table-cell {
  6. height: 50px;
  7. line-height: 50px;
  8. }
  9. .input-img-preview {
  10. /*border-radius: 50%;*/
  11. }
  12. .dropdown-menu-nav .layui-table td,
  13. .dropdown-menu-nav .layui-table th {
  14. padding: 5px;
  15. }
  16. </style>
  17. <!-- 正文开始 -->
  18. <div class="layui-fluid">
  19. <div class="layui-row layui-col-space15">
  20. <div class="layui-col-xs12 layui-col-sm6 layui-col-md3">
  21. <div class="layui-card">
  22. <div class="layui-card-header">
  23. 总订单金额<span class="layui-badge layui-badge-green pull-right">总</span>
  24. </div>
  25. <div class="layui-card-body">
  26. <p class="lay-big-font"><span style="font-size: 26px;line-height: 1;">¥</span><span id="total_amount">0</span></p>
  27. </div>
  28. </div>
  29. </div>
  30. <div class="layui-col-xs12 layui-col-sm6 layui-col-md3">
  31. <div class="layui-card">
  32. <div class="layui-card-header">
  33. 总订单量<span class="layui-badge layui-badge-blue pull-right">总</span>
  34. </div>
  35. <div class="layui-card-body">
  36. <p class="lay-big-font"><span id="total_num">0</span></p>
  37. </div>
  38. </div>
  39. </div>
  40. <div class="layui-col-xs12 layui-col-sm6 layui-col-md3">
  41. <div class="layui-card">
  42. <div class="layui-card-header">
  43. 总代理人数<span class="layui-badge layui-badge-red pull-right">总</span>
  44. </div>
  45. <div class="layui-card-body">
  46. <p class="lay-big-font"><span id="agent_num">0</span></p>
  47. </div>
  48. </div>
  49. </div>
  50. </div>
  51. <div style="height: 20px;"></div>
  52. <div class="layui-card">
  53. <div class="layui-card-body">
  54. <div class="layui-form toolbar" id="tbToolBar">
  55. <div class="layui-form-item">
  56. <div class="layui-inline">
  57. <label class="layui-form-label">手机号:</label>
  58. <div class="layui-input-inline">
  59. <input name="mobile" class="layui-input" placeholder="输入手机号">
  60. </div>
  61. </div>
  62. <div class="layui-inline">
  63. <label class="layui-form-label">用户名:</label>
  64. <div class="layui-input-inline">
  65. <input name="nickname" class="layui-input" placeholder="输入用户名">
  66. </div>
  67. </div>
  68. <div class="layui-inline">&emsp;
  69. <button class="layui-btn icon-btn" lay-filter="formSubSearchUser" lay-submit="">
  70. <i class="layui-icon"></i>搜索
  71. </button>
  72. </div>
  73. </div>
  74. </div>
  75. <div class="layui-tab layui-tab-brief usertb">
  76. <table id="dataTable" lay-filter="dataTable"></table>
  77. </div>
  78. </div>
  79. </div>
  80. </div>
  81. <script type="text/html" id="toolBarTpl">
  82. <div class="layui-btn-group fl">
  83. <a table-data="{'url':'users/plectron','action':'put',param:{'status': 40}}" class="layui-btn layui-btn-sm layui-icon layui-icon-play table-toolbar-btn">&nbsp;启用</a >
  84. <a table-data="{'url':'users/plectron','action':'put',param:{'status': 50}}" confirm class="layui-btn layui-btn-sm layui-icon layui-icon-pause table-toolbar-btn">&nbsp;冻结</a>
  85. <a table-data="{'url':'users/plectron','action':'delete'}" confirm class="layui-btn layui-btn-sm layui-icon layui-icon-close table-toolbar-btn">&nbsp;删除</a>
  86. </div>
  87. </script>
  88. <!-- 表格操作列 -->
  89. <script type="text/html" id="tableBarUser">
  90. <a class="layui-btn layui-btn-warm layui-btn-xs" lay-event="check">审核</a>
  91. <a class="layui-btn layui-btn-warm layui-btn-xs" lay-event="partnership">发放资产</a>
  92. <a class="layui-btn layui-btn-xs" lay-event="edit">编辑</a>
  93. <a class="layui-btn layui-btn-xs" lay-event="stats">详情</a>
  94. </script>
  95. <!-- 表格状态列 -->
  96. <script type="text/html" id="tableStateUser">
  97. {{# if(d.deleted_at !== 0){ }}
  98. <span class="layui-badge layui-badge-red">用户删除</span>
  99. {{# }else{ }}
  100. <input type="checkbox" value="{{ d.status }}" switch-data="{'url':'users/{{ d.id }}','action':'put'}" lay-skin="switch" lay-filter="ckDataTableState"
  101. lay-text="正常|锁定" {{d.status==1?'checked':''}}/>
  102. {{# } }}
  103. </script>
  104. <!-- 表单弹窗 -->
  105. <script type="text/html" id="modelUser">
  106. <div style="margin: 30px;">
  107. <div>管辖区域:<span id="region">测试区</span></div>
  108. <div>营业额:<span id="turnover">0</span></div>
  109. <div>订单量:<span id="total_order">0</span></div>
  110. <div>商户:<span id="seller">0</span></div>
  111. <div style="margin-top: 20px;display: flex;">
  112. <div style="padding: 15px 15px 15px 0;">
  113. <div style="margin-bottom: 3px;">¥<span>0</span></div>
  114. <div>摩的订单:<span id="taxi_order">0</span></div>
  115. </div>
  116. </div>
  117. </div>
  118. </script>
  119. <!--编辑-->
  120. <script type="text/html" id="modelArticle">
  121. <form id="modelArticleForm" lay-filter="modelArticleForm" class="layui-form model-form">
  122. <input name="id" type="hidden"/>
  123. <div class="model-form-body" style="max-height: 500px;">
  124. <div class="layui-form-item">
  125. <label class="layui-form-label layui-form-required">昵称</label>
  126. <div class="layui-input-block">
  127. <input name="username" placeholder="请输入昵称" type="text" class="layui-input" maxlength="80"
  128. lay-verType="tips" disabled/>
  129. </div>
  130. </div>
  131. <div class="layui-form-item">
  132. <label class="layui-form-label">手机号</label>
  133. <div class="layui-input-block">
  134. <input name="mobile" placeholder="请输入昵称" type="text" class="layui-input" maxlength="25"
  135. lay-verType="tips" lay-verify="required" required/>
  136. </div>
  137. </div>
  138. <div class="layui-form-item">
  139. <label class="layui-form-label">身份证号</label>
  140. <div class="layui-input-block">
  141. <input name="id_card" placeholder="请输入身份证号" type="text" class="layui-input" maxlength="11"
  142. lay-verType="tips" disabled/>
  143. </div>
  144. </div>
  145. </div>
  146. <div class="layui-form-item text-right">
  147. <button class="layui-btn layui-btn-primary" type="button" ew-event="closeDialog">取消</button>
  148. <button class="layui-btn" perm-show="put:/store/article/<id>" lay-filter="modelSubmitArticle" lay-submit>保存</button>
  149. </div>
  150. </form>
  151. </script>
  152. <!-- js部分 -->
  153. <script>
  154. layui.use(['layer', 'form', 'table', 'util', 'notice','md5', 'admin', 'setter', 'xmSelect', 'laydate', 'dropdown'], function () {
  155. var $ = layui.jquery;
  156. var layer = layui.layer;
  157. var form = layui.form;
  158. var table = layui.table;
  159. var util = layui.util;
  160. var admin = layui.admin;
  161. var notice = layui.notice;
  162. var setter = layui.setter;
  163. var md5 = layui.md5;
  164. var xmSelect = layui.xmSelect;
  165. var laydate = layui.laydate;
  166. // 时间选择
  167. laydate.render({
  168. elem: '#tbAdvSelDate',
  169. type: 'date',
  170. format: 'yyyy/MM/dd',
  171. calendar: true,
  172. theme: '#ec6c44',
  173. range: true,
  174. trigger: 'click'
  175. });
  176. form.render('select');
  177. // 渲染表格
  178. var insTb = table.render({
  179. elem: '#dataTable',
  180. url: setter.baseServer + 'users/motor_agent/index',
  181. page: true,
  182. title: "会员表",
  183. toolbar: '#toolBarTpl',
  184. cellMinWidth: 100,
  185. cols: [[
  186. {type: 'checkbox'},
  187. {field: 'user', title: '用户昵称', width: 130, templet: function (d) {
  188. return d.user? d.user.nickname : '';
  189. }},
  190. {field: 'username', title: '用户名', width: 100},
  191. {field: 'mobile', title: '手机号', width: 150},
  192. {field: 'area', title: '地区'},
  193. {field: 'id_card', title: '身份证号'},
  194. {field: 'id_card_img', title: '头像', templet: function (d) {
  195. return '<img src="' + (d.id_card_img || '../../assets/images/placeholder-refund.png') + '" style="height: 40px" class="input-img-preview"/>';
  196. }, width: 80},
  197. {
  198. field: 'created_at', sort: true, templet: function (d) {
  199. return util.toDateString(d.created_at * 1e3);
  200. }, title: '创建时间', width: 180
  201. },
  202. {field: 'status_text', title: '状态', width: 120},
  203. {fixed:'right', align: 'center', toolbar: '#tableBarUser', title: '操作', minWidth: 200}
  204. ]],
  205. done:function () {
  206. admin.renderPerm()
  207. }
  208. });
  209. // 工具条点击事件
  210. table.on('tool(dataTable)', function (obj) {
  211. var data = obj.data;
  212. var layEvent = obj.event;
  213. if (layEvent === 'stats') { // 数据
  214. showStatsModel(data);
  215. }
  216. else if (layEvent === 'check') {
  217. layer.confirm('确定要审核吗?', {
  218. skin: 'layui-layer-admin',
  219. shade: .1
  220. }, function (i) {
  221. layer.close(i);
  222. layer.load(2);
  223. admin.req('users/motor_agent/check/ids/' + data.id, {password: md5.exec('123456')},function (r) {
  224. layer.closeAll('loading');
  225. if (r.code === 10000) {
  226. notice.msg(r.message, {icon: 1});
  227. insTb.reload({}, 'data');
  228. } else {
  229. notice.msg(r.message, {icon: 2});
  230. }
  231. }, 'POST');
  232. });
  233. }
  234. else if (layEvent === 'partnership') {
  235. layer.prompt({
  236. formType: 2,
  237. title: '发放资产',
  238. }, function(value, index, elem){
  239. layer.close(index);
  240. layer.load(2);
  241. admin.req('users/motor_agent/partnership/ids/' + data.id, {amount: value}, function (r) {
  242. layer.closeAll('loading');
  243. if (r.code === 10000) {
  244. notice.msg(r.message, {icon: 1});
  245. insTb.reload({}, 'data');
  246. } else {
  247. notice.msg(r.message, {icon: 2});
  248. }
  249. }, 'post');
  250. });
  251. }
  252. else if (layEvent === 'edit') {
  253. showEditModel(data);
  254. }
  255. });
  256. function showStatsModel(data) {
  257. admin.open({
  258. type: 1,
  259. area: ['550px'], //宽高
  260. title: '代理【'+data.user.nickname+'】数据统计',
  261. content: $('#modelUser').html(),
  262. success: function (layero, dIndex) {
  263. admin.req('users/motor_agent/create/ids/'+data.id, {}, function (res) {
  264. if (res.code === 10000) {
  265. $.each(res.data,(i,d) => {
  266. if (d instanceof Object) {
  267. let total = 0,
  268. amount = 0;
  269. Object.keys(d).forEach((value, index) => {
  270. if (value) {
  271. total++;
  272. amount += parseFloat(value);
  273. }
  274. });
  275. $("#" + i).html(total).parent().prev().find('span').html(amount);
  276. }
  277. else{
  278. $("#" + i).html(d);
  279. }
  280. });
  281. } else {
  282. notice.msg(res.message, {icon: 2});
  283. }
  284. }, 'get');
  285. }
  286. });
  287. }
  288. function showEditModel(data) {
  289. admin.open({
  290. id:"LAY_modelArticle",
  291. type: 1,
  292. area: '720px', //宽高
  293. title: (data ? '修改' : '添加'),
  294. content: $('#modelArticle').html(),
  295. success: function (layero, dIndex) {
  296. // 回显数据
  297. form.val('modelArticleForm', data);
  298. form.render('radio');
  299. form.render('select');
  300. // 表单提交事件
  301. form.on('submit(modelSubmitArticle)', function (form) {
  302. layer.load(2);
  303. admin.req('users/motor_agent/update/id' + (data ? '/' + form.field.id : ''), form.field, function (res) {
  304. layer.closeAll('loading');
  305. if (res.code === 10000) {
  306. layer.close(dIndex);
  307. notice.msg(res.message, {icon: 1});
  308. insTb.reload({}, 'data');
  309. } else {
  310. notice.msg(res.message, {icon: 2});
  311. }
  312. }, data ? 'PUT' : 'POST');
  313. return false;
  314. });
  315. return false;
  316. }
  317. });
  318. }
  319. // 搜索
  320. form.on('submit(formSubSearchUser)', function (data) {
  321. insTb.reload({where: data.field,page: {curr: 1}}, 'data');
  322. });
  323. // 导出
  324. form.on('submit(formExportUser)', function (data) {
  325. admin.req("export/users",data.field,function (r) {
  326. if (r.code === 10000) {
  327. // 跳转
  328. window.open(r.data.url)
  329. } else {
  330. notice.msg(r.message, {icon: 2});
  331. }
  332. });
  333. });
  334. // 加载数据
  335. function loadData(data) {
  336. admin.req('users/motor_agent/stats', data, function (res) {
  337. if (res.code === 10000) {
  338. $.each(res.data,(i,d) => {
  339. $("#" + i).html(d)
  340. });
  341. } else {
  342. notice.msg(res.message, {icon: 2});
  343. }
  344. });
  345. }
  346. loadData(0);
  347. });
  348. </script>