mirror of
http://git.coreshop.cn/jianweie/coreshoppro.git
synced 2025-12-06 17:43:26 +08:00
### 0.6.0 专业版(大版本升级,破坏性升级,请酌情处理):
【新增】弃用现在sku前端,启用全新sku组件,更加灵活,体验更好。 【新增】新增通过商品序列获取sku全新列表功能。 【新增】仓储层底层增加二级缓存功能,后面将逐步完善底层缓存中心模块。 【新增】0元购,积分兑换模式下,也去计算用户是否科技升级。 【新增】数据及业务仓储增加二级缓存功能。curd可自主控制是否缓存和清除。 【新增】订单导出excel数据增加商品名称+货品sku组合展示的方式。 【新增】自定义交易组件增加【获取商家信息】【更新商家信息】两个接口处理。 【新增】增加公告列表及公告详情页面,首页组件公告点击跳转列表展示。 【新增】个人中心增加【公告中心】入口。 【新增】后台余额变动增加说明录入。 【调整】将前端能进行分包的文件夹都进行分包,减少主包占用,方便进行二开。 【调整】因ckeditor5存在图片不可设置宽度,上传不支持mp4,排版不畅等情况,降级使用ckeditor4版本。 【修复】修复0.5.5版本售后积分返还机制积分模式判断异常的问题。 【修复】修复使用积分全额抵扣,或其他优惠政策导致的0元购,未进行短信提醒及小票打印机未打印的问题。 【修复】修复更换ckeditor4编辑器后接龙添加编辑调用失败的问题。 【修复】修复积分全额抵扣,金额0元购的情况下,进行售后执行完毕,订单未完结的情况。 【优化】去除分销申请面板按钮无用并失效报错的customStyle属性。 【优化】优化部分方法中使用手写字符串的遗留问题,统一采用enum方式。 【优化】优化前端及接口部分命名错误的问题。错将skill误写成seckill。 【优化】去除uniapp端多个客服代码。 【优化】商品详情底部完善购物车数量显示的问题。 【优化】优化团购列表,拼团列表,秒杀页面页面样式布局差异问题。 【优化】调整支付结果界面样式效果,仿微信支付结果界面。更加清晰明朗。 【优化】优化售后提交页面json计算,开放当用户下单后但未发货情况下,可以申请直接售后的操作需求。 【优化】后台商家手机号码支持设置多个,使用小写逗号分隔,方便多个商家管理员接收下单提醒。 【优化】后台售后单审核,调整售后商品为必选项。
This commit is contained in:
@@ -20,7 +20,6 @@ using CoreCms.Net.IRepository.UnitOfWork;
|
||||
using CoreCms.Net.Model.Entities;
|
||||
using CoreCms.Net.Model.Entities.Expression;
|
||||
using CoreCms.Net.Model.ViewModels.Basics;
|
||||
using CoreCms.Net.Model.ViewModels.UI;
|
||||
using CoreCms.Net.Model.ViewModels.DTO;
|
||||
using CoreCms.Net.Utility.Helper;
|
||||
using Microsoft.AspNetCore.Http;
|
||||
@@ -42,9 +41,9 @@ namespace CoreCms.Net.Repository
|
||||
}
|
||||
|
||||
|
||||
#region 查询团购秒杀下单数量
|
||||
#region 查询团购秒杀下单数量(获取货品的秒杀团购数据)
|
||||
/// <summary>
|
||||
/// 查询团购秒杀下单数量
|
||||
/// 查询团购秒杀下单数量(获取货品的秒杀团购数据)
|
||||
/// </summary>
|
||||
/// <param name="productId"></param>
|
||||
/// <param name="userId"></param>
|
||||
@@ -56,8 +55,7 @@ namespace CoreCms.Net.Repository
|
||||
{
|
||||
var dto = new FindLimitOrderDto();
|
||||
|
||||
var statusArr = new int[]{(int)GlobalEnumVars.OrderStatus.Normal,
|
||||
(int)GlobalEnumVars.OrderStatus.Complete};
|
||||
var statusArr = new int[] { (int)GlobalEnumVars.OrderStatus.Normal, (int)GlobalEnumVars.OrderStatus.Complete };
|
||||
|
||||
var payStatusArr = new int[] { (int)GlobalEnumVars.OrderPayStatus.No, (int)GlobalEnumVars.OrderPayStatus.Yes, (int)GlobalEnumVars.OrderPayStatus.PartialYes };
|
||||
var shipStatusArr = new int[] { (int)GlobalEnumVars.OrderShipStatus.No, (int)GlobalEnumVars.OrderShipStatus.Yes, (int)GlobalEnumVars.OrderShipStatus.PartialYes };
|
||||
@@ -78,6 +76,7 @@ namespace CoreCms.Net.Repository
|
||||
queryable.In((orderItem, orderModel) => orderModel.payStatus, payStatusArr);
|
||||
queryable.In((orderItem, orderModel) => orderModel.shipStatus, shipStatusArr);
|
||||
|
||||
|
||||
//订单类型
|
||||
if (orderType > 0)
|
||||
{
|
||||
@@ -96,6 +95,62 @@ namespace CoreCms.Net.Repository
|
||||
|
||||
#endregion
|
||||
|
||||
|
||||
#region 查询团购秒杀下单数量(获取商品序号的秒杀团购数据)
|
||||
/// <summary>
|
||||
/// 查询团购秒杀下单数量(获取商品序号的秒杀团购数据)
|
||||
/// </summary>
|
||||
/// <param name="goodId"></param>
|
||||
/// <param name="userId"></param>
|
||||
/// <param name="startTime"></param>
|
||||
/// <param name="endTime"></param>
|
||||
/// <param name="orderType"></param>
|
||||
/// <returns></returns>
|
||||
public FindLimitOrderDto FindLimitOrderByGoodId(int goodId, int userId, DateTime? startTime, DateTime? endTime, int orderType = 0)
|
||||
{
|
||||
var dto = new FindLimitOrderDto();
|
||||
|
||||
var statusArr = new int[] { (int)GlobalEnumVars.OrderStatus.Normal, (int)GlobalEnumVars.OrderStatus.Complete };
|
||||
|
||||
var payStatusArr = new int[] { (int)GlobalEnumVars.OrderPayStatus.No, (int)GlobalEnumVars.OrderPayStatus.Yes, (int)GlobalEnumVars.OrderPayStatus.PartialYes };
|
||||
var shipStatusArr = new int[] { (int)GlobalEnumVars.OrderShipStatus.No, (int)GlobalEnumVars.OrderShipStatus.Yes, (int)GlobalEnumVars.OrderShipStatus.PartialYes };
|
||||
|
||||
|
||||
var queryable = DbClient.Queryable<CoreCmsOrderItem, CoreCmsOrder>((orderItem, orderModel) => new object[]
|
||||
{
|
||||
JoinType.Inner, orderItem.orderId == orderModel.orderId
|
||||
});
|
||||
|
||||
//计算订单总量
|
||||
queryable.WhereIF(goodId > 0, (orderItem, orderModel) => orderItem.goodsId == goodId);
|
||||
queryable.In((orderItem, orderModel) => orderModel.status, statusArr);
|
||||
//在活动时间范围内
|
||||
queryable.WhereIF(startTime != null, (orderItem, orderModel) => orderModel.createTime >= startTime);
|
||||
queryable.WhereIF(endTime != null, (orderItem, orderModel) => orderModel.createTime < endTime);
|
||||
//已退款、已退货、部分退款的、部分退货的排除
|
||||
queryable.In((orderItem, orderModel) => orderModel.payStatus, payStatusArr);
|
||||
queryable.In((orderItem, orderModel) => orderModel.shipStatus, shipStatusArr);
|
||||
|
||||
|
||||
//订单类型
|
||||
if (orderType > 0)
|
||||
{
|
||||
queryable.Where((orderItem, orderModel) => orderModel.orderType == orderType);
|
||||
}
|
||||
|
||||
dto.TotalOrders = queryable.Clone().Select((orderItem, orderModel) => new { nums = orderItem.nums }).MergeTable().With(SqlWith.Null).Sum(p => p.nums);
|
||||
|
||||
if (userId <= 0) return dto;
|
||||
{
|
||||
queryable.Where((orderItem, orderModel) => orderModel.userId == userId);
|
||||
dto.TotalUserOrders = queryable.Clone().Select((orderItem, orderModel) => new { nums = orderItem.nums }).MergeTable().With(SqlWith.Null).Sum(p => p.nums);
|
||||
}
|
||||
return dto;
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
|
||||
#region 根据用户id和商品id获取下了多少订单
|
||||
/// <summary>
|
||||
/// 根据用户id和商品id获取下了多少订单
|
||||
@@ -185,6 +240,7 @@ namespace CoreCms.Net.Repository
|
||||
|
||||
#endregion
|
||||
|
||||
|
||||
#region 重写根据条件查询分页数据-带用户数据
|
||||
/// <summary>
|
||||
/// 重写根据条件查询分页数据-带用户数据
|
||||
@@ -196,7 +252,7 @@ namespace CoreCms.Net.Repository
|
||||
/// <param name="orderByExpression"></param>
|
||||
/// <param name="blUseNoLock">是否使用WITH(NOLOCK)</param>
|
||||
/// <returns></returns>
|
||||
public new async Task<IPageList<CoreCmsOrder>> QueryPageAsync(Expression<Func<CoreCmsOrder, bool>> predicate,
|
||||
public async Task<IPageList<CoreCmsOrder>> QueryPageAsync(Expression<Func<CoreCmsOrder, bool>> predicate,
|
||||
Expression<Func<CoreCmsOrder, object>> orderByExpression, OrderByType orderByType, int pageIndex = 1,
|
||||
int pageSize = 20, bool blUseNoLock = false)
|
||||
{
|
||||
@@ -249,6 +305,7 @@ namespace CoreCms.Net.Repository
|
||||
updateTime = sOrder.updateTime,
|
||||
userNickName = sUser.nickName
|
||||
})
|
||||
.With(SqlWith.NoLock)
|
||||
.MergeTable()
|
||||
.Mapper(sOrder => sOrder.aftersalesItem, sOrder => sOrder.aftersalesItem.First().orderId)
|
||||
.Mapper(sOrder => sOrder.items, sOrder => sOrder.items.First().orderId)
|
||||
|
||||
Reference in New Issue
Block a user