live_store.php 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. {extend name="public/container"}
  2. {block name="content"}
  3. <div class="layui-fluid" style="background: #fff">
  4. <div class="layui-row layui-col-space15" id="app">
  5. <div class="layui-col-md12">
  6. <div class="layui-card">
  7. <div class="layui-card-body">
  8. <form class="layui-form layui-form-pane" action="">
  9. <div class="layui-form-item">
  10. <div class="layui-inline">
  11. <label class="layui-form-label">商品名称</label>
  12. <div class="layui-input-block">
  13. <input type="text" name="store_name" class="layui-input" placeholder="请输入商品名称,关键字,编号">
  14. </div>
  15. </div>
  16. <div class="layui-inline">
  17. <label class="layui-form-label">是否显示</label>
  18. <div class="layui-input-block">
  19. <select name="is_show">
  20. <option value="">全部</option>
  21. <option value="1">显示</option>
  22. <option value="0">隐藏</option>
  23. </select>
  24. </div>
  25. </div>
  26. <div class="layui-inline">
  27. <div class="layui-input-inline">
  28. <button class="layui-btn layui-btn-sm layui-btn-normal" lay-submit="search" lay-filter="search">
  29. <i class="layui-icon layui-icon-search"></i>搜索</button>
  30. </div>
  31. </div>
  32. </div>
  33. </form>
  34. </div>
  35. </div>
  36. </div>
  37. <!--产品列表-->
  38. <div class="layui-col-md12">
  39. <div class="layui-card">
  40. <div class="layui-card-body">
  41. <div class="alert alert-info" role="alert">
  42. 列表[排序]可进行快速修改,双击或者单击进入编辑模式,失去焦点可进行自动保存
  43. <button type="button" class="close" data-dismiss="alert" aria-label="Close"><span aria-hidden="true">&times;</span></button>
  44. </div>
  45. <div class="layui-btn-container">
  46. <button class="layui-btn layui-btn-normal layui-btn-sm" onclick="window.location.reload()"><i class="layui-icon layui-icon-refresh"></i> 刷新</button>
  47. </div>
  48. <table class="layui-hide" id="List" lay-filter="List"></table>
  49. <script type="text/html" id="gis_show">
  50. <input type='checkbox' name='live_goods_id' lay-skin='switch' value="{{d.live_goods_id}}" lay-filter='gis_show' lay-text='显示|隐藏' {{ d.gis_show == 1 ? 'checked' : '' }}>
  51. </script>
  52. <script type="text/html" id="image">
  53. <img style="cursor: pointer;width: 80px;height: 40px;" lay-event='open_image' src="{{d.image}}">
  54. </script>
  55. <script type="text/html" id="act">
  56. <button type="button" class="layui-btn layui-btn-xs" onclick="dropdown(this)">操作 <span class="caret"></span></button>
  57. <ul class="layui-nav-child layui-anim layui-anim-upbit">
  58. <li>
  59. <a lay-event='delect' href="javascript:void(0)">
  60. <i class="fa fa-trash"></i> 移除
  61. </a>
  62. </li>
  63. </ul>
  64. </script>
  65. </div>
  66. </div>
  67. </div>
  68. </div>
  69. </div>
  70. <script src="{__ADMIN_PATH}js/layuiList.js"></script>
  71. {/block}
  72. {block name="script"}
  73. <script>
  74. //实例化form
  75. layList.form.render();
  76. layList.date({elem:'#start_time',theme:'#393D49',type:'datetime'});
  77. layList.date({elem:'#end_time',theme:'#393D49',type:'datetime'});
  78. //加载列表
  79. layList.tableList({o:'List', done:function () {}
  80. },"{:Url('live_store_list',['live_id'=>$live_id])}",function (){
  81. return [
  82. {field: 'live_goods_id', title: '编号', sort: true,event:'live_goods_id',width:'8%',align: 'center'},
  83. {field: 'store_name', title: '商品名称',align: 'center'},
  84. {field: 'cate_name', title: '所属分类',align: 'center'},
  85. {field: 'image', title: '封面图',templet:'#image',align: 'center'},
  86. {field: 'gsales', title: '实际销量'},
  87. {field: 'gfake_sales', title: '虚拟销量',edit:'gfake_sales'},
  88. {field: 'gsort', title: '排序',sort: true,event:'gsort',edit:'gsort',align: 'center'},
  89. {field: 'gis_show', title: '是否显示',templet:'#gis_show',align: 'center'},
  90. {field: 'right', title: '操作',align:'center',toolbar:'#act',width:'10%'},
  91. ];
  92. });
  93. //下拉框
  94. $(document).click(function (e) {
  95. $('.layui-nav-child').hide();
  96. })
  97. function dropdown(that){
  98. var oEvent = arguments.callee.caller.arguments[0] || event;
  99. oEvent.stopPropagation();
  100. var offset = $(that).offset();
  101. var top=offset.top-$(window).scrollTop();
  102. var index = $(that).parents('tr').data('index');
  103. $('.layui-nav-child').each(function (key) {
  104. if (key != index) {
  105. $(this).hide();
  106. }
  107. })
  108. if($(document).height() < top+$(that).next('ul').height()){
  109. $(that).next('ul').css({
  110. 'padding': 10,
  111. 'top': - ($(that).parent('td').height() / 2 + $(that).height() + $(that).next('ul').height()/2),
  112. 'min-width': 'inherit',
  113. 'position': 'absolute'
  114. }).toggle();
  115. }else{
  116. $(that).next('ul').css({
  117. 'padding': 10,
  118. 'top':$(that).parent('td').height() / 2 + $(that).height(),
  119. 'min-width': 'inherit',
  120. 'position': 'absolute'
  121. }).toggle();
  122. }
  123. }
  124. //自定义方法
  125. var action= {
  126. set_value: function (field, id, value, model_type) {
  127. layList.baseGet(layList.Url({
  128. c:'special.special_type',
  129. a: 'set_value',
  130. q: {field: field, id: id, value: value, model_type:model_type}
  131. }), function (res) {
  132. layList.msg(res.msg);
  133. });
  134. },
  135. //打开新添加页面
  136. open_add: function (url,title) {
  137. layer.open({
  138. type: 2 //Page层类型
  139. ,area: ['100%', '100%']
  140. ,title: title
  141. ,shade: 0.6 //遮罩透明度
  142. ,maxmin: true //允许全屏最小化
  143. ,anim: 1 //0-6的动画形式,-1不开启
  144. ,content: url
  145. ,end:function() {
  146. location.reload();
  147. }
  148. });
  149. }
  150. }
  151. //查询
  152. layList.search('search',function(where){
  153. layList.reload(where,true);
  154. });
  155. layList.switch('gis_show',function (odj,value) {
  156. var is_show_value = 0
  157. if(odj.elem.checked==true){
  158. var is_show_value = 1
  159. }
  160. action.set_value('is_show',value,is_show_value,'live_goods');
  161. });
  162. //快速编辑
  163. layList.edit(function (obj) {
  164. var id=obj.data.live_goods_id,value=obj.value;
  165. switch (obj.field) {
  166. case 'gsort':
  167. if(value < 0) return layList.msg('排序不能小于0');
  168. action.set_value('sort',id,value,'live_goods');
  169. break;
  170. case 'gfake_sales':
  171. action.set_value('fake_sales',id,value,'live_goods');
  172. break;
  173. }
  174. });
  175. //监听并执行排序
  176. layList.sort(['live_goods_id','gsort'],true);
  177. //点击事件绑定
  178. layList.tool(function (event,data,obj) {
  179. switch (event) {
  180. case 'delect':
  181. var url=layList.U({c:'special.special_type',a:'set_value',q:{id:data.live_goods_id, field:'is_delete',value:1,model_type:'live_goods'}});
  182. $eb.$swal('delete',function(){
  183. $eb.axios.get(url).then(function(res){
  184. if(res.status == 200 && res.data.code == 200) {
  185. $eb.$swal('success',res.data.msg);
  186. obj.del();
  187. }else
  188. return Promise.reject(res.data.msg || '删除失败')
  189. }).catch(function(err){
  190. $eb.$swal('error',err);
  191. });
  192. })
  193. break;
  194. case 'open_image':
  195. $eb.openImage(data.image);
  196. break;
  197. }
  198. })
  199. </script>
  200. {/block}