From d9361b75e7072b29535c571a76e0b9e7860d6805 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Mon, 06 Jan 2025 14:38:53 +0800
Subject: [PATCH] feat(mall): 后台活动列表添加分页和搜索功能 - 在 ActivityServiceImpl 中实现 getAdminListInPage 方法,支持分页和搜索 - 在 AdminActivityController 中添加 list 接口,返回分页数据 - 在 IActivityService 中定义 getAdminListInPage 接口 - 更新前端模板,根据活动状态控制按钮显示
---
 src/main/resources/templates/febs/views/modules/goods/goodsList.html |   74 +++++++++++++++++++++++++++---------
 1 files changed, 55 insertions(+), 19 deletions(-)
diff --git a/src/main/resources/templates/febs/views/modules/goods/goodsList.html b/src/main/resources/templates/febs/views/modules/goods/goodsList.html
index bd804bb..518d7a3 100644
--- a/src/main/resources/templates/febs/views/modules/goods/goodsList.html
+++ b/src/main/resources/templates/febs/views/modules/goods/goodsList.html
@@ -8,8 +8,9 @@
                             <div class="layui-col-md10">
                                 <div class="layui-form-item">
                                     <div class="layui-inline">
+                                        <label class="layui-form-label layui-form-label-sm">商品名称</label>
                                         <div class="layui-input-inline">
-                                            <input type="text" placeholder="名称" name="goodsName" autocomplete="off" class="layui-input">
+                                            <input type="text" placeholder="商品名称" name="goodsName" autocomplete="off" class="layui-input">
                                         </div>
                                     </div>
                                 </div>
@@ -27,7 +28,7 @@
                             </div>
                         </div>
                     </form>
-                    <table lay-filter="userTable" lay-data="{id: 'userTable'}"></table>
+                    <table lay-filter="goodsListTable" lay-data="{id: 'goodsListTable'}"></table>
                     <style type="text/css">
                         .layui-table-cell{
                             text-align:center;
@@ -38,6 +39,10 @@
                         }
                         .layui-table img{
                             max-width:100px
+                        }
+                        ::-webkit-scrollbar {
+                            height: 20px !important;
+                            background-color: #f4f4f4;
                         }
                     </style>
                 </div>
