index.php 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680
  1. {extend name="public/container"}
  2. {block name="head_top"}
  3. <script src="{__PLUG_PATH}city.js"></script>
  4. <style>
  5. .layui-btn-xs{margin-left: 0px !important;}
  6. legend{
  7. width: auto;
  8. border: none;
  9. font-weight: 700 !important;
  10. }
  11. .site-demo-button{
  12. padding-bottom: 20px;
  13. padding-left: 10px;
  14. }
  15. .layui-form-label{
  16. width: auto;
  17. }
  18. .layui-input-block input{
  19. width: 50%;
  20. height: 34px;
  21. }
  22. .layui-form-item{
  23. margin-bottom: 0;
  24. }
  25. .layui-input-block .time-w{
  26. width: 200px;
  27. }
  28. .layui-table-body{overflow-x: hidden;}
  29. .layui-btn-group button i{
  30. line-height: 30px;
  31. margin-right: 3px;
  32. vertical-align: bottom;
  33. }
  34. .back-f8{
  35. background-color: #F8F8F8;
  36. }
  37. .layui-input-block button{
  38. border: 1px solid #e5e5e5;
  39. }
  40. .avatar{width: 50px;height: 50px;}
  41. .layui-table-body{
  42. overflow-x: unset;
  43. }
  44. </style>
  45. {/block}
  46. {block name="content"}
  47. <div class="row">
  48. <div class="col-sm-12">
  49. <div class="ibox float-e-margins">
  50. <div class="ibox-title">
  51. <h5>会员搜索</h5>
  52. <div class="ibox-tools">
  53. <a class="collapse-link">
  54. <i class="fa fa-chevron-up"></i>
  55. </a>
  56. </div>
  57. </div>
  58. <div class="ibox-content" style="display: block;">
  59. <!-- <div class="alert alert-success alert-dismissable">-->
  60. <!-- <button aria-hidden="true" data-dismiss="alert" class="close" type="button">×</button>-->
  61. <!-- 目前拥有{$count_user}个会员-->
  62. <!-- </div>-->
  63. <form class="layui-form">
  64. <div class="layui-form-item">
  65. <div class="layui-inline">
  66. <label class="layui-form-label">姓名编号:</label>
  67. <div class="layui-input-inline">
  68. <input type="text" name="nickname" id="nickname" lay-verify="nickname" style="width: 100%" autocomplete="off" placeholder="请输入姓名、编号、手机号" class="layui-input">
  69. </div>
  70. </div>
  71. <div class="layui-inline">
  72. <label class="layui-form-label">用户类型:</label>
  73. <div class="layui-input-inline">
  74. <select name="user_type" lay-verify="user_type">
  75. <option value="">全部</option>
  76. <option value="wechat">微信公众号</option>
  77. <option value="routine">微信小程序</option>
  78. <option value="h5">H5</option>
  79. </select>
  80. </div>
  81. </div>
  82. <div class="layui-inline">
  83. <label class="layui-form-label">状  态:</label>
  84. <div class="layui-input-inline">
  85. <select name="status" lay-verify="status">
  86. <option value="">全部</option>
  87. <option value="1">正常</option>
  88. <option value="0">锁定</option>
  89. </select>
  90. </div>
  91. </div>
  92. <div class="layui-inline">
  93. <label class="layui-form-label">性  别:</label>
  94. <div class="layui-input-inline">
  95. <select name="sex" lay-verify="sex">
  96. <option value="">全部</option>
  97. <option value="1">男</option>
  98. <option value="2">女</option>
  99. <option value="0">保密</option>
  100. </select>
  101. </div>
  102. </div>
  103. <div class="layui-inline">
  104. <label class="layui-form-label">身  份:</label>
  105. <div class="layui-input-inline">
  106. <select name="is_promoter" lay-verify="is_promoter">
  107. <option value="">全部</option>
  108. <option value="1">推广员</option>
  109. <option value="0">普通用户</option>
  110. </select>
  111. </div>
  112. </div>
  113. <div class="layui-inline">
  114. <label class="layui-form-label">会员等级:</label>
  115. <div class="layui-input-inline">
  116. <select name="level" lay-verify="level" lay-filter='level' id="level">
  117. <option value="" id="level-top">全部</option>
  118. </select>
  119. </div>
  120. </div>
  121. <div class="layui-inline">
  122. <label class="layui-form-label">会员分组:</label>
  123. <div class="layui-input-inline">
  124. <select name="group_id" lay-verify="group" lay-filter='group' id="group">
  125. <option value="" id="group-top">全部</option>
  126. </select>
  127. </div>
  128. </div>
  129. <div class="layui-inline">
  130. <label class="layui-form-label">国  家:</label>
  131. <div class="layui-input-inline">
  132. <select name="country" lay-verify="country" lay-filter='country'>
  133. <option value="" selected="selected">请选择国家</option>
  134. <option value="domestic">中国</option>
  135. <option value="abroad">外国</option>
  136. </select>
  137. </div>
  138. </div>
  139. <div class="layui-inline" id="province-div">
  140. <label class="layui-form-label">省  份:</label>
  141. <div class="layui-input-inline">
  142. <select name="province" lay-verify="province" lay-filter='province' id="province">
  143. <option value="" id="province-top">请选择省</option>
  144. </select>
  145. </div>
  146. </div>
  147. <div class="layui-inline" id="city-div">
  148. <label class="layui-form-label">市  区:</label>
  149. <div class="layui-input-inline">
  150. <select name="city" lay-verify="city" lay-filter='city' id="city">
  151. <option value="" id="city-top">请选择市</option>
  152. </select>
  153. </div>
  154. </div>
  155. </div>
  156. <div class="layui-form-item">
  157. <div class="layui-inline">
  158. <label class="layui-form-label">消费情况:</label>
  159. <div class="layui-input-inline">
  160. <select name="pay_count" lay-verify="pay_count">
  161. <option value="">全部</option>
  162. <option value="-1">0</option>
  163. <option value="0">1+</option>
  164. <option value="1">2+</option>
  165. <option value="2">3+</option>
  166. <option value="3">4+</option>
  167. <option value="4">5+</option>
  168. </select>
  169. </div>
  170. </div>
  171. <div class="layui-inline">
  172. <label class="layui-form-label">访问情况:</label>
  173. <div class="layui-input-inline">
  174. <select name="user_time_type" lay-verify="user_time_type">
  175. <option value="">全部</option>
  176. <option value="visitno">时间段未访问</option>
  177. <option value="visit">时间段访问过</option>
  178. <option value="add_time">首次访问</option>
  179. </select>
  180. </div>
  181. </div>
  182. <div class="layui-inline">
  183. <label class="layui-form-label">选择时间:</label>
  184. <div class="layui-input-inline">
  185. <input type="text" class="layui-input time-w" name="user_time" lay-verify="user_time" id="user_time" placeholder=" - ">
  186. </div>
  187. </div>
  188. </div>
  189. <div class="layui-col-lg12" id="app1">
  190. <button @click="excel" type="button"
  191. class="layui-btn layui-btn-warm layui-btn-sm export" type="button">
  192. <i class="fa fa-floppy-o" style="margin-right: 3px;"></i>导出
  193. </button>
  194. </div>
  195. <div class="layui-form-item">
  196. <label class="layui-form-label">
  197. <button class="layui-btn layui-btn-sm layui-btn-normal" lay-submit="" lay-filter="search" >
  198. <i class="layui-icon layui-icon-search layuiadmin-button-btn"></i>搜索</button>
  199. </label>
  200. </div>
  201. </form>
  202. </div>
  203. </div>
  204. </div>
  205. </div>
  206. <div class="row">
  207. <div class="col-sm-12">
  208. <div class="ibox">
  209. <div class="ibox-content">
  210. <div class="table-responsive">
  211. <div class="layui-btn-group conrelTable">
  212. <!-- <button class="layui-btn layui-btn-sm layui-btn-danger" type="button" data-type="set_status_f"><i class="fa fa-ban"></i>封禁</button>-->
  213. <!-- <button class="layui-btn layui-btn-sm layui-btn-normal" type="button" data-type="set_status_j"><i class="fa fa-check-circle-o"></i>解封</button>-->
  214. <button class="layui-btn layui-btn-sm layui-btn-normal" type="button" data-type="set_grant"><i class="fa fa-check-circle-o"></i>发送优惠券</button>
  215. <button class="layui-btn layui-btn-sm layui-btn-normal" type="button" data-type="set_custom"><i class="fa fa-check-circle-o"></i>发送客服图文消息</button>
  216. <button class="layui-btn layui-btn-sm layui-btn-normal" type="button" data-type="set_group"><i class="fa fa-check-circle-o" ></i>批量设置分组</button>
  217. <!-- <button class="layui-btn layui-btn-sm layui-btn-normal" type="button" data-type="set_template"><i class="fa fa-check-circle-o"></i>发送模板消息</button>-->
  218. <!-- <button class="layui-btn layui-btn-sm layui-btn-normal" type="button" data-type="set_info"><i class="fa fa-check-circle-o"></i>发送站内消息</button>-->
  219. <button class="layui-btn layui-btn-sm layui-btn-normal" type="button" data-type="refresh"><i class="layui-icon layui-icon-refresh" ></i>刷新</button>
  220. </div>
  221. <table class="layui-hide" id="userList" lay-filter="userList"></table>
  222. <script type="text/html" id="nickname">
  223. {{d.nickname}}
  224. </script>
  225. <script type="text/html" id="vip">
  226. {{# if(d.vip_name){ }}
  227. <p style="color:#dab176">{{d.vip_name}}</p>
  228. {{# } else{ }}
  229. 普通会员
  230. {{# } }}
  231. </script>
  232. <script type="text/html" id="effective">
  233. {{# if(d.effective == 1){ }}
  234. 有效
  235. {{# } else if(d.effective == 0) { }}
  236. 无效
  237. {{# } }}
  238. </script>
  239. <script type="text/html" id="is_merchant">
  240. {{# if(d.is_merchant == 1){ }}
  241. {{# } else if(d.is_merchant == 0) { }}
  242. {{# } }}
  243. </script>
  244. <script type="text/html" id="flowing_water">
  245. {{d.flowing_water}}%
  246. </script>
  247. <script type="text/html" id="data_time">
  248. <p>最近:{{d.last_time}}</p>
  249. </script>
  250. <script type="text/html" id="checkboxstatus">
  251. <input type='checkbox' name='status' lay-skin='switch' value="{{d.uid}}" lay-filter='status' lay-text='正常|禁止' {{ d.status == 1 ? 'checked' : '' }}>
  252. </script>
  253. <script type="text/html" id="barDemo">
  254. <button type="button" class="layui-btn layui-btn-xs" lay-event="edit"><i class="layui-icon layui-icon-edit"></i>编辑</button>
  255. <button type="button" class="layui-btn layui-btn-xs" onclick="dropdown(this)">操作 <span class="caret"></span></button>
  256. <ul class="layui-nav-child layui-anim layui-anim-upbit">
  257. <li>
  258. <a href="javascript:void(0);" lay-event="money">
  259. <i class="layui-icon layui-icon-edit"></i> 余额积分</a>
  260. </li>
  261. <li>
  262. <a href="javascript:void(0);" lay-event="see">
  263. <i class="layui-icon layui-icon-edit"></i> 会员详情</a>
  264. </li>
  265. <li>
  266. <a href="javascript:void(0);" lay-event="income">
  267. <i class="layui-icon layui-icon-star-fill" aria-hidden="true"></i> 收入支出</a>
  268. </li>
  269. <li>
  270. <a href="javascript:void(0);" lay-event="give_level">
  271. <i class="layui-icon layui-icon-star-fill" aria-hidden="true"></i> 修改会员等级</a>
  272. </li>
  273. <li>
  274. <a href="javascript:void(0);" lay-event="set_group">
  275. <i class="layui-icon layui-icon-star-fill" aria-hidden="true"></i> 设置分组</a>
  276. </li>
  277. {{# if(d.vip_name){ }}
  278. <li>
  279. <a href="javascript:void(0);" lay-event="del_level">
  280. <i class="layui-icon layui-icon-close-fill" aria-hidden="true"></i> 清除等级</a>
  281. </li>
  282. {{# } }}
  283. </ul>
  284. </script>
  285. </div>
  286. </div>
  287. </div>
  288. </div>
  289. </div>
  290. <script src="{__ADMIN_PATH}js/layuiList.js"></script>
  291. <script src="{__FRAME_PATH}js/content.min.js?v=1.0.0"></script>
  292. {/block}
  293. {block name="script"}
  294. <script>
  295. var level=<?=$level?>;
  296. var group=<?=$group?>;
  297. $('#province-div').hide();
  298. $('#city-div').hide();
  299. layList.select('country',function (odj,value,name) {
  300. var html = '';
  301. $.each(city,function (index,item) {
  302. html += '<option value="'+item.label+'">'+item.label+'</option>';
  303. })
  304. if(odj.value == 'domestic'){
  305. $('#province-div').show();
  306. $('#city-div').show();
  307. $('#province-top').siblings().remove();
  308. $('#province-top').after(html);
  309. $('#province').val('');
  310. layList.form.render('select');
  311. }else{
  312. $('#province-div').hide();
  313. $('#city-div').hide();
  314. }
  315. $('#province').val('');
  316. $('#city').val('');
  317. });
  318. layList.select('province',function (odj,value,name) {
  319. var html = '';
  320. $.each(city,function (index,item) {
  321. if(item.label == odj.value){
  322. $.each(item.children,function (indexe,iteme) {
  323. html += '<option value="'+iteme.label+'">'+iteme.label+'</option>';
  324. })
  325. $('#city').val('');
  326. $('#city-top').siblings().remove();
  327. $('#city-top').after(html);
  328. layList.form.render('select');
  329. }
  330. })
  331. });
  332. layList.form.render();
  333. layList.tableList('userList',"{:Url('get_user_list')}",function () {
  334. return [
  335. {type:'checkbox'},
  336. {field: 'uid', title: '编号',event:'uid',width:'4%',align:'center'},
  337. // {field: 'avatar', title: '头像', event:'open_image', width: '6%',align:'center', templet: '<p lay-event="open_image"><img class="avatar" style="cursor: pointer" class="open_image" data-image="{{d.avatar}}" src="{{d.avatar}}" alt="{{d.nickname}}"></p>'},
  338. {field: 'nickname', title: '姓名',templet:'#nickname',align:'center'},
  339. {field: 'vip', title: '姓名',templet:'#vip',align:'center'},
  340. {field: 'phone', title: '手机号',align:'center',width:'8%'},
  341. {field: 'now_money', title: '余额',sort:true,event:'now_money',align:'center'},
  342. {field: 'pay_count', title: '购买次数',align:'center'},
  343. {field: 'extract_count_price', title: '累计提现',align:'center'},
  344. {field: 'integral', title: '商城积分',sort:true,event:'integral',align:'center'},
  345. {field: 'white_integral', title: '红积分',sort:true,event:'white_integral',align:'center'},
  346. {field: 'purple_integral', title: '阳光积分',sort:true,event:'purple_integral',align:'center'},
  347. // {field: 'green_integral', title: '吉祥积分',sort:true,event:'green_integral',align:'center'},
  348. // {field: 'business_integral', title: '喜嗨积分',sort:true,event:'business_integral',align:'center'},
  349. // {field: 'paper_ticket', title: '文票',sort:true,event:'paper_ticket',align:'center'},
  350. {field: 'spread_uid_nickname', title: '推荐人',align:'center'},
  351. // {field: 'sex', title: '性别',width:'4%',align:'center'},
  352. {field: 'data_time', title: '访问日期',align:'center',width:'12%',templet:'#data_time'},
  353. // {field: 'status', title: '状态',templet:"#checkboxstatus",width:'6%',align:'center'},
  354. {field: 'effective', title: '账户状态',templet:"#effective",align:'center'},
  355. {field: 'is_merchant', title: '商家状态',templet:"#is_merchant",align:'center'},
  356. {field: 'flowing_water', title: '流水分红',align:'center',templet:"#flowing_water"},
  357. // {field: 'user_type', title: '用户类型',width:'6%',align:'center'},
  358. {field: 'operate', title: '操作', width: '10%', align: 'center', toolbar: '#barDemo'}
  359. ];
  360. });
  361. //页面刷新时加载
  362. layui.use('layer',function(){
  363. var layer = layui.layer;
  364. layer.ready(function(){
  365. var html = '';
  366. $.each(level,function (index,item) {
  367. html += '<option value="'+item.id+'">'+item.name+'</option>';
  368. })
  369. $('#level-top').val('');
  370. $('#level-top').siblings().remove();
  371. $('#level-top').after(html);
  372. layList.form.render('select');
  373. var htmls = '';
  374. $.each(group,function (index,item) {
  375. htmls += '<option value="'+item.id+'">'+item.group_name+'</option>';
  376. })
  377. $('#group-top').val('');
  378. $('#group-top').siblings().remove();
  379. $('#group-top').after(htmls);
  380. layList.form.render('select');
  381. });
  382. });
  383. layList.date('last_time');
  384. layList.date('add_time');
  385. layList.date('user_time');
  386. layList.date('time');
  387. //监听并执行 uid 的排序
  388. layList.sort(function (obj) {
  389. var layEvent = obj.field;
  390. var type = obj.type;
  391. switch (layEvent){
  392. case 'uid':
  393. layList.reload({order: layList.order(type,'u.uid')},true,null,obj);
  394. break;
  395. case 'now_money':
  396. layList.reload({order: layList.order(type,'u.now_money')},true,null,obj);
  397. break;
  398. case 'integral':
  399. layList.reload({order: layList.order(type,'u.integral')},true,null,obj);
  400. break;
  401. }
  402. });
  403. //监听并执行 uid 的排序
  404. layList.tool(function (event,data,obj) {
  405. var layEvent = event;
  406. switch (layEvent){
  407. case 'edit':
  408. $eb.createModalFrame('编辑',layList.Url({a:'edit',p:{uid:data.uid}}));
  409. break;
  410. case 'see':
  411. $eb.createModalFrame(data.nickname+'-会员详情',layList.Url({a:'see',p:{uid:data.uid}}));
  412. break;
  413. case 'del_level':
  414. $eb.$swal('delete',function(){
  415. $eb.axios.get(layList.U({a:'del_level',q:{uid:data.uid}})).then(function(res){
  416. if(res.status == 200 && res.data.code == 200) {
  417. $eb.$swal('success',res.data.msg);
  418. obj.update({vip_name:false});
  419. layList.reload();
  420. }else
  421. return Promise.reject(res.data.msg || '删除失败')
  422. }).catch(function(err){
  423. $eb.$swal('error',err);
  424. });
  425. },{
  426. title:'您确定要清除【'+data.nickname+'】的会员等级吗?',
  427. text:'清除后无法恢复请谨慎操作',
  428. confirm:'是的我要清除'
  429. })
  430. break;
  431. case 'give_level':
  432. $eb.createModalFrame(data.nickname+'-赠送会员',layList.Url({a:'give_level',p:{uid:data.uid}}),{w:500,h:300});
  433. break;
  434. case 'set_group':
  435. $eb.createModalFrame(data.nickname+'-设置分组',layList.Url({a:'set_group',p:{uid:data.uid}}),{w:500,h:300});
  436. break;
  437. case 'money':
  438. $eb.createModalFrame(data.nickname+'-积分余额修改',layList.Url({a:'edit_other',p:{uid:data.uid}}));
  439. break;
  440. case 'income':
  441. $eb.createModalFrame(data.nickname+'-收入支出',layList.Url({a:'income',p:{uid:data.uid}}),{w:750,h:750});
  442. break;
  443. case 'open_image':
  444. $eb.openImage(data.avatar);
  445. break;
  446. }
  447. });
  448. //layList.sort('uid');
  449. //监听并执行 now_money 的排序
  450. // layList.sort('now_money');
  451. //监听 checkbox 的状态
  452. layList.switch('status',function (odj,value,name) {
  453. if(odj.elem.checked==true){
  454. layList.baseGet(layList.Url({a:'set_status',p:{status:1,uid:value}}),function (res) {
  455. layList.msg(res.msg);
  456. });
  457. }else{
  458. layList.baseGet(layList.Url({a:'set_status',p:{status:0,uid:value}}),function (res) {
  459. layList.msg(res.msg);
  460. });
  461. }
  462. });
  463. layList.search('search',function(where){
  464. if(where['user_time_type'] != '' && where['user_time'] == '') return layList.msg('请选择选择时间');
  465. if(where['user_time_type'] == '' && where['user_time'] != '') return layList.msg('请选择访问情况');
  466. layList.reload(where,true);
  467. });
  468. var action={
  469. set_status_f:function () {
  470. var ids=layList.getCheckData().getIds('uid');
  471. if(ids.length){
  472. layList.basePost(layList.Url({a:'set_status',p:{is_echo:1,status:0}}),{uids:ids},function (res) {
  473. layList.msg(res.msg);
  474. layList.reload();
  475. });
  476. }else{
  477. layList.msg('请选择要封禁的会员');
  478. }
  479. },
  480. set_status_j:function () {
  481. var ids=layList.getCheckData().getIds('uid');
  482. if(ids.length){
  483. layList.basePost(layList.Url({a:'set_status',p:{is_echo:1,status:1}}),{uids:ids},function (res) {
  484. layList.msg(res.msg);
  485. layList.reload();
  486. });
  487. }else{
  488. layList.msg('请选择要解封的会员');
  489. }
  490. },
  491. set_grant:function () {
  492. var ids=layList.getCheckData().getIds('uid');
  493. if(ids.length){
  494. var str = ids.join(',');
  495. $eb.createModalFrame('发送优惠券',layList.Url({c:'ump.store_coupon',a:'grant',p:{id:str}}),{'w':800});
  496. }else{
  497. layList.msg('请选择要发送优惠券的会员');
  498. }
  499. },
  500. set_template:function () {
  501. var ids=layList.getCheckData().getIds('uid');
  502. if(ids.length){
  503. var str = ids.join(',');
  504. }else{
  505. layList.msg('请选择要发送模板消息的会员');
  506. }
  507. },
  508. set_info:function () {
  509. var ids=layList.getCheckData().getIds('uid');
  510. if(ids.length){
  511. var str = ids.join(',');
  512. $eb.createModalFrame('发送站内信息',layList.Url({c:'user.user_notice',a:'notice',p:{id:str}}),{'w':1200});
  513. }else{
  514. layList.msg('请选择要发送站内信息的会员');
  515. }
  516. },
  517. set_custom:function () {
  518. var ids=layList.getCheckData().getIds('uid');
  519. if(ids.length){
  520. var str = ids.join(',');
  521. $eb.createModalFrame('发送客服图文消息',layList.Url({c:'wechat.wechat_news_category',a:'send_news',p:{id:str,type:1}}),{'w':1200});
  522. }else{
  523. layList.msg('请选择要发送客服图文消息的会员');
  524. }
  525. },
  526. set_group:function () {
  527. var ids=layList.getCheckData().getIds('uid');
  528. if(ids.length){
  529. var str = ids.join(',');
  530. $eb.createModalFrame('批量设置分组',layList.Url({a:'set_group',p:{uid:str}}),{w:500,h:300});
  531. }else{
  532. layList.msg('请选择要批量设置分组的会员');
  533. }
  534. },
  535. refresh:function () {
  536. layList.reload();
  537. }
  538. };
  539. $('.conrelTable').find('button').each(function () {
  540. var type=$(this).data('type');
  541. $(this).on('click',function () {
  542. action[type] && action[type]();
  543. })
  544. })
  545. $(document).on('click',".open_image",function (e) {
  546. var image = $(this).data('image');
  547. $eb.openImage(image);
  548. })
  549. //下拉框
  550. $(document).click(function (e) {
  551. $('.layui-nav-child').hide();
  552. })
  553. function dropdown(that){
  554. var oEvent = arguments.callee.caller.arguments[0] || event;
  555. oEvent.stopPropagation();
  556. var offset = $(that).offset();
  557. var top=offset.top-$(window).scrollTop();
  558. var index = $(that).parents('tr').data('index');
  559. $('.layui-nav-child').each(function (key) {
  560. if (key != index) {
  561. $(this).hide();
  562. }
  563. })
  564. if($(document).height() < top+$(that).next('ul').height()){
  565. $(that).next('ul').css({
  566. 'padding': 10,
  567. 'top': - ($(that).parent('td').height() / 2 + $(that).height() + $(that).next('ul').height()/2),
  568. 'left':offset.left-$(that).parents('td').offset().left-20,
  569. 'min-width': 'inherit',
  570. 'position': 'absolute'
  571. }).toggle();
  572. }else{
  573. $(that).next('ul').css({
  574. 'padding': 10,
  575. 'top':$(that).parent('td').height() / 2 + $(that).height(),
  576. 'left':offset.left-$(that).parents('td').offset().left-20,
  577. 'min-width': 'inherit',
  578. 'position': 'absolute'
  579. }).toggle();
  580. }
  581. }
  582. require(['vue'], function (Vue) {
  583. new Vue({
  584. el: "#app1",
  585. data: {
  586. badge: [],
  587. where: {
  588. nickname: '',
  589. group: '',
  590. excel: 0,
  591. },
  592. showtime: false,
  593. },
  594. watch: {
  595. 'where.status': function () {
  596. this.where.excel = 0;
  597. this.getBadge();
  598. layList.reload(this.where, true);
  599. },
  600. 'where.data': function () {
  601. this.where.excel = 0;
  602. this.getBadge();
  603. layList.reload(this.where, true);
  604. },
  605. 'where.type': function () {
  606. this.where.excel = 0;
  607. this.getBadge();
  608. layList.reload(this.where, true);
  609. },
  610. 'where.pay_type': function () {
  611. this.where.excel = 0;
  612. this.getBadge();
  613. layList.reload(this.where, true);
  614. }
  615. },
  616. methods: {
  617. setData: function (item) {
  618. var that = this;
  619. if (item.is_zd == true) {
  620. that.showtime = true;
  621. this.where.data = this.$refs.date_time.innerText;
  622. } else {
  623. this.showtime = false;
  624. this.where.data = item.value;
  625. }
  626. },
  627. getBadge: function () {
  628. var that = this;
  629. layList.basePost(layList.Url({c: 'order.store_order', a: 'getBadge'}), this.where, function (rem) {
  630. that.badge = rem.data;
  631. });
  632. },
  633. search: function () {
  634. this.where.excel = 0;
  635. this.getBadge();
  636. layList.reload(this.where, true);
  637. },
  638. refresh: function () {
  639. layList.reload();
  640. this.getBadge();
  641. },
  642. excel: function () {
  643. var nickname = $('#nickname').val();
  644. var group = $('#group').val();
  645. this.where['nickname'] = nickname;
  646. this.where['group'] = group;
  647. this.where.excel = 1;
  648. location.href = layList.U({c: 'user.user', a: 'get_user_list', q: this.where});
  649. this.where.excel = 0;
  650. }
  651. },
  652. mounted: function () {
  653. var that = this;
  654. that.getBadge();
  655. window.formReload = this.search;
  656. layList.laydate.render({
  657. elem: this.$refs.date_time,
  658. trigger: 'click',
  659. eventElem: this.$refs.time,
  660. range: true,
  661. change: function (value) {
  662. that.where.data = value;
  663. }
  664. });
  665. }
  666. })
  667. });
  668. </script>
  669. {/block}