live_goods.php 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  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="is_pink">
  50. {{# if(d.is_pink){ }}
  51. <span class="layui-badge layui-bg-green">拼团开启</span>
  52. {{# }else{ }}
  53. <span class="layui-badge">拼团关闭</span>
  54. {{# } }}
  55. </script>
  56. <script type="text/html" id="gis_show">
  57. <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' : '' }}>
  58. </script>
  59. <script type="text/html" id="image">
  60. <img style="cursor: pointer;width: 80px;height: 40px;" lay-event='open_image' src="{{d.image}}">
  61. </script>
  62. <script type="text/html" id="act">
  63. <button type="button" class="layui-btn layui-btn-xs" onclick="dropdown(this)">操作 <span class="caret"></span></button>
  64. <ul class="layui-nav-child layui-anim layui-anim-upbit">
  65. <li>
  66. <a lay-event='delect' href="javascript:void(0)">
  67. <i class="fa fa-trash"></i> 移除
  68. </a>
  69. </li>
  70. </ul>
  71. </script>
  72. </div>
  73. </div>
  74. </div>
  75. </div>
  76. </div>
  77. <script src="{__ADMIN_PATH}js/layuiList.js"></script>
  78. {/block}
  79. {block name="script"}
  80. <script>
  81. //实例化form
  82. layList.form.render();
  83. layList.date({elem:'#start_time',theme:'#393D49',type:'datetime'});
  84. layList.date({elem:'#end_time',theme:'#393D49',type:'datetime'});
  85. //加载列表
  86. layList.tableList({o:'List', done:function () {}
  87. },"{:Url('live_goods_list',['live_id'=>$live_id])}",function (){
  88. return [
  89. {field: 'live_goods_id', title: '编号', sort: true,event:'live_goods_id',width:'8%',align: 'center'},
  90. {field: 'title', title: '专题名称',align: 'center'},
  91. {field: 'subject_name', title: '所属分类',align: 'center'},
  92. {field: 'image', title: '封面图',templet:'#image',align: 'center'},
  93. {field: 'gsales', title: '实际销量'},
  94. {field: 'gfake_sales', title: '虚拟销量',edit:'gfake_sales'},
  95. {field: 'gsort', title: '排序',sort: true,event:'gsort',edit:'gsort',align: 'center'},
  96. {field: 'gis_show', title: '是否显示',templet:'#gis_show',align: 'center'},
  97. {field: 'right', title: '操作',align:'center',toolbar:'#act',width:'10%'},
  98. ];
  99. });
  100. //下拉框
  101. $(document).click(function (e) {
  102. $('.layui-nav-child').hide();
  103. })
  104. function dropdown(that){
  105. var oEvent = arguments.callee.caller.arguments[0] || event;
  106. oEvent.stopPropagation();
  107. var offset = $(that).offset();
  108. var top=offset.top-$(window).scrollTop();
  109. var index = $(that).parents('tr').data('index');
  110. $('.layui-nav-child').each(function (key) {
  111. if (key != index) {
  112. $(this).hide();
  113. }
  114. })
  115. if($(document).height() < top+$(that).next('ul').height()){
  116. $(that).next('ul').css({
  117. 'padding': 10,
  118. 'top': - ($(that).parent('td').height() / 2 + $(that).height() + $(that).next('ul').height()/2),
  119. 'min-width': 'inherit',
  120. 'position': 'absolute'
  121. }).toggle();
  122. }else{
  123. $(that).next('ul').css({
  124. 'padding': 10,
  125. 'top':$(that).parent('td').height() / 2 + $(that).height(),
  126. 'min-width': 'inherit',
  127. 'position': 'absolute'
  128. }).toggle();
  129. }
  130. }
  131. //自定义方法
  132. var action= {
  133. set_value: function (field, id, value, model_type) {
  134. layList.baseGet(layList.Url({
  135. c:'special.special_type',
  136. a: 'set_value',
  137. q: {field: field, id: id, value: value, model_type:model_type}
  138. }), function (res) {
  139. layList.msg(res.msg);
  140. });
  141. },
  142. //打开新添加页面
  143. open_add: function (url,title) {
  144. layer.open({
  145. type: 2 //Page层类型
  146. ,area: ['100%', '100%']
  147. ,title: title
  148. ,shade: 0.6 //遮罩透明度
  149. ,maxmin: true //允许全屏最小化
  150. ,anim: 1 //0-6的动画形式,-1不开启
  151. ,content: url
  152. ,end:function() {
  153. location.reload();
  154. }
  155. });
  156. }
  157. }
  158. //查询
  159. layList.search('search',function(where){
  160. layList.reload(where,true);
  161. });
  162. layList.switch('gis_show',function (odj,value) {
  163. var is_show_value = 0
  164. if(odj.elem.checked==true){
  165. var is_show_value = 1
  166. }
  167. action.set_value('is_show',value,is_show_value,'live_goods');
  168. });
  169. //快速编辑
  170. layList.edit(function (obj) {
  171. var id=obj.data.live_goods_id,value=obj.value;
  172. switch (obj.field) {
  173. case 'gsort':
  174. if(value < 0) return layList.msg('排序不能小于0');
  175. action.set_value('sort',id,value,'live_goods');
  176. break;
  177. case 'gfake_sales':
  178. action.set_value('fake_sales',id,value,'live_goods');
  179. break;
  180. }
  181. });
  182. //监听并执行排序
  183. layList.sort(['live_goods_id','gsort'],true);
  184. //点击事件绑定
  185. layList.tool(function (event,data,obj) {
  186. switch (event) {
  187. case 'delect':
  188. 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'}});
  189. $eb.$swal('delete',function(){
  190. $eb.axios.get(url).then(function(res){
  191. if(res.status == 200 && res.data.code == 200) {
  192. $eb.$swal('success',res.data.msg);
  193. obj.del();
  194. }else
  195. return Promise.reject(res.data.msg || '删除失败')
  196. }).catch(function(err){
  197. $eb.$swal('error',err);
  198. });
  199. })
  200. break;
  201. case 'open_image':
  202. $eb.openImage(data.image);
  203. break;
  204. }
  205. })
  206. </script>
  207. {/block}