@@ -60,6 +65,13 @@
     <input type="checkbox" value={{d.id}} lay-text="上架|下架" lay-skin="switch" lay-filter="upOrDownSwitch">
     {{# } }}
 </script>
+<script type="text/html" id="isHotSwitch">
+    {{# if(d.isHot === 1) { }}
+    <input type="checkbox" value={{d.id}} lay-text="是|否" checked lay-skin="switch" lay-filter="isHotSwitch">
+    {{# } else { }}
+    <input type="checkbox" value={{d.id}} lay-text="是|否" lay-skin="switch" lay-filter="isHotSwitch">
+    {{# } }}
+</script>
 <script type="text/html" id="isSkuFormat">
     {{# if(d.isSku === 1) { }}
         <span>是</span>
@@ -68,7 +80,7 @@
     {{# } }}
 </script>
 <script type="text/html" id="goodsTypeFormat">
-    {{# if(d.isNormal === 1) { }}
+    {{# if(d.isNormal == 1) { }}
         <span>普通商品</span>
     {{# } else { }}
         <span>套餐</span>
@@ -92,16 +104,18 @@
             $reset = $view.find('#reset'),
             $searchForm = $view.find('form'),
             $add = $view.find('#add'),
-            sortObject = {field: 'phone', type: null},
+            sortObject = {field: 'isSale', type: 'asc'},
             tableIns;
 
         form.render();
-
+        let currPageGoods = 1;//首先默认值为1,防止出错
+        //获取当前页
+        currPageGoods = $view.find(".layui-laypage-em").next().html();
         // 表格初始化
         initTable();
 
         // 初始化表格操作栏各个按钮功能
-        table.on('tool(userTable)', function (obj) {
+        table.on('tool(goodsListTable)', function (obj) {
             var data = obj.data,
                 layEvent = obj.event;
             if (layEvent === 'downGoods') {
@@ -170,18 +184,31 @@
                 $query.click();
             });
         }
+        function goodsHot(id) {
+            febs.get(ctx + 'admin/goods/goodsHot/' + id, null, function () {
+                febs.alert.success('设置成功');
+                $query.click();
+            });
+        }
+        function goodsNotHot(id) {
+            febs.get(ctx + 'admin/goods/goodsNotHot/' + id, null, function () {
+                febs.alert.success('设置成功');
+                $query.click();
+            });
+        }
 
         // 查询按钮
         $query.on('click', function () {
             var params = $.extend(getQueryParams(), {field: sortObject.field, order: sortObject.type});
-            tableIns.reload({where: params, page: {curr: 1}});
+            // params.pageNum = $view.find(".layui-laypage-em").next().html();
+            tableIns.reload({where: params, page: {curr: currPageGoods}});
         });
 
         // 刷新按钮
         $reset.on('click', function () {
             $searchForm[0].reset();
             sortObject.type = 'null';
-            tableIns.reload({where: getQueryParams(), page: {curr: 1}, initSort: sortObject});
+            tableIns.reload({where: getQueryParams(), page: {curr: currPageGoods}, initSort: sortObject});
         });
 
         $add.on('click', function () {
@@ -200,23 +227,24 @@
         function initTable() {
             tableIns = febs.table.init({
                 elem: $view.find('table'),
-                id: 'userTable',
+                id: 'goodsListTable',
                 url: ctx + 'admin/goods/goodsList?goodsType=1',
                 cols: [[
-                    {field: 'goodsNo', title: '商品编号', minWidth: 150,align:'left'},
-                    {field: 'goodsName', title: '商品名称', minWidth: 150,align:'left'},
+                    {field: 'goodsNo', title: '商品编号', minWidth: 100,align:'left'},
+                    {field: 'goodsName', title: '商品名称', minWidth: 140,align:'left'},
                     {field: 'thumb', title: '缩略图',
                         templet: function (d) {
                             return '<a lay-event="seeImgThumb"><img id="seeImgThumb'+d.id+'" src="'+d.thumb+'" alt=""></a>';
                         }, minWidth: 150,align:'center'},
-                    {field: 'categaryName', title: '分类', minWidth: 150,align:'left'},
-                    {field: 'isSale', title: '是否上架', templet: '#upOrDownSwitch', minWidth: 130,align:'center'},
-                    {templet:"#goodsTypeFormat",  title: '商品类型', minWidth: 150,align:'left'},
-                    {templet:"#isSkuFormat", title: '是否多规格', minWidth: 150,align:'left'},
-                    {field: 'presentPrice', title: '现价', minWidth: 150,align:'left'},
-                    {field: 'originalPrice', title: '原价', minWidth: 150,align:'left'},
-                    {field: 'stock', title: '商品库存', minWidth: 150,align:'left'},
-                    {field: 'skuVolume', title: '商品销量', minWidth: 150,align:'left'},
+                    {field: 'categaryName', title: '分类', minWidth: 140,align:'left'},
+                    {field: 'isSale', title: '是否上架', templet: '#upOrDownSwitch', minWidth: 100,align:'center'},
+                    {field: 'isHot', title: '是否主推', templet: '#isHotSwitch', minWidth: 100,align:'center'},
+                    {templet:"#goodsTypeFormat",  title: '商品类型', minWidth: 140,align:'left'},
+                    {templet:"#isSkuFormat", title: '是否多规格', minWidth: 100,align:'left'},
+                    {field: 'presentPrice', title: '现价', minWidth: 100,align:'left'},
+                    {field: 'originalPrice', title: '原价', minWidth: 100,align:'left'},
+                    {field: 'stock', title: '商品库存', minWidth: 100,align:'left'},
+                    {field: 'skuVolume', title: '商品销量', minWidth: 100,align:'left'},
                     {title: '操作',
                         templet: function (d) {
                             if (d.isSale === 1) {
@@ -243,6 +271,14 @@
             }
         })
 
+        form.on('switch(isHotSwitch)', function (data) {
+            if (data.elem.checked) {
+                goodsHot(data.value);
+            } else {
+                goodsNotHot(data.value);
+            }
+        })
+
         // 获取查询参数
         function getQueryParams() {
             return {
--
Gitblit v1.9.1