31 changed files with 544 additions and 82 deletions
@ -0,0 +1,47 @@ |
|||
using System.ComponentModel.DataAnnotations; |
|||
using Win_in.Sfs.Shared.Domain; |
|||
|
|||
namespace Win_in.Sfs.Basedata.Application.Contracts; |
|||
|
|||
[Display(Name = "物品收容器信息")] |
|||
|
|||
public class ItemContainerDTO : SfsBaseDataDTOBase |
|||
{ |
|||
/// <summary>
|
|||
/// 收容器代码
|
|||
/// </summary>
|
|||
[Display(Name = "收容器代码")] |
|||
[StringLength(SfsEfCorePropertyConst.CodeLength, ErrorMessage = "{0}最多输入{1}个字符")] |
|||
public string ContainerCode { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 收容器名称
|
|||
/// </summary>
|
|||
[Display(Name = "收容器名称")] |
|||
[StringLength(SfsEfCorePropertyConst.CodeLength, ErrorMessage = "{0}最多输入{1}个字符")] |
|||
public string ContainerName { get; set; } |
|||
/// <summary>
|
|||
/// 收容器类型
|
|||
/// </summary>
|
|||
[Display(Name = "收容器类型")] |
|||
[StringLength(SfsEfCorePropertyConst.DescLength, ErrorMessage = "{0}最多输入{1}个字符")] |
|||
public string ContainerType { get; set; } |
|||
/// <summary>
|
|||
/// 物品代码
|
|||
/// </summary>
|
|||
[Display(Name = "物品代码")] |
|||
[StringLength(SfsEfCorePropertyConst.DescLength, ErrorMessage = "{0}最多输入{1}个字符")] |
|||
public string ItemCode { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 收容器计量单位
|
|||
/// </summary>
|
|||
[Display(Name = "收容器计量单位")] |
|||
public string BasicUom { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 收容器数量
|
|||
/// </summary>
|
|||
[Display(Name = "收容器数量")] |
|||
public decimal Qty { get; set; } |
|||
} |
@ -0,0 +1,11 @@ |
|||
using System.Collections.Generic; |
|||
using System.Threading.Tasks; |
|||
using Win_in.Sfs.Shared.Application.Contracts; |
|||
|
|||
namespace Win_in.Sfs.Basedata.Application.Contracts; |
|||
|
|||
public interface IItemContainerAppService : ISfsBaseDataAppServiceBase<ItemContainerDTO, SfsBaseDataRequestInputBase, ItemContainerEditInput>, ISfsUpsertAppService<ItemContainerEditInput> |
|||
{ |
|||
Task<List<ItemContainerDTO>> GetListByItemCodeAsync(string itemCode); |
|||
Task UpsertAndItemBasicUomAsync(string itemCode,decimal stdPackQty); |
|||
} |
@ -0,0 +1,53 @@ |
|||
using System.ComponentModel.DataAnnotations; |
|||
using Win_in.Sfs.Shared.Domain; |
|||
|
|||
namespace Win_in.Sfs.Basedata.Application.Contracts; |
|||
|
|||
public class ItemContainerEditInput : SfsBaseDataCreateOrUpdateInputBase |
|||
{ |
|||
#region Base
|
|||
/// <summary>
|
|||
/// 收容器名称
|
|||
/// </summary>
|
|||
[Display(Name = "收容器名称")] |
|||
[StringLength(SfsEfCorePropertyConst.CodeLength, ErrorMessage = "{0}最多输入{1}个字符")] |
|||
public string ContainerName { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 收容器类型
|
|||
/// </summary>
|
|||
[Display(Name = "收容器类型")] |
|||
[StringLength(SfsEfCorePropertyConst.DescLength, ErrorMessage = "{0}最多输入{1}个字符")] |
|||
public string ContainerType { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 收容器计量单位
|
|||
/// </summary>
|
|||
[Display(Name = "收容器计量单位")] |
|||
public string BasicUom { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 收容器数量
|
|||
/// </summary>
|
|||
[Display(Name = "收容器数量")] |
|||
public decimal Qty { get; set; } |
|||
#endregion
|
|||
|
|||
#region Create
|
|||
/// <summary>
|
|||
/// 收容器代码
|
|||
/// </summary>
|
|||
[Display(Name = "收容器代码")] |
|||
[Required(ErrorMessage = "{0}是必填项")] |
|||
[StringLength(SfsEfCorePropertyConst.CodeLength, ErrorMessage = "{0}最多输入{1}个字符")] |
|||
public string ContainerCode { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 物品代码
|
|||
/// </summary>
|
|||
[Display(Name = "物品代码")] |
|||
[Required(ErrorMessage = "{0}是必填项")] |
|||
[StringLength(SfsEfCorePropertyConst.DescLength, ErrorMessage = "{0}最多输入{1}个字符")] |
|||
public string ItemCode { get; set; } |
|||
#endregion
|
|||
} |
@ -0,0 +1,64 @@ |
|||
using System.ComponentModel.DataAnnotations; |
|||
using Win_in.Sfs.Shared.Application.Contracts; |
|||
using Win_in.Sfs.Shared.Domain; |
|||
|
|||
namespace Win_in.Sfs.Basedata.Application.Contracts; |
|||
|
|||
[Display(Name = "物品收容器")] |
|||
public class ItemContainerImportInput : SfsBaseDataImportInputBase |
|||
{ |
|||
/// <summary>
|
|||
/// 收容器代码
|
|||
/// </summary>
|
|||
[Key] |
|||
[Display(Name = "收容器代码")] |
|||
[Required(ErrorMessage = "{0}不能为空")] |
|||
[StringLength(SfsEfCorePropertyConst.CodeLength, ErrorMessage = "{0}最多输入{1}个字符")] |
|||
public string ContainerCode { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 收容器名称
|
|||
/// </summary>
|
|||
[Display(Name = "收容器名称")] |
|||
[StringLength(SfsEfCorePropertyConst.CodeLength, ErrorMessage = "{0}最多输入{1}个字符")] |
|||
public string ContainerName { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 收容器类型
|
|||
/// </summary>
|
|||
[Display(Name = "收容器类型")] |
|||
[StringLength(SfsEfCorePropertyConst.DescLength, ErrorMessage = "{0}最多输入{1}个字符")] |
|||
[ValueMapping("EA", "EA")] |
|||
[ValueMapping("Box", "Box")] |
|||
[ValueMapping("Pallet", "Pallet")] |
|||
public string ContainerType { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 物品编号
|
|||
/// </summary>
|
|||
[Key] |
|||
[Display(Name = "物品编号")] |
|||
[Required(ErrorMessage = "物品编号不能为空")] |
|||
[StringLength(SfsEfCorePropertyConst.DescLength, ErrorMessage = "{0}最多输入{1}个字符")] |
|||
public string ItemCode { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 收容器计量单位
|
|||
/// </summary>
|
|||
[Display(Name = "收容器计量单位")] |
|||
public string BasicUom { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 收容器数量
|
|||
/// </summary>
|
|||
[Display(Name = "收容器数量")] |
|||
[Required(ErrorMessage = "{0}是必填项")] |
|||
public decimal Qty { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 备注
|
|||
/// </summary>
|
|||
[Display(Name = "备注")] |
|||
[StringLength(SfsEfCorePropertyConst.RemarkLength, ErrorMessage = "{0}最多输入{1}个字符")] |
|||
public string Remark { get; set; } |
|||
} |
@ -0,0 +1,21 @@ |
|||
using Volo.Abp.Authorization.Permissions; |
|||
using Win_in.Sfs.Basedata.Domain; |
|||
|
|||
namespace Win_in.Sfs.Basedata.Application.Contracts; |
|||
|
|||
public static class ItemContainerPermissions |
|||
{ |
|||
|
|||
public const string Default = BasedataPermissions.GroupName + "." + nameof(ItemContainer); |
|||
public const string Create = Default + "." + BasedataPermissions.CreateStr; |
|||
public const string Update = Default + "." + BasedataPermissions.UpdateStr; |
|||
public const string Delete = Default + "." + BasedataPermissions.DeleteStr; |
|||
|
|||
public static void AddItemContainerPermission(this PermissionGroupDefinition permissionGroup) |
|||
{ |
|||
var itemContainerPermission = permissionGroup.AddPermission(Default, BasedataPermissionDefinitionProvider.L(nameof(ItemContainer))); |
|||
itemContainerPermission.AddChild(Create, BasedataPermissionDefinitionProvider.L(BasedataPermissions.CreateStr)); |
|||
itemContainerPermission.AddChild(Update, BasedataPermissionDefinitionProvider.L(BasedataPermissions.UpdateStr)); |
|||
itemContainerPermission.AddChild(Delete, BasedataPermissionDefinitionProvider.L(BasedataPermissions.DeleteStr)); |
|||
} |
|||
} |
@ -0,0 +1,69 @@ |
|||
using System.Collections.Generic; |
|||
using System.ComponentModel.DataAnnotations; |
|||
using System.Linq; |
|||
using System.Threading.Tasks; |
|||
|
|||
using Microsoft.AspNetCore.Authorization; |
|||
using Microsoft.AspNetCore.Mvc; |
|||
using Volo.Abp.Caching; |
|||
using Win_in.Sfs.Basedata.Application.Contracts; |
|||
using Win_in.Sfs.Basedata.Domain; |
|||
using Win_in.Sfs.Basedata.Domain.Shared; |
|||
|
|||
namespace Win_in.Sfs.Basedata.Application; |
|||
|
|||
[Authorize] |
|||
[Route($"{BasedataConsts.RootPath}item-container")] |
|||
|
|||
public class ItemContainerAppService |
|||
: SfsBaseDataAppServiceBase<ItemContainer, ItemContainerDTO, SfsBaseDataRequestInputBase, ItemContainerEditInput, ItemContainerImportInput> |
|||
, IItemContainerAppService |
|||
{ |
|||
private readonly IItemContainerManager _manager; |
|||
private new readonly IItemContainerRepository _repository; |
|||
|
|||
public ItemContainerAppService( |
|||
IItemContainerRepository repository |
|||
, IDistributedCache<ItemContainerDTO> cache |
|||
, IItemContainerManager manager |
|||
, IItemBasicAppService itemBasicAppService) : base(repository, cache) |
|||
{ |
|||
base.CreatePolicyName = ItemContainerPermissions.Create; |
|||
base.UpdatePolicyName = ItemContainerPermissions.Update; |
|||
base.DeletePolicyName = ItemContainerPermissions.Delete; |
|||
_repository = repository; |
|||
_manager = manager; |
|||
} |
|||
|
|||
[HttpPost("upsert")] |
|||
public virtual async Task UpsertAsync(ItemContainerEditInput input) |
|||
{ |
|||
var entity = ObjectMapper.Map<ItemContainerEditInput, ItemContainer>(input); |
|||
await _repository.UpsertAsync(entity).ConfigureAwait(false); |
|||
} |
|||
|
|||
[HttpGet("list/by-item")] |
|||
public virtual async Task<List<ItemContainerDTO>> GetListByItemCodeAsync(string itemCode) |
|||
{ |
|||
var entities = await _repository.GetListAsync(c => c.ItemCode == itemCode).ConfigureAwait(false); |
|||
var dtos = ObjectMapper.Map<List<ItemContainer>, List<ItemContainerDTO>>(entities); |
|||
return dtos; |
|||
} |
|||
|
|||
|
|||
protected override async Task ValidateImportModelAsync(ItemContainerImportInput importInput, List<ValidationResult> validationRresult) |
|||
{ |
|||
await base.CheckItemBasicPackUomAsync(importInput.ItemCode, importInput.BasicUom, validationRresult).ConfigureAwait(false); |
|||
//await base.CheckItemContainerAsync(importInput.ContainerCode, validationRresult).ConfigureAwait(false);
|
|||
} |
|||
|
|||
[HttpPut("upsert-and-item-basic-std-pack")] |
|||
public async Task UpsertAndItemBasicUomAsync(string itemCode,decimal stdPackQty) |
|||
{ |
|||
var itemContainers=await _repository.GetListAsync(p => p.ItemCode == itemCode).ConfigureAwait(false); |
|||
var entity=itemContainers.First(); |
|||
entity.Qty = stdPackQty; |
|||
await _repository.UpsertAsync(entity).ConfigureAwait(false); |
|||
await ItemBasicAppService.UpsertStdPackQtyAsync(itemCode, stdPackQty).ConfigureAwait(false); |
|||
} |
|||
} |
@ -0,0 +1,33 @@ |
|||
using AutoMapper; |
|||
using Volo.Abp.AutoMapper; |
|||
using Win_in.Sfs.Basedata.Application.Contracts; |
|||
using Win_in.Sfs.Basedata.Domain; |
|||
|
|||
namespace Win_in.Sfs.Basedata.Application; |
|||
|
|||
public partial class BasedataApplicationAutoMapperProfile : Profile |
|||
{ |
|||
private void ItemContainerAutoMapperProfile() |
|||
{ |
|||
CreateMap<ItemContainer, ItemContainerDTO>() |
|||
.ReverseMap(); |
|||
|
|||
CreateMap<ItemContainerImportInput, ItemContainer>() |
|||
.IgnoreAuditedObjectProperties() |
|||
.Ignore(x => x.TenantId) |
|||
.Ignore(x => x.ExtraProperties) |
|||
.Ignore(x => x.ConcurrencyStamp) |
|||
; |
|||
|
|||
CreateMap<ItemContainerEditInput, ItemContainer>() |
|||
.IgnoreAuditedObjectProperties() |
|||
.Ignore(x => x.TenantId) |
|||
.Ignore(x=>x.Id) |
|||
.Ignore(x => x.ExtraProperties) |
|||
.Ignore(x => x.ConcurrencyStamp) |
|||
; |
|||
CreateMap<ItemContainerEditInput, ItemContainer>() |
|||
.IgnoreAuditedObjectProperties() |
|||
.Ignore(x => x.ConcurrencyStamp).Ignore(x => x.Id); |
|||
} |
|||
} |
@ -0,0 +1,9 @@ |
|||
using Volo.Abp.Domain.Services; |
|||
using Win_in.Sfs.Shared.Domain; |
|||
|
|||
namespace Win_in.Sfs.Basedata.Domain; |
|||
|
|||
public interface IItemContainerManager : IDomainService, IBulkImportService<ItemContainer> |
|||
{ |
|||
|
|||
} |
@ -0,0 +1,9 @@ |
|||
using System.Threading.Tasks; |
|||
using Win_in.Sfs.Shared.Domain; |
|||
|
|||
namespace Win_in.Sfs.Basedata.Domain; |
|||
|
|||
public interface IItemContainerRepository : ISfsBaseDataRepositoryBase<ItemContainer>, ISfsBulkRepositoryBase<ItemContainer> |
|||
{ |
|||
Task UpsertAsync(ItemContainer entity); |
|||
} |
@ -0,0 +1,46 @@ |
|||
using System.ComponentModel.DataAnnotations; |
|||
using System.ComponentModel.DataAnnotations.Schema; |
|||
using Win_in.Sfs.Shared.Domain.Entities; |
|||
using Win_in.Sfs.Shared.Domain.Shared; |
|||
|
|||
namespace Win_in.Sfs.Basedata.Domain; |
|||
|
|||
public class ItemContainer : SfsBaseDataAggregateRootBase |
|||
{ |
|||
/// <summary>
|
|||
/// 收容器代码
|
|||
/// </summary>
|
|||
[IgnoreUpdate] |
|||
public string ContainerCode { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 收容器名称
|
|||
/// </summary>
|
|||
public string ContainerName { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 收容器类型
|
|||
/// </summary>
|
|||
public string ContainerType { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 物品代码
|
|||
/// </summary>
|
|||
[IgnoreUpdate] |
|||
public string ItemCode { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 计量单位
|
|||
/// </summary>
|
|||
[Display(Name = "计量单位")] |
|||
[MaxLength(SfsPropertyConst.CodeLength)] |
|||
public string BasicUom { get; set; } |
|||
|
|||
/// <summary>
|
|||
/// 数量
|
|||
/// </summary>
|
|||
[Display(Name = "数量")] |
|||
[Column(TypeName = "decimal(18,6)")] |
|||
public decimal Qty { get; set; } |
|||
|
|||
} |
@ -0,0 +1,31 @@ |
|||
using System.Collections.Generic; |
|||
using System.Threading.Tasks; |
|||
using Volo.Abp.Domain.Services; |
|||
|
|||
namespace Win_in.Sfs.Basedata.Domain; |
|||
|
|||
public class ItemContainerManager : DomainService, IItemContainerManager |
|||
{ |
|||
private readonly IItemContainerRepository _repository; |
|||
|
|||
private readonly IItemBasicRepository _itemBasicRepository; |
|||
|
|||
public ItemContainerManager(IItemContainerRepository repository, IItemBasicRepository itemBasicRepository) |
|||
{ |
|||
_repository = repository; |
|||
_itemBasicRepository = itemBasicRepository; |
|||
} |
|||
|
|||
/// <summary>
|
|||
/// 执行导入
|
|||
/// </summary>
|
|||
public virtual async Task ImportDataAsync(List<ItemContainer> mergeEntities, List<ItemContainer> deleteEntities = null) |
|||
{ |
|||
if (deleteEntities != null && deleteEntities.Count > 0) |
|||
{ |
|||
await _repository.BulkDeleteAsync(deleteEntities).ConfigureAwait(false); |
|||
} |
|||
|
|||
await _repository.BulkMergeAsync(mergeEntities).ConfigureAwait(false); |
|||
} |
|||
} |
@ -0,0 +1,36 @@ |
|||
using Microsoft.EntityFrameworkCore; |
|||
using Volo.Abp.EntityFrameworkCore.Modeling; |
|||
using Win_in.Sfs.Basedata.Domain; |
|||
using Win_in.Sfs.Shared.Domain.Shared; |
|||
using Win_in.Sfs.Shared.EntityFrameworkCore; |
|||
|
|||
namespace Win_in.Sfs.Basedata.EntityFrameworkCore; |
|||
|
|||
public static class ItemContainerDbContextModelCreatingExtensions |
|||
{ |
|||
public static void ConfigureItemContainer(this ModelBuilder builder, BasedataModelBuilderConfigurationOptions options) |
|||
{ |
|||
builder.Entity<ItemContainer>(b => |
|||
{ |
|||
//Configure table & schema name
|
|||
b.ToTable(options.TablePrefix + nameof(ItemContainer), options.Schema); |
|||
//Configure ABP properties
|
|||
b.ConfigureByConvention(); |
|||
//Configure Sfs base properties
|
|||
b.ConfigureSfsBase(); |
|||
|
|||
//Properties
|
|||
|
|||
b.Property(q => q.ContainerCode).IsRequired().HasMaxLength(SfsPropertyConst.CodeLength); |
|||
b.Property(q => q.ItemCode).IsRequired().HasMaxLength(SfsPropertyConst.CodeLength); |
|||
b.Property(q => q.ContainerName).HasMaxLength(SfsPropertyConst.NameLength); |
|||
b.Property(q => q.ContainerType).HasMaxLength(SfsPropertyConst.NameLength); |
|||
|
|||
//Relations
|
|||
//None
|
|||
|
|||
//Indexes
|
|||
b.HasIndex(q => new { q.ItemCode, q.ContainerCode }).IsUnique(); |
|||
}); |
|||
} |
|||
} |
@ -0,0 +1,32 @@ |
|||
using System.Threading.Tasks; |
|||
using Microsoft.EntityFrameworkCore; |
|||
using Volo.Abp.EntityFrameworkCore; |
|||
using Win_in.Sfs.Basedata.Domain; |
|||
using Win_in.Sfs.Shared.Domain; |
|||
|
|||
namespace Win_in.Sfs.Basedata.EntityFrameworkCore; |
|||
|
|||
public class ItemContainerEfCoreRepository : SfsBaseDataEfCoreRepositoryBase<BasedataDbContext, ItemContainer>, IItemContainerRepository, ISfsBulkRepositoryBase<ItemContainer> |
|||
{ |
|||
public ItemContainerEfCoreRepository(IDbContextProvider<BasedataDbContext> dbContextProvider) : base(dbContextProvider) |
|||
{ |
|||
|
|||
} |
|||
|
|||
public virtual async Task UpsertAsync(ItemContainer entity) |
|||
{ |
|||
var dbSet = await GetDbSetAsync().ConfigureAwait(false); |
|||
var exist = await dbSet.FirstOrDefaultAsync(p => p.ItemCode == entity.ItemCode).ConfigureAwait(false); |
|||
if (exist == null) |
|||
{ |
|||
var insRet = await InsertAsync(entity).ConfigureAwait(false); |
|||
} |
|||
else |
|||
{ |
|||
exist.ContainerName = entity.ContainerName; |
|||
exist.ContainerCode = entity.ContainerCode; |
|||
exist.BasicUom = entity.BasicUom; |
|||
exist.Qty = entity.Qty; |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,22 @@ |
|||
using AutoMapper; |
|||
using Volo.Abp.AutoMapper; |
|||
using Win_in.Sfs.Wms.Inventory.Application.Contracts; |
|||
using Win_in.Sfs.Wms.Store.Domain; |
|||
|
|||
namespace Win_in.Sfs.Wms.Store.Event; |
|||
|
|||
public partial class StoreEventAutoMapperProfile : Profile |
|||
{ |
|||
private void ContainerNoteAutoMapperProfile() |
|||
{ |
|||
CreateMap<ContainerNoteDetail, TransferLogEditInput>() |
|||
.Ignore(x => x.DocNumber) |
|||
.Ignore(x => x.JobNumber) |
|||
.Ignore(x => x.Worker) |
|||
.Ignore(x => x.TransType) |
|||
.Ignore(x => x.ExtraProperties) |
|||
.Ignore(x => x.TransSubType) |
|||
; |
|||
} |
|||
|
|||
} |
Loading…
Reference in new issue