From a0bf7c7be9e52bf179db59117fc3660c24604a96 Mon Sep 17 00:00:00 2001 From: KKSU <15274802129@163.com> Date: Wed, 08 Jan 2025 11:05:45 +0800 Subject: [PATCH] feat(mall): 新增活动管理功能 --- src/main/resources/mapper/modules/MallGoodsMapper.xml | 11 - src/main/resources/templates/index.html | 7 + src/main/java/cc/mrbird/febs/mall/service/impl/ActivityServiceImpl.java | 95 ++++++++++++++---- src/main/java/cc/mrbird/febs/mall/vo/AdminMallActivityListVo.java | 13 ++ src/main/resources/templates/febs/views/modules/activity/list.html | 48 ++------- src/main/resources/templates/febs/views/modules/activity/add.html | 2 src/main/java/cc/mrbird/febs/mall/controller/AdminActivityController.java | 28 +++++ src/main/java/cc/mrbird/febs/mall/dto/MallGoodsQueryDto.java | 7 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallGoodsCategoryServiceImpl.java | 18 +++ src/main/java/cc/mrbird/febs/mall/service/IActivityService.java | 11 ++ src/main/resources/templates/febs/views/modules/banner/platformBannerAdd.html | 52 ++++++--- 11 files changed, 199 insertions(+), 93 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/mall/controller/AdminActivityController.java b/src/main/java/cc/mrbird/febs/mall/controller/AdminActivityController.java index 8de371f..2575c9d 100644 --- a/src/main/java/cc/mrbird/febs/mall/controller/AdminActivityController.java +++ b/src/main/java/cc/mrbird/febs/mall/controller/AdminActivityController.java @@ -14,6 +14,7 @@ import org.springframework.web.bind.annotation.*; import javax.validation.Valid; +import javax.validation.constraints.NotNull; import java.util.Map; @Slf4j @@ -38,7 +39,7 @@ @PostMapping("add") @ControllerEndpoint(operation = "新增", exceptionMessage = "新增失败") public FebsResponse addActivity(@RequestBody @Valid AdminActivityAddDto adminActivityAddDto) { - return iActivityService.addActivity(adminActivityAddDto); + return iActivityService.addAdminActivity(adminActivityAddDto); } /** @@ -49,4 +50,29 @@ public FebsResponse discountUpdate(@RequestBody @Valid AdminDiscountVO adminDiscountVO) { return iActivityService.discountUpdate(adminDiscountVO); } + + + @GetMapping(value = "/activityList") + public FebsResponse activityList() { + return new FebsResponse().success().data(iActivityService.getAdminActivityList()); + } + + /** + * 活动-开启 + */ + @GetMapping("changeState/{id}/{state}") + @ControllerEndpoint(operation = "活动-开启", exceptionMessage = "操作失败") + public FebsResponse changeState(@NotNull(message = "{required}") @PathVariable Long id + ,@NotNull(message = "{required}") @PathVariable Integer state) { + return iActivityService.changeAdminState(id,state); + } + + /** + * 活动-删除 + */ + @GetMapping("delActivity/{id}") + @ControllerEndpoint(operation = "活动-删除", exceptionMessage = "删除失败") + public FebsResponse delActivity(@NotNull(message = "{required}") @PathVariable Long id) { + return iActivityService.delAdminActivity(id); + } } diff --git a/src/main/java/cc/mrbird/febs/mall/dto/MallGoodsQueryDto.java b/src/main/java/cc/mrbird/febs/mall/dto/MallGoodsQueryDto.java index dde8bdf..14f9515 100644 --- a/src/main/java/cc/mrbird/febs/mall/dto/MallGoodsQueryDto.java +++ b/src/main/java/cc/mrbird/febs/mall/dto/MallGoodsQueryDto.java @@ -4,8 +4,6 @@ import io.swagger.annotations.ApiModelProperty; import lombok.Data; -import javax.validation.constraints.NotNull; - /** * @author wzy * @date 2021-09-17 @@ -35,9 +33,12 @@ @ApiModelProperty(value = "是否热卖", example = "1是2否") private Integer isHot; - @ApiModelProperty(value = "是否套餐 1-普通商品 2-套餐", example = "2") + @ApiModelProperty(value = "是否套餐 1-普通商品 2-积分商品 3-活动商品 ", example = "2") private Integer isNormal; + @ApiModelProperty(value = "是否套餐 1-普通商品 2-积分商品 3-活动商品 ", example = "2") + private Long activityId; + @ApiModelProperty(value = "1-付费商品 2-积分商品") private Integer goodsType; diff --git a/src/main/java/cc/mrbird/febs/mall/service/IActivityService.java b/src/main/java/cc/mrbird/febs/mall/service/IActivityService.java index e4a0bc6..13cc50d 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/IActivityService.java +++ b/src/main/java/cc/mrbird/febs/mall/service/IActivityService.java @@ -5,14 +5,23 @@ import cc.mrbird.febs.mall.entity.MallActivity; import cc.mrbird.febs.mall.vo.AdminActivityAddDto; import cc.mrbird.febs.mall.vo.AdminDiscountVO; +import cc.mrbird.febs.mall.vo.AdminMallActivityListVo; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.service.IService; + +import java.util.List; public interface IActivityService extends IService<MallActivity> { IPage<MallActivity> getAdminListInPage(MallActivity mallActivity, QueryRequest request); - FebsResponse addActivity(AdminActivityAddDto adminActivityAddDto); + FebsResponse addAdminActivity(AdminActivityAddDto adminActivityAddDto); FebsResponse discountUpdate(AdminDiscountVO adminDiscountVO); + + List<AdminMallActivityListVo> getAdminActivityList(); + + FebsResponse changeAdminState(Long id, Integer state); + + FebsResponse delAdminActivity(Long id); } diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ActivityServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ActivityServiceImpl.java index 53b8341..57dbb83 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/ActivityServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ActivityServiceImpl.java @@ -1,5 +1,6 @@ package cc.mrbird.febs.mall.service.impl; +import cc.mrbird.febs.common.configure.FebsConfigure; import cc.mrbird.febs.common.entity.FebsResponse; import cc.mrbird.febs.common.entity.QueryRequest; import cc.mrbird.febs.common.enumerates.ActivityTypeEnum; @@ -11,6 +12,7 @@ import cc.mrbird.febs.mall.service.IActivityService; import cc.mrbird.febs.mall.vo.AdminActivityAddDto; import cc.mrbird.febs.mall.vo.AdminDiscountVO; +import cc.mrbird.febs.mall.vo.AdminMallActivityListVo; import cn.hutool.core.collection.CollUtil; import cn.hutool.core.util.ObjectUtil; import cn.hutool.core.util.StrUtil; @@ -25,7 +27,9 @@ import java.math.BigDecimal; import java.math.RoundingMode; +import java.util.ArrayList; import java.util.List; +import java.util.concurrent.CompletableFuture; import java.util.stream.Collectors; @Slf4j @@ -38,6 +42,7 @@ private final MallGoodsMapper mallGoodsMapper; private final MallGoodsSkuMapper mallGoodsSkuMapper; private final MallGoodsStyleMapper mallGoodsStyleMapper; + private final FebsConfigure febsConfigure; @Override public IPage<MallActivity> getAdminListInPage(MallActivity mallActivity, QueryRequest request) { Page<MallActivity> page = new Page<>(request.getPageNum(), request.getPageSize()); @@ -55,7 +60,7 @@ } @Override - public FebsResponse addActivity(AdminActivityAddDto adminActivityAddDto) { + public FebsResponse addAdminActivity(AdminActivityAddDto adminActivityAddDto) { MallActivity mallActivity = new MallActivity(); mallActivity.setName(adminActivityAddDto.getName()); @@ -90,6 +95,7 @@ } private void addDiscountGoods(Long activityId,BigDecimal discountSize, List<Long> goodsIds){ + MallActivity mallActivity = this.baseMapper.selectById(activityId); //将对应选中的商品按照这个折扣力度重新计算一遍 List<MallGoods> mallGoods = mallGoodsMapper.selectList( new LambdaQueryWrapper<MallGoods>() @@ -97,42 +103,49 @@ .in(MallGoods::getId, goodsIds) ); if(CollUtil.isNotEmpty(mallGoods)){ + List<CompletableFuture<Void>> futures = new ArrayList<>(); //复制对应的商品的规则 for(MallGoods mallGoodsItem:mallGoods){ - Long goodsId = mallGoodsItem.getId(); - //新增活动商品 - Long goodsIdNew = addGoodsEntity(activityId, discountSize, mallGoodsItem); + CompletableFuture<Void> uCompletableFuture = CompletableFuture.runAsync(() -> { + Long goodsId = mallGoodsItem.getId(); + //新增活动商品 + Long goodsIdNew = addGoodsEntity(mallActivity, discountSize, mallGoodsItem); - List<MallGoodsStyle> mallGoodsStyles = mallGoodsStyleMapper.selectList( - new LambdaQueryWrapper<MallGoodsStyle>() - .eq(MallGoodsStyle::getGoodsId, goodsId) - ); + List<MallGoodsStyle> mallGoodsStyles = mallGoodsStyleMapper.selectList( + new LambdaQueryWrapper<MallGoodsStyle>() + .eq(MallGoodsStyle::getGoodsId, goodsId) + ); - if(CollUtil.isNotEmpty(mallGoodsStyles)){ - for(MallGoodsStyle mallGoodsStyleItem:mallGoodsStyles){ - Long styleItemId = mallGoodsStyleItem.getId(); + if(CollUtil.isNotEmpty(mallGoodsStyles)){ + for(MallGoodsStyle mallGoodsStyleItem:mallGoodsStyles){ + Long styleItemId = mallGoodsStyleItem.getId(); - Long styleItemIdNew = addGoodsStyleEntity(goodsIdNew, mallGoodsStyleItem); - List<MallGoodsSku> mallGoodsSkus = mallGoodsSkuMapper.selectList( - new LambdaQueryWrapper<MallGoodsSku>() - .eq(MallGoodsSku::getStyleId, styleItemId) - .eq(MallGoodsSku::getGoodsId, goodsId) - ); - if(CollUtil.isNotEmpty(mallGoodsSkus)){ - for(MallGoodsSku mallGoodsSkuItem:mallGoodsSkus){ - addGoodsSkuEntity(goodsIdNew,styleItemIdNew,discountSize,mallGoodsSkuItem); + Long styleItemIdNew = addGoodsStyleEntity(goodsIdNew, mallGoodsStyleItem); + List<MallGoodsSku> mallGoodsSkus = mallGoodsSkuMapper.selectList( + new LambdaQueryWrapper<MallGoodsSku>() + .eq(MallGoodsSku::getStyleId, styleItemId) + .eq(MallGoodsSku::getGoodsId, goodsId) + ); + if(CollUtil.isNotEmpty(mallGoodsSkus)){ + for(MallGoodsSku mallGoodsSkuItem:mallGoodsSkus){ + addGoodsSkuEntity(goodsIdNew,styleItemIdNew,discountSize,mallGoodsSkuItem); + } } } } - } + },febsConfigure.asyncThreadPoolTaskExecutor()); + futures.add(uCompletableFuture); } + // 等待所有任务完成 + CompletableFuture<Void> allOf = CompletableFuture.allOf(futures.toArray(new CompletableFuture[0])); + allOf.join(); } } - private Long addGoodsEntity(Long activityId,BigDecimal discountSize,MallGoods mallGoodsItem){ - MallActivity mallActivity = this.baseMapper.selectById(activityId); + private Long addGoodsEntity(MallActivity mallActivity,BigDecimal discountSize,MallGoods mallGoodsItem){ mallGoodsItem.setIsNormal(GoodsTypeEnum.HUO_DONG.getValue()); - mallGoodsItem.setGoodsName(mallActivity.getName()+mallGoodsItem.getGoodsName()); + mallGoodsItem.setGoodsName(mallActivity.getName()+"-"+(StrUtil.isEmpty(mallGoodsItem.getGoodsName()) ? "":mallGoodsItem.getGoodsName())); + mallGoodsItem.setGoodsNo(mallGoodsItem.getGoodsNo()+"-"+mallActivity.getCode()); mallGoodsItem.setActivityId(mallActivity.getId()); BigDecimal presentPrice = new BigDecimal(mallGoodsItem.getPresentPrice()).multiply(discountSize).setScale(2, RoundingMode.DOWN); mallGoodsItem.setPresentPrice(presentPrice.toString()); @@ -179,4 +192,38 @@ public FebsResponse discountUpdate(AdminDiscountVO adminDiscountVO) { return null; } + + @Override + public List<AdminMallActivityListVo> getAdminActivityList() { + List<AdminMallActivityListVo> mallActivityList = new ArrayList<>(); + + List<MallActivity> mallActivities = this.baseMapper.selectList( + new LambdaQueryWrapper<MallActivity>() + .select(MallActivity::getId, MallActivity::getName) + .eq(MallActivity::getState, YesOrNoOrIngEnum.YES.getValue()) + ); + if(CollUtil.isNotEmpty(mallActivities)){ + for (MallActivity mallActivity : mallActivities) { + AdminMallActivityListVo adminMallActivityListVo = new AdminMallActivityListVo(); + adminMallActivityListVo.setId(mallActivity.getId()); + adminMallActivityListVo.setName(mallActivity.getName()); + mallActivityList.add(adminMallActivityListVo); + } + } + return mallActivityList; + } + + @Override + public FebsResponse changeAdminState(Long id, Integer state) { + MallActivity mallActivity = this.baseMapper.selectById(id); + mallActivity.setState(state); + this.baseMapper.updateById(mallActivity); + return new FebsResponse().success().message("操作成功"); + } + + @Override + public FebsResponse delAdminActivity(Long id) { + this.baseMapper.deleteById(id); + return new FebsResponse().success().message("操作成功"); + } } diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallGoodsCategoryServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallGoodsCategoryServiceImpl.java index 8c596f9..3cf8985 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallGoodsCategoryServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallGoodsCategoryServiceImpl.java @@ -1,9 +1,11 @@ package cc.mrbird.febs.mall.service.impl; import cc.mrbird.febs.mall.entity.MallAddressWorld; +import cc.mrbird.febs.mall.entity.MallGoods; import cc.mrbird.febs.mall.entity.MallGoodsCategory; import cc.mrbird.febs.mall.mapper.MallAddressWorldMapper; import cc.mrbird.febs.mall.mapper.MallGoodsCategoryMapper; +import cc.mrbird.febs.mall.mapper.MallGoodsMapper; import cc.mrbird.febs.mall.service.IApiMallGoodsCategoryService; import cc.mrbird.febs.mall.vo.AdminWorldAddressVo; import cc.mrbird.febs.mall.vo.MallGoodsCategoryVo; @@ -27,10 +29,24 @@ public class ApiMallGoodsCategoryServiceImpl extends ServiceImpl<MallGoodsCategoryMapper, MallGoodsCategory> implements IApiMallGoodsCategoryService { private final MallAddressWorldMapper mallAddressWorldMapper; + private final MallGoodsMapper mallGoodsMapper; @Override public List<MallGoodsCategoryVo> findAllCategoryList() { - return this.baseMapper.selectAllCategoryList(); + List<MallGoodsCategoryVo> mallGoodsCategoryVos = this.baseMapper.selectAllCategoryList(); + if(CollUtil.isNotEmpty(mallGoodsCategoryVos)){ + mallGoodsCategoryVos.forEach(item -> { + Long id = item.getId(); + List<MallGoods> mallGoods = mallGoodsMapper.selectList( + new LambdaQueryWrapper<MallGoods>() + .select(MallGoods::getId) + .eq(MallGoods::getCategoryId, id)); + if(CollUtil.isNotEmpty(mallGoods)){ + mallGoodsCategoryVos.remove(item); + } + }); + } + return mallGoodsCategoryVos; } @Override diff --git a/src/main/java/cc/mrbird/febs/mall/vo/AdminMallActivityListVo.java b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallActivityListVo.java new file mode 100644 index 0000000..f727ff8 --- /dev/null +++ b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallActivityListVo.java @@ -0,0 +1,13 @@ +package cc.mrbird.febs.mall.vo; + +import io.swagger.annotations.ApiModel; +import lombok.Data; + +@Data +@ApiModel(value = "AdminMallActivityListVo", description = "信息返回类") +public class AdminMallActivityListVo { + + private Long id; + + private String name; +} diff --git a/src/main/resources/mapper/modules/MallGoodsMapper.xml b/src/main/resources/mapper/modules/MallGoodsMapper.xml index 69120e4..f335a63 100644 --- a/src/main/resources/mapper/modules/MallGoodsMapper.xml +++ b/src/main/resources/mapper/modules/MallGoodsMapper.xml @@ -86,20 +86,12 @@ select a.id, a.goods_name, - a.goods_introdution goodsIntroduction, a.thumb, a.unit, a.original_price, a.present_price, - a.level_one_price, - a.level_two_price, - a.level_three_price, a.score, a.is_hot, - a.carriage_type, - a.carriage_amount, - a.carriage_rule_id, - a.goods_weight, a.order_number, <if test="record.memberId != null"> case when collection.id is null then 2 else 1 end hasCollect, @@ -123,6 +115,9 @@ <if test="record.isNormal != null and record.isNormal != ''"> and a.is_normal = #{record.isNormal} </if> + <if test="record.isNormal == 3"> + and a.activity_id = #{record.activityId} + </if> <if test="record.goodsType != null and record.goodsType != '' and record.goodsType == 1"> and a.goods_type = #{record.goodsType} and a.present_price != 0 </if> diff --git a/src/main/resources/templates/febs/views/modules/activity/add.html b/src/main/resources/templates/febs/views/modules/activity/add.html index 7652ee0..ec4ce82 100644 --- a/src/main/resources/templates/febs/views/modules/activity/add.html +++ b/src/main/resources/templates/febs/views/modules/activity/add.html @@ -213,7 +213,7 @@ iconfont: { parent: 'hidden', }, - // radio: true, + radio: true, clickClose: true, tree: { show: true, diff --git a/src/main/resources/templates/febs/views/modules/activity/list.html b/src/main/resources/templates/febs/views/modules/activity/list.html index 761988c..3dbd263 100644 --- a/src/main/resources/templates/febs/views/modules/activity/list.html +++ b/src/main/resources/templates/febs/views/modules/activity/list.html @@ -28,18 +28,12 @@ </div> </form> <table lay-filter="activityTable" lay-data="{id: 'activityTable'}"></table> - <style type="text/css"> - .layui-table-cell{ - text-align:center; - height: auto; - white-space: nowrap; /*文本不会换行,在同一行显示*/ - overflow: hidden; /*超出隐藏*/ - text-overflow: ellipsis; /*省略号显示*/ - } - .layui-table img{ - max-width:100px - } - </style> +<!-- <style type="text/css">--> +<!-- ::-webkit-scrollbar {--> +<!-- height: 20px !important;--> +<!-- background-color: #f4f4f4;--> +<!-- }--> +<!-- </style>--> </div> </div> </div> @@ -97,16 +91,6 @@ table.on('tool(activityTable)', function (obj) { var data = obj.data, layEvent = obj.event; - if (layEvent === 'closeAct') { - febs.modal.confirm('关闭', '确认关闭该活动?', function () { - closeAct(data.id); - }); - } - if (layEvent === 'startAct') { - febs.modal.confirm('开启', '确认开启该活动?', function () { - startAct(data.id); - }); - } if (layEvent === 'delAct') { febs.modal.confirm('删除', '确认删除该活动?', function () { delAct(data.id); @@ -140,21 +124,15 @@ }); } }); - function closeAct(id) { - febs.get(ctx + 'admin/act/closeMallAct/' + id, null, function () { - febs.alert.success('关闭成功'); - $query.click(); - }); - } - function startAct(id) { - febs.get(ctx + 'admin/act/startMallAct/' + id, null, function () { - febs.alert.success('开启成功'); + function changeState(id,state) { + febs.get(ctx + 'admin/activity/changeState/' + id+'/' + state, null, function (data) { + febs.alert.success(data.message); $query.click(); }); } function delAct(id) { - febs.get(ctx + 'admin/act/delMallAct/' + id, null, function () { - febs.alert.success('删除成功'); + febs.get(ctx + 'admin/activity/delActivity/' + id, null, function (data) { + febs.alert.success(data.message); $query.click(); }); } @@ -225,9 +203,9 @@ form.on('switch(activityStateSwitch)', function (data) { if (data.elem.checked) { - startAct(data.value); + changeState(data.value,1); } else { - closeAct(data.value); + changeState(data.value,0); } }) diff --git a/src/main/resources/templates/febs/views/modules/banner/platformBannerAdd.html b/src/main/resources/templates/febs/views/modules/banner/platformBannerAdd.html index 5928f1c..975d129 100644 --- a/src/main/resources/templates/febs/views/modules/banner/platformBannerAdd.html +++ b/src/main/resources/templates/febs/views/modules/banner/platformBannerAdd.html @@ -50,13 +50,6 @@ autocomplete="off" class="layui-input" readonly> </div> </div> -<!-- <div class="layui-form-item">--> -<!-- <label class="layui-form-label febs-form-item-require">联系方式:</label>--> -<!-- <div class="layui-input-block">--> -<!-- <input type="text" name="sort" minlength="4" maxlength="10" --> -<!-- lay-verify="range|sort" autocomplete="off" class="layui-input" >--> -<!-- </div>--> -<!-- </div>--> <div class="layui-form-item"> <label class="layui-form-label febs-form-item-require">是否置顶:</label> <div class="layui-input-block"> @@ -64,13 +57,6 @@ <input type="radio" name="isTop" value="2" title="否"> </div> </div> -<!-- <div class="layui-form-item">--> -<!-- <label class="layui-form-label febs-form-item-require">显示端口:</label>--> -<!-- <div class="layui-input-block">--> -<!-- <input type="radio" name="showPort" value="1" title="pc" checked="">--> -<!-- <input type="radio" name="showPort" value="2" title="手机">--> -<!-- </div>--> -<!-- </div>--> <div class="layui-form-item"> <label class="layui-form-label febs-form-item-require">是否可跳转:</label> <div class="layui-input-block"> @@ -78,14 +64,14 @@ <input type="radio" name="isJump" value="2" title="否"> </div> </div> + <div class="layui-form-item"> - <label class="layui-form-label">跳转链接:</label> + <label class="layui-form-label">关联活动:</label> <div class="layui-input-block"> - <input type="text" name="jumpUrl" - autocomplete="off" class="layui-input" > + <div id="jumpUrl-list"></div> </div> - <div class="layui-form-mid layui-word-aux">图片需要跳转到商品详情,请填写商品编号。</div> </div> + <div class="layui-form-item"> <label class="layui-form-label febs-form-item-require">跳转外部或内部:</label> <div class="layui-input-block"> @@ -100,7 +86,7 @@ </div> <script data-th-inline="javascript"> - layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree','upload'], function () { + layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree','upload', 'xmSelect'], function () { var $ = layui.$, febs = layui.febs, layer = layui.layer, @@ -132,9 +118,37 @@ form.render(); + var activityList = xmSelect.render({ + el: '#jumpUrl-list', + language: 'zh', + prop : { + value : 'id', + children : 'child' + }, + iconfont: { + parent: 'hidden', + }, + radio: true,//单选按钮。如何想要多选直接注释掉此行代码 + clickClose: true, + tree: { + show: true, + //非严格模式 + strict: false, + }, + data: [] + }) + + febs.get(ctx + 'admin/activity/activityList', null, function(res) { + activityList.update({ + data : res.data, + autoRow: true, + }); + }) + formSelects.render(); form.on('submit(banner-add-form-submit)', function (data) { + data.field.jumpUrl = activityList.getValue('valueStr'); febs.post(ctx + 'admin/banner/platformBannerAdds', data.field, function () { layer.closeAll(); febs.alert.success('新增成功'); diff --git a/src/main/resources/templates/index.html b/src/main/resources/templates/index.html index 5ffad6c..e3e3270 100644 --- a/src/main/resources/templates/index.html +++ b/src/main/resources/templates/index.html @@ -25,6 +25,13 @@ <!-- <script src="https://unpkg.com/@wangeditor/editor@latest/dist/index.js"></script>--> <script src="http://gosspublic.alicdn.com/aliyun-oss-sdk-6.17.0.min.js"></script> <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/wangeditor@latest/dist/wangEditor.min.js" ></script> + + <style type="text/css"> + ::-webkit-scrollbar { + height: 20px !important; + background-color: #f4f4f4; + } + </style> <link rel="icon" th:href="@{febs/images/favicon.ico}" type="image/x-icon"/> </head> <body> -- Gitblit v1.9.1