添加项目文件。

This commit is contained in:
JianWeie
2021-12-20 21:27:32 +08:00
parent 747486f5cb
commit 82d825b7a5
3514 changed files with 887941 additions and 0 deletions

View File

@@ -0,0 +1,58 @@
/***********************************************************************
* 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.Linq.Expressions;
using System.Threading.Tasks;
using CoreCms.Net.Configuration;
using CoreCms.Net.IRepository;
using CoreCms.Net.IRepository.UnitOfWork;
using CoreCms.Net.IServices;
using CoreCms.Net.Model.Entities;
using CoreCms.Net.Model.ViewModels.Basics;
using SqlSugar;
namespace CoreCms.Net.Services
{
/// <summary>
/// 服务项目表 接口实现
/// </summary>
public class CoreCmsServicesServices : BaseServices<CoreCmsServices>, ICoreCmsServicesServices
{
private readonly ICoreCmsServicesRepository _dal;
private readonly IUnitOfWork _unitOfWork;
public CoreCmsServicesServices(IUnitOfWork unitOfWork, ICoreCmsServicesRepository dal)
{
this._dal = dal;
base.BaseDal = dal;
_unitOfWork = unitOfWork;
}
/// <summary>
/// 根据条件查询分页数据
/// </summary>
/// <param name="predicate">判断集合</param>
/// <param name="orderByType">排序方式</param>
/// <param name="pageIndex">当前页面索引</param>
/// <param name="pageSize">分布大小</param>
/// <param name="orderByExpression"></param>
/// <returns></returns>
public async Task<IPageList<CoreCmsServices>> TagQueryPageAsync(Expression<Func<CoreCmsServices, bool>> predicate,
Expression<Func<CoreCmsServices, object>> orderByExpression, OrderByType orderByType, int pageIndex = 1,
int pageSize = 20)
{
return await _dal.TagQueryPageAsync(predicate, orderByExpression, orderByType, pageIndex, pageSize);
}
}
}

View File

@@ -0,0 +1,109 @@
/***********************************************************************
* 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.Threading.Tasks;
using CoreCms.Net.Configuration;
using CoreCms.Net.IRepository;
using CoreCms.Net.IRepository.UnitOfWork;
using CoreCms.Net.IServices;
using CoreCms.Net.Model.Entities;
using CoreCms.Net.Model.ViewModels.UI;
using CoreCms.Net.Utility.Helper;
using Microsoft.Extensions.DependencyInjection;
namespace CoreCms.Net.Services
{
/// <summary>
/// 服务购买表 接口实现
/// </summary>
public class CoreCmsUserServicesOrderServices : BaseServices<CoreCmsUserServicesOrder>, ICoreCmsUserServicesOrderServices
{
private readonly ICoreCmsUserServicesOrderRepository _dal;
private readonly IServiceProvider _serviceProvider;
private readonly IUnitOfWork _unitOfWork;
public CoreCmsUserServicesOrderServices(IUnitOfWork unitOfWork, ICoreCmsUserServicesOrderRepository dal, IServiceProvider serviceProvider)
{
this._dal = dal;
_serviceProvider = serviceProvider;
base.BaseDal = dal;
_unitOfWork = unitOfWork;
}
/// <summary>
/// 完成服务订单后生成兑换券
/// </summary>
/// <param name="serviceOrderId"></param>
/// <param name="paymentId"></param>
/// <returns></returns>
public async Task<WebApiCallBack> CreateUserServicesTickets(string serviceOrderId, string paymentId)
{
using var container = _serviceProvider.CreateScope();
var servicesServices = container.ServiceProvider.GetService<ICoreCmsServicesServices>();
var userServicesTicketServices = container.ServiceProvider.GetService<ICoreCmsUserServicesTicketServices>();
var jm = new WebApiCallBack();
var model = await _dal.QueryByClauseAsync(p => p.serviceOrderId == serviceOrderId);
if (model == null)
{
jm.msg = "订单获取失败";
return jm;
}
var servicesModel = await servicesServices.QueryByClauseAsync(p => p.id == model.servicesId);
if (servicesModel == null)
{
jm.msg = "服务信息获取失败";
return jm;
}
model.isPay = true;
model.payTime = DateTime.Now;
model.paymentId = paymentId;
model.servicesEndTime = servicesModel.validityEndTime;
var up = await _dal.UpdateAsync(model);
var bl = false;
if (up)
{
var tickets = new List<CoreCmsUserServicesTicket>();
for (int i = 0; i < servicesModel.ticketNumber; i++)
{
var tk = new CoreCmsUserServicesTicket();
tk.serviceOrderId = serviceOrderId;
tk.securityCode = Guid.NewGuid();
tk.redeemCode = CommonHelper.GetSerialNumberType((int)GlobalEnumVars.SerialNumberType.);
tk.serviceId = model.servicesId;
tk.userId = model.userId;
tk.status = (int)GlobalEnumVars.ServicesTicketStatus.Normal;
tk.validityType = servicesModel.validityType;
tk.validityStartTime = servicesModel.validityStartTime;
tk.validityEndTime = servicesModel.validityEndTime;
tk.createTime = DateTime.Now;
tk.isVerification = false;
tickets.Add(tk);
}
bl = await userServicesTicketServices.InsertAsync(tickets) > 0;
}
jm.status = bl && up;
jm.msg = bl && up ? GlobalConstVars.EditSuccess : GlobalConstVars.EditFailure;
return jm;
}
}
}

View File

@@ -0,0 +1,38 @@
/***********************************************************************
* 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.Threading.Tasks;
using CoreCms.Net.Configuration;
using CoreCms.Net.IRepository;
using CoreCms.Net.IRepository.UnitOfWork;
using CoreCms.Net.IServices;
using CoreCms.Net.Model.Entities;
using CoreCms.Net.Model.ViewModels.UI;
namespace CoreCms.Net.Services
{
/// <summary>
/// 服务消费券 接口实现
/// </summary>
public class CoreCmsUserServicesTicketServices : BaseServices<CoreCmsUserServicesTicket>, ICoreCmsUserServicesTicketServices
{
private readonly ICoreCmsUserServicesTicketRepository _dal;
private readonly IUnitOfWork _unitOfWork;
public CoreCmsUserServicesTicketServices(IUnitOfWork unitOfWork, ICoreCmsUserServicesTicketRepository dal)
{
this._dal = dal;
base.BaseDal = dal;
_unitOfWork = unitOfWork;
}
}
}

View File

@@ -0,0 +1,128 @@
/***********************************************************************
* 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.Linq;
using System.Threading.Tasks;
using CoreCms.Net.Configuration;
using CoreCms.Net.IRepository;
using CoreCms.Net.IRepository.UnitOfWork;
using CoreCms.Net.IServices;
using CoreCms.Net.Loging;
using CoreCms.Net.Model.Entities;
using CoreCms.Net.Model.ViewModels.UI;
using CoreCms.Net.Utility.Helper;
using SqlSugar;
namespace CoreCms.Net.Services
{
/// <summary>
/// 服务券核验日志 接口实现
/// </summary>
public class CoreCmsUserServicesTicketVerificationLogServices : BaseServices<CoreCmsUserServicesTicketVerificationLog>, ICoreCmsUserServicesTicketVerificationLogServices
{
private readonly ICoreCmsUserServicesTicketVerificationLogRepository _dal;
private readonly ICoreCmsServicesServices _servicesServices;
private readonly ICoreCmsUserServicesTicketServices _userServicesTicketServices;
private readonly ICoreCmsClerkServices _clerkServices;
private readonly IUnitOfWork _unitOfWork;
public CoreCmsUserServicesTicketVerificationLogServices(IUnitOfWork unitOfWork, ICoreCmsUserServicesTicketVerificationLogRepository dal, ICoreCmsClerkServices clerkServices, ICoreCmsServicesServices servicesServices, ICoreCmsUserServicesTicketServices userServicesTicketServices)
{
this._dal = dal;
_clerkServices = clerkServices;
_servicesServices = servicesServices;
_userServicesTicketServices = userServicesTicketServices;
base.BaseDal = dal;
_unitOfWork = unitOfWork;
}
/// <summary>
/// 店铺核销的服务券列表
/// </summary>
/// <returns></returns>
public async Task<WebApiCallBack> GetVerificationLogs(int userId, int page, int limit)
{
var jm = new WebApiCallBack();
var clerk = await _clerkServices.QueryByClauseAsync(p => p.userId == userId);
if (clerk == null)
{
jm.msg = "未查询到用户门店";
return jm;
}
var logs = await _dal.QueryPageAsync(p => p.storeId == clerk.storeId && p.isDel == false, p => p.verificationTime, OrderByType.Desc, page, limit);
if (logs != null && logs.Any())
{
var ticketIds = logs.Select(p => p.ticketId).ToList();
var serviceIds = logs.Select(p => p.serviceId).ToList();
var servicesModel = await _servicesServices.QueryListByClauseAsync(p => serviceIds.Contains(p.id));
var ticketsMdoel = await _userServicesTicketServices.QueryListByClauseAsync(p => ticketIds.Contains(p.id));
foreach (var item in logs)
{
item.ticket = ticketsMdoel.Find(p => p.id == item.ticketId);
item.service = servicesModel.Find(p => p.id == item.serviceId);
}
jm.status = true;
jm.msg = "获取成功";
}
jm.data = logs;
jm.otherData = new
{
logs.TotalPages,
logs.TotalCount
};
return jm;
}
/// <summary>
/// 删除服务券核销单(软删除)
/// </summary>
/// <param name="ids"></param>
/// <param name="userId"></param>
/// <returns></returns>
public async Task<WebApiCallBack> LogDelete(int id, int userId = 0)
{
var jm = new WebApiCallBack();
var model = await _dal.QueryByClauseAsync(p => p.id == id);
if (model != null)
{
if (userId > 0)
{
var clerks = await _clerkServices.ExistsAsync(p => p.userId == userId && p.storeId == model.storeId);
if (!clerks)
{
jm.msg = "你无权删除该服务券核销单";
return jm;
}
}
model.isDel = true;
var bl = await _dal.UpdateAsync(model);
jm.status = bl;
jm.msg = bl ? "删除成功" : "删除失败";
}
else
{
jm.msg = "未找到服务券核销单";
}
return jm;
}
}
}