live_store.php 10 KB

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