key1_beacon_api/ARW.Service/Business/BusinessService/Custom/Customers/CustomerService.cs
2023-11-22 12:17:14 +08:00

118 lines
4.2 KiB
C#

using Infrastructure.Attribute;
using Microsoft.AspNetCore.Http;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Infrastructure;
using ARW.Model;
using ARW.Repository;
using ARW.Model.Dto.Business.Custom.Customers;
using ARW.Model.Models.Business.Custom.Customers;
using ARW.Model.Vo.Business.Custom.Customers;
using ARW.Repository.Business.Custom.Customers;
using ARW.Service.Business.IBusinessService.Custom.Customers;
using ARW.Common;
using System.Security.Cryptography;
using ARW.Model.System;
namespace ARW.Service.Business.BusinessService.Custom.Customers
{
/// <summary>
/// 小程序客户接口实现类
///
/// @author lwh
/// @date 2023-06-05
/// </summary>
[AppService(ServiceType = typeof(ICustomerService), ServiceLifetime = LifeTime.Transient)]
public class CustomerServiceImpl : BaseService<Customer>, ICustomerService
{
private readonly CustomerRepository _CustomerRepository;
public CustomerServiceImpl(CustomerRepository CustomerRepository)
{
_CustomerRepository = CustomerRepository;
}
#region
/// <summary>
/// 查询小程序客户分页列表
/// </summary>
public Task<PagedInfo<CustomerVo>> GetCustomerList(CustomerQueryDto parm)
{
//开始拼装查询条件d
var predicate = Expressionable.Create<Customer>();
predicate = predicate.AndIF(!string.IsNullOrEmpty(parm.CustomerXcxOpenid), it => it.CustomerXcxOpenid == parm.CustomerXcxOpenid);
predicate = predicate.AndIF(!string.IsNullOrEmpty(parm.CustomerNickname), it => it.CustomerNickname.Contains(parm.CustomerNickname));
predicate = predicate.AndIF(!string.IsNullOrEmpty(parm.CustomerMobilePhoneNumber), it => it.CustomerMobilePhoneNumber.Contains(parm.CustomerMobilePhoneNumber));
predicate = predicate.AndIF(parm.BeginTime != null && parm.EndTime != null, it => it.CustomerLastLoginTime >= parm.BeginTime && it.CustomerLastLoginTime <= parm.EndTime);
var query = _CustomerRepository
.Queryable()
.Where(predicate.ToExpression())
.OrderBy(s => s.Create_time, OrderByType.Desc)
.Select(s => new CustomerVo
{
CustomerId = s.CustomerId,
CustomerGuid = s.CustomerGuid,
CustomerType = s.CustomerType,
CustomerXcxOpenid = s.CustomerXcxOpenid,
CustomerNickname = s.CustomerNickname,
CustomerMobilePhoneNumber = s.CustomerMobilePhoneNumber,
CustomerAvatar = s.CustomerAvatar,
CustomerGender = s.CustomerGender,
CustomerAvailableBalance = s.CustomerAvailableBalance,
CustomerAvailablePoints = s.CustomerAvailablePoints,
CustomerTotalPaymentAmount = s.CustomerTotalPaymentAmount,
CustomerActualConsumptionAmount = s.CustomerActualConsumptionAmount,
CustomerLastLoginTime = s.CustomerLastLoginTime,
CustomerPassword = s.CustomerPassword
});
return query.ToPageAsync(parm);
}
/// <summary>
/// 添加或修改小程序客户
/// </summary>
public async Task<string> AddOrUpdateCustomer(Customer model)
{
//密码md5
model.CustomerPassword = NETCore.Encrypt.EncryptProvider.Md5(model.CustomerPassword);
if (model.CustomerId != 0)
{
var response = await _CustomerRepository.UpdateAsync(model);
return "修改成功!";
}
else
{
var response = await _CustomerRepository.InsertReturnSnowflakeIdAsync(model);
return "添加成功!";
}
}
#region Excel处理
/// <summary>
/// Excel数据导出处理
/// </summary>
public async Task<List<CustomerVo>> HandleExportData(List<CustomerVo> data)
{
return data;
}
#endregion
#endregion
}
}