导出货架存量
This commit is contained in:
@ -15,7 +15,13 @@ namespace WCS.BLL.Services.IService
|
|||||||
/// <param name="request"></param>
|
/// <param name="request"></param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public Task<PageQueryResponse<MatDetailCurrentInfoModel>> GetMatDetailCurrentInfos(GetMatDetailCurrentInfosRequest request);
|
public Task<PageQueryResponse<MatDetailCurrentInfoModel>> GetMatDetailCurrentInfos(GetMatDetailCurrentInfosRequest request);
|
||||||
|
/// <summary>
|
||||||
|
/// 导出货架存量数据
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="request"></param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public Task<PageQueryResponse<MatDetailCurrentInfoModel>> ExportMatDetailCurrentInfos(GetMatDetailCurrentInfosRequest request);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 更新货架存量
|
/// 更新货架存量
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -99,6 +99,77 @@ namespace WCS.BLL.Services.Service
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async Task<PageQueryResponse<MatDetailCurrentInfoModel>> ExportMatDetailCurrentInfos(GetMatDetailCurrentInfosRequest request)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var recordsQueryable = DbHelp.db.Queryable<MatDetailCurrentInfo>()
|
||||||
|
.LeftJoin<ShelfInfo>((mci, si) => mci.ShelfId == si.Id)
|
||||||
|
.LeftJoin<LocationInfo>((mci, si, li) => (si.TransStatus == TransStatusEnum.静止 && si.CurrentLocationId == li.Id)
|
||||||
|
|| (si.TransStatus == TransStatusEnum.运输中 && si.DestinationLocationId == li.Id))
|
||||||
|
.WhereIF(request.LocationAreaId != null && request.LocationAreaId != 0, (mci, si, li) => li.LocationAreaId == request.LocationAreaId)
|
||||||
|
.WhereIF(!string.IsNullOrEmpty(request.LocationCode), (mci, si, li) => li.LocationCode.Contains(request.LocationCode))
|
||||||
|
.WhereIF(request.ShelfTypeId != null && request.ShelfTypeId != 0, (mci, si, li) => si.ShelfTypeId == request.ShelfTypeId)
|
||||||
|
.WhereIF(!string.IsNullOrEmpty(request.ShelfCode), (mci, si, li) => si.ShelfCode.Contains(request.ShelfCode))
|
||||||
|
.WhereIF(!string.IsNullOrEmpty(request.MatCode), (mci, si, li) => mci.MatCode.Contains(request.MatCode))
|
||||||
|
.WhereIF(!string.IsNullOrEmpty(request.MatName), (mci, si, li) => mci.MatName.Contains(request.MatName))
|
||||||
|
.Select((mci, si, li) => new MatDetailCurrentInfoModel()
|
||||||
|
{
|
||||||
|
Id = mci.Id,
|
||||||
|
ShelfId = mci.ShelfId,
|
||||||
|
ShelfCode = mci.ShelfCode,
|
||||||
|
ShelfType = mci.ShelfType,
|
||||||
|
|
||||||
|
LocationArea = li.LocationArea,
|
||||||
|
LocationCode = li.LocationCode,
|
||||||
|
|
||||||
|
MatCode = mci.MatCode,
|
||||||
|
MatName = mci.MatName,
|
||||||
|
MatSpec = mci.MatSpec,
|
||||||
|
MatUnit = mci.MatUnit,
|
||||||
|
MatCustomer = mci.MatCustomer,
|
||||||
|
MatQty = mci.MatQty,
|
||||||
|
MatSupplier = mci.MatSupplier,
|
||||||
|
|
||||||
|
StationCode = mci.StationCode,
|
||||||
|
ModifyUser = mci.ModifyUser,
|
||||||
|
ModifyTime = mci.ModifyTime
|
||||||
|
});
|
||||||
|
//分页
|
||||||
|
var totalCount = await recordsQueryable.CountAsync();
|
||||||
|
var records = await recordsQueryable
|
||||||
|
.OrderByDescending(mci => mci.Id)
|
||||||
|
.Take(65535)
|
||||||
|
.ToListAsync();
|
||||||
|
//生成序号
|
||||||
|
var index = 1;
|
||||||
|
for (int i = 0; i < records.Count; i++)
|
||||||
|
{
|
||||||
|
records[i].RowNumber = index++;
|
||||||
|
}
|
||||||
|
return new PageQueryResponse<MatDetailCurrentInfoModel>()
|
||||||
|
{
|
||||||
|
Code = 200,
|
||||||
|
Message = $"success",
|
||||||
|
Data = new PageQueryResponseData<MatDetailCurrentInfoModel>()
|
||||||
|
{
|
||||||
|
TotalCount = totalCount,
|
||||||
|
MaxPage = request.PageSize == 0 ? 0 : (int)Math.Ceiling((decimal)totalCount / request.PageSize),
|
||||||
|
Count = records.Count,
|
||||||
|
Lists = records.ToList()
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
return new PageQueryResponse<MatDetailCurrentInfoModel>()
|
||||||
|
{
|
||||||
|
Code = 300,
|
||||||
|
Message = $"操作失败:{ex.Message}",
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public async Task<ResponseCommon<object>> updateMatDetailCurrentInfo(AddLocaionInfoRequest<MatDetailCurrentInfo> request)
|
public async Task<ResponseCommon<object>> updateMatDetailCurrentInfo(AddLocaionInfoRequest<MatDetailCurrentInfo> request)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
|
@ -7,6 +7,7 @@ using WCS.BLL.DbModels;
|
|||||||
using WCS.Model.ApiModel.MatBaseInfo;
|
using WCS.Model.ApiModel.MatBaseInfo;
|
||||||
using WCS.Model.ApiModel.MatDetailCurrentInfo;
|
using WCS.Model.ApiModel.MatDetailCurrentInfo;
|
||||||
using WCS.DAL.DbModels;
|
using WCS.DAL.DbModels;
|
||||||
|
using WCS.WebApi.Helper;
|
||||||
|
|
||||||
namespace WCS.WebApi.Controllers
|
namespace WCS.WebApi.Controllers
|
||||||
{
|
{
|
||||||
@ -31,6 +32,34 @@ namespace WCS.WebApi.Controllers
|
|||||||
return await _matDetailCurrentInfoService.GetMatDetailCurrentInfos(request);
|
return await _matDetailCurrentInfoService.GetMatDetailCurrentInfos(request);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Route("exportMatDetailCurrentInfos")]
|
||||||
|
[HttpPost(Name = "exportMatDetailCurrentInfos")]
|
||||||
|
public async Task<IActionResult> ExportMatDetailCurrentInfos(GetMatDetailCurrentInfosRequest request)
|
||||||
|
{
|
||||||
|
var result = await _matDetailCurrentInfoService.ExportMatDetailCurrentInfos(request);
|
||||||
|
var data = result.Data?.Lists;
|
||||||
|
var columns = new[]
|
||||||
|
{
|
||||||
|
new ExportableColumn("序号","RowNumber"),
|
||||||
|
new ExportableColumn("货架类型","ShelfType"),
|
||||||
|
new ExportableColumn("货架编码","ShelfCode"),
|
||||||
|
new ExportableColumn("位置区域","LocationArea"),
|
||||||
|
new ExportableColumn("位置编号","LocationCode"),
|
||||||
|
new ExportableColumn("物料编码","MatCode"),
|
||||||
|
new ExportableColumn("物料名称","MatName"),
|
||||||
|
new ExportableColumn("物料规格","MatSpec"),
|
||||||
|
new ExportableColumn("数量", "MatQty"),
|
||||||
|
new ExportableColumn("更新人", "ModifyUser"),
|
||||||
|
new ExportableColumn("更新时间", "ModifyTime"),
|
||||||
|
};
|
||||||
|
if (data == null)
|
||||||
|
{
|
||||||
|
return NotFound();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return ExportExcelHelper.Export("导出数据", columns, data);
|
||||||
|
}
|
||||||
|
|
||||||
[HttpPost("updateMatDetailCurrentInfo")]
|
[HttpPost("updateMatDetailCurrentInfo")]
|
||||||
public async Task<ResponseCommon<object>> updateMatDetailCurrentInfo(AddLocaionInfoRequest<MatDetailCurrentInfo> request)
|
public async Task<ResponseCommon<object>> updateMatDetailCurrentInfo(AddLocaionInfoRequest<MatDetailCurrentInfo> request)
|
||||||
{
|
{
|
||||||
|
@ -327,6 +327,51 @@ namespace 智慧物流软件系统.ViewModel
|
|||||||
return true;
|
return true;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 导出数据为Excel文件
|
||||||
|
/// </summary>
|
||||||
|
public ICommand BtnExportCommand { get => new DelegateCommand(BtnExport); }
|
||||||
|
public async void BtnExport()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
#region 选择文件保存路径
|
||||||
|
Microsoft.Win32.SaveFileDialog sfd = new Microsoft.Win32.SaveFileDialog();
|
||||||
|
sfd.Title = "选择文件保存路径";
|
||||||
|
sfd.Filter = ".xlsx文件(*.xlsx)|*.xlsx";
|
||||||
|
sfd.FileName = "货架存量" + DateTime.Now.ToString("yyyyMMddhhmmss");
|
||||||
|
sfd.OverwritePrompt = true;
|
||||||
|
if (sfd.ShowDialog() != true)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
string path = sfd.FileName;
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
var body = new GetMatDetailCurrentInfosRequest()
|
||||||
|
{
|
||||||
|
LocationAreaId = SelectedLocationAreaItems == null ? null : SelectedLocationAreaItems.Id,
|
||||||
|
LocationCode = LocationCode,
|
||||||
|
ShelfTypeId = SelectedShelfTypeItem == null ? null : selectedShelfTypeItem.Id,
|
||||||
|
ShelfCode = ShelfCode,
|
||||||
|
MatCode = MatCode,
|
||||||
|
MatName = MatName,
|
||||||
|
|
||||||
|
UserName = LocalStatic.CurrentUser,
|
||||||
|
DeviceType = LocalFile.Config.DeviceType,
|
||||||
|
PageNumber = CurrentPage,
|
||||||
|
PageSize = PageSize,
|
||||||
|
};
|
||||||
|
await ApiHelp.PostDownloadFileAsync(path, System.Net.Http.HttpMethod.Post, LocalFile.Config.ApiIpHost + "matDetailCurrenInfo/exportMatDetailCurrentInfos", body);
|
||||||
|
Growl.Success("导出成功!");
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Growl.Error("导出失败:" + ex.Message);
|
||||||
|
}
|
||||||
|
}
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region PageOperation 分页操作
|
#region PageOperation 分页操作
|
||||||
|
@ -148,7 +148,7 @@
|
|||||||
<DataGridTextColumn Header="名称" MaxWidth="150" Binding="{Binding MatName}"></DataGridTextColumn>
|
<DataGridTextColumn Header="名称" MaxWidth="150" Binding="{Binding MatName}"></DataGridTextColumn>
|
||||||
<DataGridTextColumn Header="规格" MaxWidth="150" Binding="{Binding MatSpec}"></DataGridTextColumn>
|
<DataGridTextColumn Header="规格" MaxWidth="150" Binding="{Binding MatSpec}"></DataGridTextColumn>
|
||||||
<DataGridTextColumn Header="单位" Binding="{Binding MatUnit}"></DataGridTextColumn>
|
<DataGridTextColumn Header="单位" Binding="{Binding MatUnit}"></DataGridTextColumn>
|
||||||
|
|
||||||
<DataGridTextColumn Header="客户" Binding="{Binding MatCustomer}"></DataGridTextColumn>
|
<DataGridTextColumn Header="客户" Binding="{Binding MatCustomer}"></DataGridTextColumn>
|
||||||
<DataGridTextColumn IsReadOnly="True" Header="状态" Binding="{Binding IsEnableStr}"></DataGridTextColumn>
|
<DataGridTextColumn IsReadOnly="True" Header="状态" Binding="{Binding IsEnableStr}"></DataGridTextColumn>
|
||||||
<DataGridTextColumn IsReadOnly="True" Header="更新人" Binding="{Binding ModifyUser}"></DataGridTextColumn>
|
<DataGridTextColumn IsReadOnly="True" Header="更新人" Binding="{Binding ModifyUser}"></DataGridTextColumn>
|
||||||
@ -221,95 +221,6 @@
|
|||||||
</Grid>
|
</Grid>
|
||||||
</Grid>
|
</Grid>
|
||||||
</Border>
|
</Border>
|
||||||
<!--<Border Grid.Row="1" Margin="3" Background="AliceBlue" CornerRadius="3" Padding="0">
|
|
||||||
<Grid>
|
|
||||||
<Grid.RowDefinitions>
|
|
||||||
<RowDefinition Height="0.8*"></RowDefinition>
|
|
||||||
<RowDefinition Height="8*"></RowDefinition>
|
|
||||||
<RowDefinition Height="0.7*"></RowDefinition>
|
|
||||||
</Grid.RowDefinitions>
|
|
||||||
<StackPanel Grid.Row="0" Orientation="Horizontal">
|
|
||||||
<Button MinHeight="40" FontSize="18" Margin="5" Command="{Binding BtnExportCommand}"
|
|
||||||
Content=" 导 出" FontFamily="{StaticResource IconFont}"
|
|
||||||
Style="{StaticResource ButtonWarning}" Background="DarkOrange">
|
|
||||||
</Button>
|
|
||||||
</StackPanel>
|
|
||||||
<DataGrid Grid.Row="1"
|
|
||||||
SelectedCellsChanged="DataGrid_SelectedCellsChanged"
|
|
||||||
ItemsSource="{Binding DataGridItemSource}"
|
|
||||||
RowHeight="39"
|
|
||||||
AutoGenerateColumns="False"
|
|
||||||
FontSize="13">
|
|
||||||
<DataGrid.Columns>
|
|
||||||
<DataGridTextColumn Header="序号" Binding="{Binding RowNumber}"></DataGridTextColumn>
|
|
||||||
<DataGridTextColumn Header="接口地址" Binding="{Binding RequestUrl}"></DataGridTextColumn>
|
|
||||||
<DataGridTextColumn Header="设备IP" Binding="{Binding DeviceIp}"></DataGridTextColumn>
|
|
||||||
<DataGridTextColumn Header="请求参数" Binding="{Binding RequestBody}" MaxWidth="100"></DataGridTextColumn>
|
|
||||||
<DataGridTextColumn Header="QueryString" Binding="{Binding QueryString}" MaxWidth="100"></DataGridTextColumn>
|
|
||||||
<DataGridTextColumn Header="请求时间" Binding="{Binding RequestTime,StringFormat='yyyy-MM-dd HH:mm:ss'}"></DataGridTextColumn>
|
|
||||||
<DataGridTextColumn Header="返回参数" Binding="{Binding ResponseJson}" MaxWidth="100"></DataGridTextColumn>
|
|
||||||
<DataGridTextColumn Header="返回时间" Binding="{Binding ResponseTime,StringFormat='yyyy-MM-dd HH:mm:ss'}"></DataGridTextColumn>
|
|
||||||
<DataGridTextColumn Header="耗时(ms)" Binding="{Binding ExecutionTime}"></DataGridTextColumn>
|
|
||||||
</DataGrid.Columns>
|
|
||||||
</DataGrid>
|
|
||||||
|
|
||||||
<Grid Grid.Row="2">
|
|
||||||
<Border CornerRadius="3" Background="Transparent" VerticalAlignment="Center" >
|
|
||||||
<Grid HorizontalAlignment="Stretch" Margin="0" VerticalAlignment="Top" Width="Auto" MinHeight="26">
|
|
||||||
<Grid.RowDefinitions>
|
|
||||||
<RowDefinition/>
|
|
||||||
</Grid.RowDefinitions>
|
|
||||||
<Grid.ColumnDefinitions>
|
|
||||||
<ColumnDefinition Width="5*"></ColumnDefinition>
|
|
||||||
<ColumnDefinition Width="5*"></ColumnDefinition>
|
|
||||||
<ColumnDefinition Width="5*"></ColumnDefinition>
|
|
||||||
</Grid.ColumnDefinitions>
|
|
||||||
|
|
||||||
<StackPanel Orientation="Horizontal" Margin="5">
|
|
||||||
<TextBlock FontSize="14" Text="共"></TextBlock>
|
|
||||||
<TextBlock FontSize="14" Text="{Binding TotalCount ,FallbackValue=0}"></TextBlock>
|
|
||||||
<TextBlock FontSize="14" Text="条记录 "></TextBlock>
|
|
||||||
<TextBlock FontSize="14" Text="第"></TextBlock>
|
|
||||||
<TextBlock FontSize="14" Text="{Binding CurrentPage,FallbackValue=0}"></TextBlock>
|
|
||||||
<TextBlock FontSize="14" Text="/"></TextBlock>
|
|
||||||
<TextBlock FontSize="14" Text="{Binding MaxPage,FallbackValue=0}"></TextBlock>
|
|
||||||
<TextBlock FontSize="14" Text="页"></TextBlock>
|
|
||||||
</StackPanel>
|
|
||||||
|
|
||||||
<StackPanel Orientation="Horizontal" HorizontalAlignment="Center" Grid.Column="1">
|
|
||||||
<Grid>
|
|
||||||
<Grid.RowDefinitions >
|
|
||||||
<RowDefinition Height="30"></RowDefinition>
|
|
||||||
</Grid.RowDefinitions>
|
|
||||||
<Grid.ColumnDefinitions>
|
|
||||||
<ColumnDefinition Width="auto"/>
|
|
||||||
<ColumnDefinition Width="auto"/>
|
|
||||||
<ColumnDefinition Width="auto"/>
|
|
||||||
<ColumnDefinition Width="auto"/>
|
|
||||||
<ColumnDefinition Width="auto"/>
|
|
||||||
</Grid.ColumnDefinitions>
|
|
||||||
|
|
||||||
<Button BorderBrush="Transparent" Background="Transparent" Grid.Column="0" Name="btnFirst" Content="首页" Foreground="Black" FontSize="14"
|
|
||||||
Command="{Binding BtnFirstPageCommand}"/>
|
|
||||||
<Button BorderBrush="Transparent" Background="Transparent" Grid.Column="1" Name="btnPrev" Content="上一页" FontSize="14"
|
|
||||||
Command="{Binding BtnPrePageCommand}"/>
|
|
||||||
<TextBox BorderBrush="Transparent" Grid.Column="2" FontSize="14" MinWidth="50" HorizontalAlignment="Center" VerticalAlignment="Center" Cursor="IBeam" IsEnabled="False"
|
|
||||||
Text ="{Binding CurrentPage}" TextAlignment="Center"
|
|
||||||
|
|
||||||
/>
|
|
||||||
<Button BorderBrush="Transparent" Background="Transparent" Grid.Column="3" Name="btnNext" Content="下一页" FontSize="14"
|
|
||||||
Command="{Binding BtnNextPageCommand}"/>
|
|
||||||
<Button BorderBrush="Transparent" Background="Transparent" Grid.Column="4" Name="btnLast" Content="末页" FontSize="14"
|
|
||||||
Command="{Binding BtnLastPageCommand}"/>
|
|
||||||
</Grid>
|
|
||||||
</StackPanel>
|
|
||||||
|
|
||||||
</Grid>
|
|
||||||
</Border>
|
|
||||||
</Grid>
|
|
||||||
</Grid>
|
|
||||||
</Border>-->
|
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
</Border>
|
</Border>
|
||||||
</pi:UserControlBase>
|
</pi:UserControlBase>
|
||||||
|
Reference in New Issue
Block a user