mirror of
http://git.coreshop.cn/jianweie/coreshoppro.git
synced 2026-02-05 12:09:49 +08:00
【新增】弃用现在sku前端,启用全新sku组件,更加灵活,体验更好。 【新增】新增通过商品序列获取sku全新列表功能。 【新增】仓储层底层增加二级缓存功能,后面将逐步完善底层缓存中心模块。 【新增】0元购,积分兑换模式下,也去计算用户是否科技升级。 【新增】数据及业务仓储增加二级缓存功能。curd可自主控制是否缓存和清除。 【新增】订单导出excel数据增加商品名称+货品sku组合展示的方式。 【新增】自定义交易组件增加【获取商家信息】【更新商家信息】两个接口处理。 【新增】增加公告列表及公告详情页面,首页组件公告点击跳转列表展示。 【新增】个人中心增加【公告中心】入口。 【新增】后台余额变动增加说明录入。 【调整】将前端能进行分包的文件夹都进行分包,减少主包占用,方便进行二开。 【调整】因ckeditor5存在图片不可设置宽度,上传不支持mp4,排版不畅等情况,降级使用ckeditor4版本。 【修复】修复0.5.5版本售后积分返还机制积分模式判断异常的问题。 【修复】修复使用积分全额抵扣,或其他优惠政策导致的0元购,未进行短信提醒及小票打印机未打印的问题。 【修复】修复更换ckeditor4编辑器后接龙添加编辑调用失败的问题。 【修复】修复积分全额抵扣,金额0元购的情况下,进行售后执行完毕,订单未完结的情况。 【优化】去除分销申请面板按钮无用并失效报错的customStyle属性。 【优化】优化部分方法中使用手写字符串的遗留问题,统一采用enum方式。 【优化】优化前端及接口部分命名错误的问题。错将skill误写成seckill。 【优化】去除uniapp端多个客服代码。 【优化】商品详情底部完善购物车数量显示的问题。 【优化】优化团购列表,拼团列表,秒杀页面页面样式布局差异问题。 【优化】调整支付结果界面样式效果,仿微信支付结果界面。更加清晰明朗。 【优化】优化售后提交页面json计算,开放当用户下单后但未发货情况下,可以申请直接售后的操作需求。 【优化】后台商家手机号码支持设置多个,使用小写逗号分隔,方便多个商家管理员接收下单提醒。 【优化】后台售后单审核,调整售后商品为必选项。
573 lines
20 KiB
C#
573 lines
20 KiB
C#
/***********************************************************************
|
|
* Project: CoreCms
|
|
* ProjectName: 核心内容管理系统
|
|
* Web: https://www.corecms.net
|
|
* Author: 大灰灰
|
|
* Email: jianweie@163.com
|
|
* CreateTime: 2021/1/31 21:45:10
|
|
* Description: 暂无
|
|
***********************************************************************/
|
|
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.ComponentModel;
|
|
using System.Linq;
|
|
using System.Linq.Expressions;
|
|
using System.Threading.Tasks;
|
|
using AutoMapper;
|
|
using CoreCms.Net.Auth.HttpContextUser;
|
|
using CoreCms.Net.Configuration;
|
|
using CoreCms.Net.IServices;
|
|
using CoreCms.Net.Model.Entities;
|
|
using CoreCms.Net.Model.Entities.Expression;
|
|
using CoreCms.Net.Model.FromBody;
|
|
using CoreCms.Net.Model.ViewModels.DTO;
|
|
using CoreCms.Net.Model.ViewModels.UI;
|
|
using CoreCms.Net.Utility.Extensions;
|
|
using Microsoft.AspNetCore.Authorization;
|
|
using Microsoft.AspNetCore.Http;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using Newtonsoft.Json;
|
|
using SqlSugar;
|
|
|
|
namespace CoreCms.Net.Web.WebApi.Controllers
|
|
{
|
|
/// <summary>
|
|
/// 商品相关接口处理
|
|
/// </summary>
|
|
[Route("api/[controller]/[action]")]
|
|
[ApiController]
|
|
public class GoodController : ControllerBase
|
|
{
|
|
private IMapper _mapper;
|
|
private readonly IHttpContextUser _user;
|
|
|
|
private ICoreCmsSettingServices _settingServices;
|
|
private ICoreCmsGoodsCategoryServices _goodsCategoryServices;
|
|
private ICoreCmsGoodsServices _goodsServices;
|
|
private ICoreCmsProductsServices _productsServices;
|
|
private ICoreCmsBrandServices _brandServices;
|
|
private ICoreCmsOrderItemServices _orderItemServices;
|
|
private ICoreCmsGoodsCommentServices _goodsCommentServices;
|
|
private ICoreCmsGoodsParamsServices _goodsParamsServices;
|
|
private ICoreCmsGoodsCollectionServices _goodsCollectionServices;
|
|
private ICoreCmsUserServices _userServices;
|
|
|
|
/// <summary>
|
|
/// 构造函数
|
|
/// </summary>
|
|
public GoodController(IMapper mapper
|
|
, IHttpContextUser user
|
|
, ICoreCmsSettingServices settingServices
|
|
, ICoreCmsGoodsCategoryServices goodsCategoryServices
|
|
, ICoreCmsGoodsServices goodsServices
|
|
, ICoreCmsProductsServices productsServices
|
|
, ICoreCmsBrandServices brandServices
|
|
, ICoreCmsOrderItemServices orderItemServices
|
|
, ICoreCmsGoodsCommentServices goodsCommentServices
|
|
, ICoreCmsGoodsParamsServices goodsParamsServices
|
|
, ICoreCmsGoodsCollectionServices goodsCollectionServices
|
|
, ICoreCmsUserServices userServices
|
|
)
|
|
{
|
|
_mapper = mapper;
|
|
_user = user;
|
|
_settingServices = settingServices;
|
|
_goodsCategoryServices = goodsCategoryServices;
|
|
_goodsServices = goodsServices;
|
|
_productsServices = productsServices;
|
|
_brandServices = brandServices;
|
|
_orderItemServices = orderItemServices;
|
|
_goodsCommentServices = goodsCommentServices;
|
|
_goodsParamsServices = goodsParamsServices;
|
|
_goodsCollectionServices = goodsCollectionServices;
|
|
_userServices = userServices;
|
|
|
|
}
|
|
|
|
//公共接口====================================================================================================
|
|
|
|
#region 获取所有商品分类栏目数据
|
|
/// <summary>
|
|
/// 获取所有商品分类栏目数据
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async Task<WebApiCallBack> GetAllCategories()
|
|
{
|
|
var jm = new WebApiCallBack() { status = true };
|
|
|
|
var data = await _goodsCategoryServices.QueryListByClauseAsync(p => p.isShow == true, p => p.sort, OrderByType.Asc, true, true);
|
|
var wxGoodCategoryDto = new List<WxGoodCategoryDto>();
|
|
|
|
var parents = data.Where(p => p.parentId == 0).ToList();
|
|
if (parents.Any())
|
|
{
|
|
parents.ForEach(p =>
|
|
{
|
|
var model = new WxGoodCategoryDto();
|
|
model.id = p.id;
|
|
model.name = p.name;
|
|
model.imageUrl = !string.IsNullOrEmpty(p.imageUrl) ? p.imageUrl : "/static/images/common/empty.png";
|
|
model.sort = p.sort;
|
|
|
|
var childs = data.Where(p => p.parentId == model.id).ToList();
|
|
if (childs.Any())
|
|
{
|
|
var childsList = new List<WxGoodCategoryChild>();
|
|
childs.ForEach(o =>
|
|
{
|
|
childsList.Add(new WxGoodCategoryChild()
|
|
{
|
|
id = o.id,
|
|
imageUrl = !string.IsNullOrEmpty(o.imageUrl) ? o.imageUrl : "/static/images/common/empty.png",
|
|
name = o.name,
|
|
sort = o.sort
|
|
});
|
|
});
|
|
model.child = childsList;
|
|
}
|
|
wxGoodCategoryDto.Add(model);
|
|
});
|
|
}
|
|
jm.status = true;
|
|
jm.data = wxGoodCategoryDto;
|
|
|
|
return jm;
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region 根据查询条件获取分页数据============================================================
|
|
/// <summary>
|
|
/// 根据查询条件获取分页数据
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async Task<WebApiCallBack> GetGoodsPageList([FromBody] FMPageByWhereOrder entity)
|
|
{
|
|
var jm = new WebApiCallBack();
|
|
|
|
var where = PredicateBuilder.True<CoreCmsGoods>();
|
|
where = where.And(p => p.isDel == false);
|
|
where = where.And(p => p.isMarketable == true);
|
|
|
|
var className = string.Empty;
|
|
if (!string.IsNullOrWhiteSpace(entity.where))
|
|
{
|
|
var obj = JsonConvert.DeserializeAnonymousType(entity.where, new
|
|
{
|
|
priceFrom = "",
|
|
priceTo = "",
|
|
catId = "",
|
|
brandId = "",
|
|
labelId = "",
|
|
searchName = "",
|
|
});
|
|
|
|
if (!string.IsNullOrWhiteSpace(obj.priceFrom))
|
|
{
|
|
var priceF = obj.priceFrom.ObjectToDouble(0);
|
|
if (priceF >= 0)
|
|
{
|
|
var f = Convert.ToDecimal(priceF);
|
|
where = where.And(p => p.price >= f);
|
|
}
|
|
}
|
|
if (!string.IsNullOrWhiteSpace(obj.priceTo))
|
|
{
|
|
var priceT = obj.priceTo.ObjectToDouble(0);
|
|
if (priceT > 0)
|
|
{
|
|
var f = Convert.ToDecimal(priceT);
|
|
where = where.And(p => p.price <= f);
|
|
}
|
|
}
|
|
if (!string.IsNullOrWhiteSpace(obj.catId))
|
|
{
|
|
var catId = obj.catId.ObjectToInt(0);
|
|
if (catId > 0)
|
|
{
|
|
var category = await _goodsCategoryServices.QueryByIdAsync(catId, true, true);
|
|
if (category != null)
|
|
{
|
|
className = category.name;
|
|
}
|
|
|
|
var childs = await _goodsCategoryServices.QueryListByClauseAsync(p => p.parentId == catId, p => p.sort, OrderByType.Asc, true, true);
|
|
if (childs.Any())
|
|
{
|
|
var ids = childs.Select(p => p.id).ToList();
|
|
where = where.And(p => ids.Contains(p.goodsCategoryId) || p.goodsCategoryId == catId);
|
|
}
|
|
else
|
|
{
|
|
where = where.And(p => p.goodsCategoryId == catId);
|
|
}
|
|
}
|
|
}
|
|
if (!string.IsNullOrWhiteSpace(obj.brandId))
|
|
{
|
|
var brandId = obj.brandId.ObjectToInt(0);
|
|
if (brandId > 0)
|
|
{
|
|
where = where.And(p => p.brandId == brandId);
|
|
}
|
|
}
|
|
if (!string.IsNullOrWhiteSpace(obj.labelId))
|
|
{
|
|
where = where.And(p => (',' + p.labelIds.Trim(',') + ',').Contains(',' + obj.labelId.Trim(',') + ','));
|
|
}
|
|
if (!string.IsNullOrWhiteSpace(obj.searchName))
|
|
{
|
|
where = where.And(p => p.name.Contains(obj.searchName));
|
|
}
|
|
}
|
|
var orderBy = " isRecommend desc,isHot desc";
|
|
if (!string.IsNullOrWhiteSpace(entity.order))
|
|
{
|
|
orderBy += "," + entity.order;
|
|
}
|
|
//获取数据
|
|
var list = await _goodsServices.QueryPageAsync(where, orderBy, entity.page, entity.limit, false);
|
|
if (list.Any())
|
|
{
|
|
foreach (var goods in list)
|
|
{
|
|
goods.images = !string.IsNullOrEmpty(goods.images) ? goods.images.Split(",")[0] : "/static/images/common/empty.png";
|
|
}
|
|
}
|
|
//获取品牌
|
|
var brands = await _brandServices.QueryListByClauseAsync(p => p.isShow == true, p => p.sort, OrderByType.Desc, true, true);
|
|
|
|
//返回数据
|
|
jm.status = true;
|
|
jm.data = new
|
|
{
|
|
list,
|
|
className,
|
|
entity.page,
|
|
list.TotalCount,
|
|
list.TotalPages,
|
|
entity.limit,
|
|
entity.where,
|
|
entity.order,
|
|
brands
|
|
};
|
|
jm.msg = "数据调用成功!";
|
|
|
|
return jm;
|
|
}
|
|
#endregion
|
|
|
|
#region 获取商品详情======================================================================
|
|
/// <summary>
|
|
/// 获取商品详情
|
|
/// </summary>
|
|
/// <param name="entity"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async Task<WebApiCallBack> GetDetial([FromBody] FMIntId entity)
|
|
{
|
|
var jm = new WebApiCallBack();
|
|
|
|
var model = await _goodsServices.GetGoodsDetail(entity.id, 0, false, "goods", 0, entity.data.ObjectToBool());
|
|
if (model == null)
|
|
{
|
|
jm.msg = "商品获取失败";
|
|
return jm;
|
|
}
|
|
|
|
jm.status = true;
|
|
jm.msg = "获取商品详情成功";
|
|
jm.data = model;
|
|
jm.methodDescription = JsonConvert.SerializeObject(_user);
|
|
|
|
return jm;
|
|
}
|
|
#endregion
|
|
|
|
#region 获取单个货品信息======================================================================
|
|
/// <summary>
|
|
/// 获取单个货品信息
|
|
/// </summary>
|
|
/// <param name="entity"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async Task<WebApiCallBack> GetProductInfo([FromBody] FMGetProductInfo entity)
|
|
{
|
|
var jm = new WebApiCallBack();
|
|
|
|
var userId = 0;
|
|
if (_user != null)
|
|
{
|
|
userId = _user.ID;
|
|
}
|
|
|
|
bool bl = entity.type == "pinTuan" || entity.type == "group";
|
|
|
|
var getProductInfo = await _productsServices.GetProductInfo(entity.id, bl, userId, entity.type, entity.groupId);
|
|
if (getProductInfo == null)
|
|
{
|
|
jm.msg = "获取单个货品失败";
|
|
return jm;
|
|
}
|
|
|
|
jm.status = true;
|
|
jm.msg = "获取单个货品成功";
|
|
jm.data = getProductInfo;
|
|
|
|
return jm;
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region 获取商品评价列表分页数据======================================================================
|
|
/// <summary>
|
|
/// 获取商品评价列表分页数据
|
|
/// </summary>
|
|
/// <param name="entity"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async Task<WebApiCallBack> GetGoodsComment([FromBody] FMPageByIntId entity)
|
|
{
|
|
var jm = new WebApiCallBack();
|
|
|
|
//获取数据
|
|
var list = await _goodsCommentServices.QueryPageAsync(p => p.goodsId == entity.id && p.isDisplay == true, p => p.createTime, OrderByType.Desc, entity.page, entity.limit);
|
|
|
|
if (list.Any())
|
|
{
|
|
foreach (var item in list)
|
|
{
|
|
item.imagesArr = !string.IsNullOrEmpty(item.images) ? item.images.Split(",") : null;
|
|
}
|
|
}
|
|
|
|
jm.status = true;
|
|
jm.msg = "获取评论成功";
|
|
jm.data = new
|
|
{
|
|
list,
|
|
commentsCount = list.TotalCount,
|
|
totalPages = list.TotalPages
|
|
};
|
|
|
|
return jm;
|
|
}
|
|
#endregion
|
|
|
|
#region 获取商品参数======================================================================
|
|
/// <summary>
|
|
/// 获取单个商品参数
|
|
/// </summary>
|
|
/// <param name="entity"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async Task<WebApiCallBack> GetGoodsParams([FromBody] FMIntId entity)
|
|
{
|
|
var jm = new WebApiCallBack();
|
|
|
|
//获取数据
|
|
var goods = await _goodsServices.QueryByIdAsync(entity.id);
|
|
if (goods == null)
|
|
{
|
|
jm.msg = GlobalConstVars.DataisNo;
|
|
return jm;
|
|
}
|
|
var list = new List<WxNameValueDto>();
|
|
var goodsParams = await _goodsParamsServices.QueryAsync(true, true);
|
|
|
|
if (!string.IsNullOrEmpty(goods.parameters))
|
|
{
|
|
var arrItem = goods.parameters.Split("|");
|
|
foreach (var item in arrItem)
|
|
{
|
|
if (!item.Contains(":")) continue;
|
|
|
|
var childArr = item.Split(":");
|
|
if (childArr.Length == 2)
|
|
{
|
|
var paramsId = Convert.ToInt32(childArr[0]);
|
|
var paramsModel = goodsParams.First(p => p.id == paramsId);
|
|
if (paramsModel != null)
|
|
{
|
|
list.Add(new WxNameValueDto()
|
|
{
|
|
name = paramsModel.name,
|
|
value = childArr[1]
|
|
});
|
|
}
|
|
}
|
|
}
|
|
}
|
|
jm.status = true;
|
|
jm.msg = "获取商品参数成功";
|
|
jm.data = list;
|
|
|
|
return jm;
|
|
}
|
|
#endregion
|
|
|
|
#region 获取随机推荐商品==================================================
|
|
/// <summary>
|
|
/// 获取随机推荐商品
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async Task<WebApiCallBack> GetGoodsRecommendList([FromBody] FMIntId entity)
|
|
{
|
|
if (entity.id <= 0)
|
|
{
|
|
entity.id = 10;
|
|
}
|
|
|
|
var bl = entity.data.ObjectToBool();
|
|
|
|
var jm = new WebApiCallBack()
|
|
{
|
|
status = true,
|
|
code = 0,
|
|
msg = "获取成功",
|
|
data = await _goodsServices.GetGoodsRecommendList(entity.id, bl)
|
|
};
|
|
return jm;
|
|
}
|
|
#endregion
|
|
|
|
|
|
#region 获取商品sku======================================================================
|
|
/// <summary>
|
|
/// 获取商品sku
|
|
/// </summary>
|
|
/// <param name="entity"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
public async Task<WebApiCallBack> GetSku([FromBody] FMGetSku entity)
|
|
{
|
|
var jm = new WebApiCallBack();
|
|
|
|
var good = await _goodsServices.QueryByClauseAsync(p => p.id == entity.id, true);
|
|
if (good == null)
|
|
{
|
|
jm.msg = "商品获取失败";
|
|
return jm;
|
|
}
|
|
|
|
//取所有货品
|
|
var products = await _productsServices.QueryListByClauseAsync(p => p.goodsId == good.id && p.isDel == false, p => p.id, OrderByType.Asc, true);
|
|
if (products == null)
|
|
{
|
|
jm.msg = "商品sku列表获取失败";
|
|
return jm;
|
|
}
|
|
|
|
var skus = await _goodsServices.GetCoreCmsProductsView(good, products, 0, entity.isPromotion, entity.type, entity.groupId);
|
|
if (skus == null)
|
|
{
|
|
jm.msg = "商品sku列表组合获取失败";
|
|
return jm;
|
|
}
|
|
jm.status = true;
|
|
jm.msg = "获取商品详情成功";
|
|
jm.data = skus;
|
|
|
|
return jm;
|
|
}
|
|
#endregion
|
|
|
|
//验证接口====================================================================================================
|
|
|
|
|
|
#region 根据Token获取商品详情======================================================================
|
|
/// <summary>
|
|
/// 根据Token获取商品详情
|
|
/// </summary>
|
|
/// <param name="entity"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
[Authorize]
|
|
public async Task<WebApiCallBack> GetDetialByToken([FromBody] FMIntId entity)
|
|
{
|
|
var jm = new WebApiCallBack();
|
|
|
|
var userId = 0;
|
|
if (_user != null)
|
|
{
|
|
userId = _user.ID;
|
|
}
|
|
var model = await _goodsServices.GetGoodsDetail(entity.id, userId, false, "goods", 0, entity.data.ObjectToBool());
|
|
|
|
if (model == null)
|
|
{
|
|
jm.msg = "商品获取失败";
|
|
return jm;
|
|
}
|
|
await _goodsServices.UpdateAsync(p => new CoreCmsGoods() { viewCount = p.viewCount + 1 },
|
|
p => p.id == entity.id);
|
|
|
|
|
|
jm.status = true;
|
|
jm.msg = "获取商品详情成功";
|
|
jm.data = model;
|
|
jm.methodDescription = JsonConvert.SerializeObject(_user);
|
|
|
|
return jm;
|
|
}
|
|
#endregion
|
|
|
|
|
|
|
|
|
|
#region 根据Token获取商品sku======================================================================
|
|
/// <summary>
|
|
/// 根据Token获取商品sku
|
|
/// </summary>
|
|
/// <param name="entity"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
[Authorize]
|
|
public async Task<WebApiCallBack> GetSkuByToken([FromBody] FMGetSku entity)
|
|
{
|
|
var jm = new WebApiCallBack();
|
|
|
|
var userId = 0;
|
|
if (_user != null)
|
|
{
|
|
userId = _user.ID;
|
|
}
|
|
|
|
var good = await _goodsServices.QueryByClauseAsync(p => p.id == entity.id, true);
|
|
if (good == null)
|
|
{
|
|
jm.msg = "商品获取失败";
|
|
return jm;
|
|
}
|
|
|
|
//取所有货品
|
|
var products = await _productsServices.QueryListByClauseAsync(p => p.goodsId == good.id && p.isDel == false, p => p.id, OrderByType.Asc, true);
|
|
if (products == null)
|
|
{
|
|
jm.msg = "商品sku列表获取失败";
|
|
return jm;
|
|
}
|
|
|
|
var skus = await _goodsServices.GetCoreCmsProductsView(good, products, userId, entity.isPromotion, entity.type, entity.groupId);
|
|
if (skus == null)
|
|
{
|
|
jm.msg = "商品sku列表组合获取失败";
|
|
return jm;
|
|
}
|
|
|
|
jm.status = true;
|
|
jm.msg = "获取商品详情成功";
|
|
jm.data = skus;
|
|
|
|
return jm;
|
|
}
|
|
#endregion
|
|
|
|
|
|
}
|
|
} |