客户端任务查询页面

This commit is contained in:
hehaibing-1996
2025-02-22 11:33:36 +08:00
parent 0b79188bbb
commit f49af6acee
10 changed files with 448 additions and 259 deletions

View File

@ -5,6 +5,7 @@ using System.Linq;
using System.Text; using System.Text;
using System.Threading.Tasks; using System.Threading.Tasks;
using WCS.DAL.DbModels; using WCS.DAL.DbModels;
using WCS.Model.ApiModel.AGV;
namespace WCS.BLL.DbModels namespace WCS.BLL.DbModels
{ {
@ -61,7 +62,7 @@ namespace WCS.BLL.DbModels
/// 货架码 /// 货架码
/// </summary> /// </summary>
[SugarColumn(ColumnName = "shelf_Code", Length = 64, IsNullable = true, ColumnDescription = "AGV编号")] [SugarColumn(ColumnName = "shelf_Code", Length = 64, IsNullable = true, ColumnDescription = "AGV编号")]
public string ShlefCode { get; set; } = string.Empty; public string ShelfCode { get; set; } = string.Empty;
/// <summary> /// <summary>
/// AGV编号 /// AGV编号
@ -81,6 +82,18 @@ namespace WCS.BLL.DbModels
[SugarColumn(ColumnName = "create_time", IsNullable = true, ColumnDescription = "任务创建时间")] [SugarColumn(ColumnName = "create_time", IsNullable = true, ColumnDescription = "任务创建时间")]
public DateTime? CreateTime { get; set; } = DateTime.Now; public DateTime? CreateTime { get; set; } = DateTime.Now;
/// <summary>
/// 最后更新时间
/// </summary>
[SugarColumn(ColumnName = "modify_time", IsNullable = true, ColumnDescription = "最后更新时间")]
public DateTime? ModifyTime { get; set; } = DateTime.Now;
/// <summary>
/// 任务状态
/// </summary>
[SugarColumn(ColumnName = "task_status", IsNullable = true, ColumnDescription = "任务状态")]
public TaskStatusEnum TaskStatus { get; set; } = TaskStatusEnum.;
#endregion #endregion
/// <summary> /// <summary>
@ -95,14 +108,4 @@ namespace WCS.BLL.DbModels
[SugarColumn(IsIgnore = true)] [SugarColumn(IsIgnore = true)]
public bool IsSelected { get; set; } public bool IsSelected { get; set; }
} }
//1-已创建2-正在执行5-取消完成9-已结束, 10-被打断
public enum TaskStatusEnum
{
= 1,
= 2,
= 5,
= 9,
= 10,
}
} }

View File

@ -40,6 +40,19 @@ namespace WCS.DAL.DbModels
[SugarColumn(ColumnName = "rcs_store_code", Length = 64, IsNullable = true, ColumnDescription = "RCS库位编号")] [SugarColumn(ColumnName = "rcs_store_code", Length = 64, IsNullable = true, ColumnDescription = "RCS库位编号")]
public string RcsStoreCode { get; set; } public string RcsStoreCode { get; set; }
/// <summary>
/// X坐标
/// </summary>
[SugarColumn(ColumnName = "X", IsNullable = true, DefaultValue = "0", ColumnDescription = "X坐标")]
public decimal X { get; set; }
/// <summary>
/// Y坐标
/// </summary>
[SugarColumn(ColumnName = "Y", IsNullable = true, DefaultValue = "0", ColumnDescription = "Y坐标")]
public decimal Y { get; set; }
/// <summary> /// <summary>
/// 可放置货架类型 /// 可放置货架类型
/// </summary> /// </summary>

View File

@ -13,10 +13,11 @@ namespace WCS.BLL.Manager
//AGV动作相关 //AGV动作相关
public static class AGVManager public static class AGVManager
{ {
public static object lockFlag = new object();
/// <summary> /// <summary>
/// 产生AGV点到点搬运任务 /// 产生AGV点到点搬运任务
/// </summary> /// </summary>
public static AGVResponseModel GenAgvSchedulingTask(LocationInfo startLocation,LocationInfo endLocation,string shelfCode,string createUser) public static AGVResponseModel GenAgvSchedulingTask(LocationInfo startLocation, LocationInfo endLocation, string shelfCode, string createUser)
{ {
var url = @"http://192.168.18.150:8181/rcms/services/rest/hikRpcService/genAgvSchedulingTask"; var url = @"http://192.168.18.150:8181/rcms/services/rest/hikRpcService/genAgvSchedulingTask";
var startPositionCodePathItem = new PositionCodePathItem() var startPositionCodePathItem = new PositionCodePathItem()
@ -32,36 +33,36 @@ namespace WCS.BLL.Manager
positionCodePathItems.Add(startPositionCodePathItem); positionCodePathItems.Add(startPositionCodePathItem);
positionCodePathItems.Add((endPositionCodePathItem)); positionCodePathItems.Add((endPositionCodePathItem));
var body = new AGVRequestModel() //任务只允许一个一个发送
lock (lockFlag)
{ {
positionCodePath = positionCodePathItems, var body = new AGVRequestModel()
};
var response = ApiHelp.GetDataFromHttp<AGVResponseModel>(url,body,"POST",true);
if (response.code == "0" && response.message == "成功")
{
//生成任务数据
var task = new AgvTask()
{ {
ShlefCode = shelfCode, positionCodePath = positionCodePathItems,
RequestCode = body.reqCode,
TaskCode = body.taskCode,
TaskType = "GenAgvSchedulingTask",
StratLocationId = startLocation.Id,
StartLocationCode = startLocation.LocationCode,
EndLocationId = endLocation.Id,
EndLocationCode = endLocation.LocationCode,
CreateUser = createUser
}; };
DbHelp.db.Insertable(task).ExecuteCommand();
}
return response; var response = ApiHelp.GetDataFromHttp<AGVResponseModel>(url, body, "POST", true);
if (response.code == "0" && response.message == "成功")
{
//生成任务数据
var task = new AgvTask()
{
ShelfCode = shelfCode,
RequestCode = body.reqCode,
TaskCode = body.taskCode,
TaskType = "GenAgvSchedulingTask",
StratLocationId = startLocation.Id,
StartLocationCode = startLocation.LocationCode,
EndLocationId = endLocation.Id,
EndLocationCode = endLocation.LocationCode,
CreateUser = createUser
};
DbHelp.db.Insertable(task).ExecuteCommand();
}
return response;
}
} }
} }
public class AGVResult
{
public bool IsSuccess { get; set; }
}
} }

View File

@ -0,0 +1,111 @@
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Text;
using WCS.Model.ApiModel.StoreInfo;
namespace WCS.Model.ApiModel.AGV
{
public class AGVTaskModel : INotifyPropertyChanged
{
/// <summary>
/// 主键 自增Id
/// </summary>
public int Id { get; set; }
#region
/// <summary>
/// 请求码
/// </summary>
public string RequestCode { get; set; }
/// <summary>
/// 任务码
/// </summary>
public string TaskCode { get; set; }
/// <summary>
/// 任务类型
/// </summary>
public string TaskType { get; set; } = string.Empty;
/// <summary>
/// 起点位置ID
/// </summary>
public int StratLocationId { get; set; } = 0;
/// <summary>
/// 起点位置编码
/// </summary>
public string StartLocationCode { get; set; } = string.Empty;
/// <summary>
/// 终点位置ID
/// </summary>
public int EndLocationId { get; set; } = 0;
/// <summary>
/// 终点位置编码
/// </summary>
public string EndLocationCode { get; set; } = string.Empty;
/// <summary>
/// 货架码
/// </summary>
public string ShelfCode { get; set; } = string.Empty;
/// <summary>
/// AGV编号
/// </summary>
public string AgvCode { get; set; } = string.Empty;
/// <summary>
/// 任务发起人
/// </summary>
public string? CreateUser { get; set; }
/// <summary>
/// 任务创建时间
/// </summary>
public DateTime? CreateTime { get; set; } = DateTime.Now;
/// <summary>
/// 最后更新时间
/// </summary>
public DateTime? ModifyTime { get; set; } = DateTime.Now;
/// <summary>
/// 任务状态
/// </summary>
public TaskStatusEnum TaskStatus { get; set; } = TaskStatusEnum.;
#endregion
/// <summary>
/// 序号
/// </summary>
public int RowNumber { get; set; }
/// <summary>
/// 是否选择
/// </summary>
public bool IsSelected
{
get { return isSelected; }
set
{
isSelected = value;
OnPropertyChanged(nameof(IsSelected));
}
}
public bool isSelected;
public event PropertyChangedEventHandler PropertyChanged;
protected virtual void OnPropertyChanged(string propertyName)
{
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
}
}
}

View File

@ -0,0 +1,29 @@
using System;
using System.Collections.Generic;
using System.Text;
namespace WCS.Model.ApiModel.AGV
{
public class GetAGVTasksRequest : PageQueryRequestBase
{
public string ShelfCode { get; set; } = string.Empty;
public string CreateUser { get; set; } = string.Empty;
public string StartLocationCode { get; set; } = string.Empty;
public string EndLocationCode { get; set; } = string.Empty;
public TaskStatusEnum? TaskStatus { get; set; } = null;
}
//1-已创建2-正在执行5-取消完成9-已结束, 10-被打断
public enum TaskStatusEnum
{
= 1,
= 2,
= 5,
= 9,
= 10,
}
}

View File

@ -56,7 +56,7 @@ namespace WCS.WebApi.Controllers
} }
//判断并更新数据 //判断并更新数据
var shelf = await DbHelp.db.Queryable<ShelfInfo>().Where(t => t.ShelfCode == request.podCode || t.ShelfCode == task.ShlefCode) var shelf = await DbHelp.db.Queryable<ShelfInfo>().Where(t => t.ShelfCode == request.podCode || t.ShelfCode == task.ShelfCode)
.FirstAsync(); .FirstAsync();
if (shelf != null && request.method == "outbin") if (shelf != null && request.method == "outbin")
{ {
@ -67,6 +67,9 @@ namespace WCS.WebApi.Controllers
if (shelf != null && request.method == "end") if (shelf != null && request.method == "end")
{ {
task.TaskStatus = TaskStatusEnum.;
DbHelp.db.Updateable(task).ExecuteCommand();
shelf.CurrentLocationId = shelf.DestinationLocationId; shelf.CurrentLocationId = shelf.DestinationLocationId;
shelf.CurrentLocaiotnCode = shelf.DestinationLocaiotnCode; shelf.CurrentLocaiotnCode = shelf.DestinationLocaiotnCode;
shelf.DestinationLocationId = 0; shelf.DestinationLocationId = 0;

View File

@ -0,0 +1,85 @@
using Microsoft.AspNetCore.Mvc;
using Newtonsoft.Json;
using NPOI.SS.Formula.Functions;
using SqlSugar;
using WCS.BLL;
using WCS.BLL.DbModels;
using WCS.BLL.HardWare;
using WCS.BLL.Manager;
using WCS.BLL.Services.IService;
using WCS.BLL.Services.Service;
using WCS.DAL.Db;
using WCS.DAL.DbModels;
using WCS.Model;
using WCS.Model.ApiModel.AGV;
using WCS.Model.ApiModel.Home;
using WCS.Model.ApiModel.StoreInfo;
using Mode = WCS.BLL.HardWare.Mode;
namespace WCS.WebApi.Controllers
{
/// <summary>
/// 主页面的接口
/// </summary>
[ApiController]
[Route("[controller]")]
public class AgvTaskController : ControllerBase
{
public AgvTaskController()
{
}
/// <summary>
/// agv任务回调
/// </summary>
/// <param name="request"></param>
/// <returns></returns>
[Route("getAGVTasks")]
[HttpPost(Name = "getAGVTasks")]
public async Task<PageQueryResponse<AgvTask>> getAGVTasks(GetAGVTasksRequest request)
{
try
{
var recordsQueryable = DbHelp.db.Queryable<AgvTask>()
.WhereIF(string.IsNullOrEmpty(request.ShelfCode), t => t.ShelfCode.Contains(request.ShelfCode))
.WhereIF(string.IsNullOrEmpty(request.CreateUser), t => t.CreateUser.Contains(request.CreateUser))
.WhereIF(string.IsNullOrEmpty(request.StartLocationCode), t => t.StartLocationCode.Contains(request.StartLocationCode))
.WhereIF(string.IsNullOrEmpty(request.EndLocationCode), t => t.StartLocationCode.Contains(request.EndLocationCode))
.WhereIF(request.TaskStatus !=null, t => t.TaskStatus == request.TaskStatus);
var totalCount = await recordsQueryable.CountAsync();
var records = await recordsQueryable
.Skip((request.PageNumber - 1) * request.PageSize).Take(request.PageSize)
.ToListAsync();
//生成序号
for (int i = 0; i < records.Count; i++)
{
records[i].RowNumber = (request.PageNumber - 1) * request.PageSize + i + 1;
}
return new PageQueryResponse<AgvTask>()
{
Code = 200,
Message = $"success",
Data = new PageQueryResponseData<AgvTask>()
{
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<AgvTask>()
{
Code = 300,
Message = $"操作失败:{ex.Message}",
};
}
}
}
}

View File

@ -12,6 +12,8 @@ using WCS.Model.ApiModel;
using WCS.Model.ApiModel.MatBaseInfo; using WCS.Model.ApiModel.MatBaseInfo;
using System.Collections.ObjectModel; using System.Collections.ObjectModel;
using WCS.Model.ApiModel.Stocktaking; using WCS.Model.ApiModel.Stocktaking;
using System.Security.AccessControl;
using WCS.Model.ApiModel.AGV;
namespace .ViewModel namespace .ViewModel
{ {
@ -21,19 +23,19 @@ namespace 智慧物流软件系统.ViewModel
public AGVTaskViewModel() public AGVTaskViewModel()
{ {
//初始化下拉列表框 //初始化下拉列表框
StocktakingStatuses.Add("全部"); TaskStatus.Add("全部");
var statuses = Enum.GetValues(typeof(StocktakingStatusEnum)) var statuses = Enum.GetValues(typeof(TaskStatusEnum))
.Cast<StocktakingStatusEnum>() .Cast<TaskStatusEnum>()
.ToList(); .ToList();
foreach (var status in statuses) foreach (var status in statuses)
{ {
StocktakingStatuses.Add(status.ToString()); TaskStatus.Add(status.ToString());
} }
} }
#region Property #region Property
private ObservableCollection<MatDetailStocktakingInfoModel> dataGridItemSource; private ObservableCollection<AGVTaskModel> dataGridItemSource;
public ObservableCollection<MatDetailStocktakingInfoModel> DataGridItemSource public ObservableCollection<AGVTaskModel> DataGridItemSource
{ {
get { return dataGridItemSource; } get { return dataGridItemSource; }
set set
@ -42,8 +44,8 @@ namespace 智慧物流软件系统.ViewModel
} }
} }
public MatDetailStocktakingInfoModel selectedataGridItem; public AGVTaskModel selectedataGridItem;
public MatDetailStocktakingInfoModel SelectedataGridItem public AGVTaskModel SelectedataGridItem
{ {
get { return selectedataGridItem; } get { return selectedataGridItem; }
set set
@ -53,49 +55,62 @@ namespace 智慧物流软件系统.ViewModel
} }
/// <summary> /// <summary>
/// 物料编码 /// 货架编码
/// </summary> /// </summary>
private string matCode; private string shelfCode;
public string MatCode public string ShelfCode
{ {
get { return matCode; } get { return shelfCode; }
set set
{ {
SetProperty(ref matCode, value); SetProperty(ref shelfCode, value);
} }
} }
/// <summary> /// <summary>
/// 物料名称 /// 任务创建人
/// </summary> /// </summary>
private string matName; private string createUser;
public string MatName public string CreateUser
{ {
get { return matName; } get { return createUser; }
set set
{ {
SetProperty(ref matName, value); SetProperty(ref createUser, value);
} }
} }
/// <summary> /// <summary>
/// 盘点人 /// 起点
/// </summary> /// </summary>
private string stocktakingUser; private string startLocationCode;
public string StocktakingUser public string StartLocationCode
{ {
get { return stocktakingUser; } get { return startLocationCode; }
set set
{ {
SetProperty(ref stocktakingUser, value); SetProperty(ref startLocationCode, value);
} }
} }
/// <summary> /// <summary>
/// 盘点状态列表 /// 终点
/// </summary>
private string endLocationCode;
public string EndLocationCode
{
get { return endLocationCode; }
set
{
SetProperty(ref endLocationCode, value);
}
}
/// <summary>
/// 结束位置
/// </summary> /// </summary>
private List<string> stocktakingStatuses = new List<string>(); private List<string> stocktakingStatuses = new List<string>();
public List<string> StocktakingStatuses public List<string> TaskStatus
{ {
get { return stocktakingStatuses; } get { return stocktakingStatuses; }
set set
@ -104,26 +119,28 @@ namespace 智慧物流软件系统.ViewModel
} }
} }
private string selectedStocktakingStatus; private string selectedTaskStatus;
public string SelectedStocktakingStatus public string SelectedTaskStatus
{ {
get { return selectedStocktakingStatus; } get { return selectedTaskStatus; }
set set
{ {
SetProperty(ref selectedStocktakingStatus, value); SetProperty(ref selectedTaskStatus, value);
} }
} }
#endregion #endregion
#region Command #region Command
public ICommand BtnResetCommand { get => new DelegateCommand(BtnReset); } public ICommand BtnResetCommand { get => new DelegateCommand(BtnReset); }
public void BtnReset() public void BtnReset()
{ {
MatCode = string.Empty; ShelfCode = string.Empty;
MatName = string.Empty; CreateUser = string.Empty;
StocktakingUser = string.Empty;
SelectedStocktakingStatus = StocktakingStatuses.Where(t => t.Contains("未提交")).First(); StartLocationCode = string.Empty;
EndLocationCode = string.Empty;
SelectedTaskStatus = TaskStatus.Where(t => t.Contains("正在执行")).First();
} }
public ICommand BtnSearchCommand { get => new DelegateCommand(BtnSearchReset); } public ICommand BtnSearchCommand { get => new DelegateCommand(BtnSearchReset); }
@ -138,17 +155,20 @@ namespace 智慧物流软件系统.ViewModel
CurrentPage = 1; CurrentPage = 1;
return; return;
} }
var isSelected = Enum.TryParse<StocktakingStatusEnum>(SelectedStocktakingStatus, out StocktakingStatusEnum status);
var isSelected = Enum.TryParse<TaskStatusEnum>(SelectedTaskStatus, out TaskStatusEnum status);
#region #region
var dia = Dialog.Show(new TextDialog()); var dia = Dialog.Show(new TextDialog());
try try
{ {
var body = new GetStocktakingInfosRequest() var body = new GetAGVTasksRequest()
{ {
MatCode = MatCode, ShelfCode = ShelfCode,
MatName = MatName, StartLocationCode = StartLocationCode,
StocktakingUser = StocktakingUser, EndLocationCode = EndLocationCode,
StocktakingStatus = isSelected ? status : null, CreateUser = CreateUser,
TaskStatus = isSelected ? status : null,
UserName = LocalStatic.CurrentUser, UserName = LocalStatic.CurrentUser,
DeviceType = LocalFile.Config.DeviceType, DeviceType = LocalFile.Config.DeviceType,
@ -156,10 +176,10 @@ namespace 智慧物流软件系统.ViewModel
PageSize = PageSize, PageSize = PageSize,
}; };
var Result = ApiHelp.GetDataFromHttp<PageQueryResponse<MatDetailStocktakingInfoModel>>(LocalFile.Config.ApiIpHost + "PDAStocktaking/getStocktakingInfos", body, "POST"); var Result = ApiHelp.GetDataFromHttp<PageQueryResponse<AGVTaskModel>>(LocalFile.Config.ApiIpHost + "AgvTask/getAGVTasks", body, "POST");
if (Result != null && Result.Data != null && Result.Data.Lists != null) if (Result != null && Result.Data != null && Result.Data.Lists != null)
{ {
DataGridItemSource = new ObservableCollection<MatDetailStocktakingInfoModel>(Result.Data.Lists); DataGridItemSource = new ObservableCollection<AGVTaskModel>(Result.Data.Lists);
MaxPage = Result.Data.MaxPage; MaxPage = Result.Data.MaxPage;
TotalCount = Result.Data.TotalCount; TotalCount = Result.Data.TotalCount;
} }
@ -224,39 +244,39 @@ namespace 智慧物流软件系统.ViewModel
public ICommand BtnEditCommand { get => new DelegateCommand(BtnEdit); } public ICommand BtnEditCommand { get => new DelegateCommand(BtnEdit); }
public async void BtnEdit() public async void BtnEdit()
{ {
//查询勾选的第一个数据 ////查询勾选的第一个数据
var matDetailStocktakingInfo = DataGridItemSource?.Where(t => t.IsSelected == true).FirstOrDefault(); //var matDetailStocktakingInfo = DataGridItemSource?.Where(t => t.IsSelected == true).FirstOrDefault();
if (matDetailStocktakingInfo == null) //if (matDetailStocktakingInfo == null)
{ //{
Growl.Warning("请选择需要修改的数据!"); // Growl.Warning("请选择需要修改的数据!");
return; // return;
} //}
else //else
{ //{
var updateView = new MatDetailStocktakingInfoUpdateView("修改盘点数据", matDetailStocktakingInfo); // var updateView = new MatDetailStocktakingInfoUpdateView("修改盘点数据", matDetailStocktakingInfo);
updateView.ShowDialog(); // updateView.ShowDialog();
if (updateView.DialogResult == true) // if (updateView.DialogResult == true)
{ // {
matDetailStocktakingInfo = updateView.matDetailStocktakingInfo; // matDetailStocktakingInfo = updateView.matDetailStocktakingInfo;
var body = new UpdateStocktakingInfoRequest() // var body = new UpdateStocktakingInfoRequest()
{ // {
MatDetailStocktakingInfoId = matDetailStocktakingInfo.Id, // MatDetailStocktakingInfoId = matDetailStocktakingInfo.Id,
StocktakingQty = matDetailStocktakingInfo.StocktakingQty, // StocktakingQty = matDetailStocktakingInfo.StocktakingQty,
UserName = LocalStatic.CurrentUser, // UserName = LocalStatic.CurrentUser,
DeviceType = LocalFile.Config.DeviceType, // DeviceType = LocalFile.Config.DeviceType,
}; // };
var Result = ApiHelp.GetDataFromHttp<ResponseBase<object>>(LocalFile.Config.ApiIpHost + "PDAStocktaking/updateStocktakingInfos", body, "POST"); // var Result = ApiHelp.GetDataFromHttp<ResponseBase<object>>(LocalFile.Config.ApiIpHost + "PDAStocktaking/updateStocktakingInfos", body, "POST");
if (Result != null && Result.Code == 200) // if (Result != null && Result.Code == 200)
{ // {
CurrentPage = 1; // CurrentPage = 1;
Growl.Success("修改成功!"); // Growl.Success("修改成功!");
} // }
else // else
{ // {
Growl.Error($"{Result?.Message?.ToString()}"); // Growl.Error($"{Result?.Message?.ToString()}");
} // }
} // }
} //}
} }
/// <summary> /// <summary>

View File

@ -15,8 +15,8 @@
Padding="0"> Padding="0">
<Grid> <Grid>
<Grid.RowDefinitions> <Grid.RowDefinitions>
<RowDefinition Height="1*"></RowDefinition> <RowDefinition Height="2*"></RowDefinition>
<RowDefinition Height="10*"></RowDefinition> <RowDefinition Height="12*"></RowDefinition>
</Grid.RowDefinitions> </Grid.RowDefinitions>
<Border Grid.Row="0" <Border Grid.Row="0"
Margin="5 5 5 0" Margin="5 5 5 0"
@ -25,42 +25,64 @@
Padding="0"> Padding="0">
<Grid> <Grid>
<Grid.ColumnDefinitions> <Grid.ColumnDefinitions>
<ColumnDefinition Width="1.9*"></ColumnDefinition>
<ColumnDefinition Width="2*"></ColumnDefinition> <ColumnDefinition Width="2*"></ColumnDefinition>
<ColumnDefinition Width="1.9*"></ColumnDefinition>
<ColumnDefinition Width="2*"></ColumnDefinition> <ColumnDefinition Width="2*"></ColumnDefinition>
<ColumnDefinition Width="1.9*"></ColumnDefinition>
<ColumnDefinition Width="2*"></ColumnDefinition> <ColumnDefinition Width="2*"></ColumnDefinition>
<ColumnDefinition Width="1.9*"></ColumnDefinition> <ColumnDefinition Width="2.2*"></ColumnDefinition>
<ColumnDefinition Width="1.8*"></ColumnDefinition>
<ColumnDefinition Width="2*"></ColumnDefinition>
<ColumnDefinition Width="1.8*"></ColumnDefinition>
<ColumnDefinition Width="2*"></ColumnDefinition> <ColumnDefinition Width="2*"></ColumnDefinition>
<ColumnDefinition Width="2*"></ColumnDefinition> <ColumnDefinition Width="2*"></ColumnDefinition>
<ColumnDefinition Width="2*"></ColumnDefinition> <ColumnDefinition Width="2*"></ColumnDefinition>
<ColumnDefinition Width="2*"></ColumnDefinition> <ColumnDefinition Width="2*"></ColumnDefinition>
</Grid.ColumnDefinitions> </Grid.ColumnDefinitions>
<TextBlock Grid.Column="2" <Grid.RowDefinitions>
VerticalAlignment="Center" <RowDefinition></RowDefinition>
HorizontalAlignment="Right" <RowDefinition></RowDefinition>
Text="盘点状态:" </Grid.RowDefinitions>
FontSize="18"></TextBlock>
<ComboBox Grid.Column="3"
VerticalAlignment="Center"
HorizontalAlignment="Stretch"
FontSize="18"
MinWidth="90"
ItemsSource="{Binding StocktakingStatuses}"
SelectedValue="{Binding SelectedStocktakingStatus}">
</ComboBox>
<TextBlock Grid.Column="0" <TextBlock Grid.Column="0"
VerticalAlignment="Center" VerticalAlignment="Center"
HorizontalAlignment="Right" HorizontalAlignment="Right"
Text="物料编码:" Text="货架编码:"
FontSize="18"></TextBlock> FontSize="18"></TextBlock>
<TextBox Grid.Column="1" <TextBox Grid.Column="1"
VerticalAlignment="Center" VerticalAlignment="Center"
HorizontalAlignment="Stretch" HorizontalAlignment="Stretch"
FontSize="18" FontSize="18"
MinWidth="90" MinWidth="90"
Text="{Binding MatCode}"></TextBox> Text="{Binding ShelfCode}"></TextBox>
<TextBlock Grid.Column="0"
Grid.Row="1"
VerticalAlignment="Center"
HorizontalAlignment="Right"
Text="创建人:"
FontSize="18"></TextBlock>
<TextBox Grid.Column="1"
Grid.Row="1"
VerticalAlignment="Center"
HorizontalAlignment="Stretch"
FontSize="18"
MinWidth="90"
Text="{Binding CreateUser}"
></TextBox>
<TextBlock Grid.Column="2"
VerticalAlignment="Center"
HorizontalAlignment="Right"
Text="任务状态:"
FontSize="18"></TextBlock>
<ComboBox Grid.Column="3"
VerticalAlignment="Center"
HorizontalAlignment="Stretch"
FontSize="18"
MinWidth="90"
ItemsSource="{Binding TaskStatus}"
SelectedValue="{Binding SelectedTaskStatus}">
</ComboBox>
<TextBlock Grid.Column="4" <TextBlock Grid.Column="4"
VerticalAlignment="Center" VerticalAlignment="Center"
HorizontalAlignment="Right" HorizontalAlignment="Right"
@ -71,7 +93,8 @@
HorizontalAlignment="Stretch" HorizontalAlignment="Stretch"
FontSize="18" FontSize="18"
MinWidth="90" MinWidth="90"
Text="{Binding StartPoint}"></TextBox> Text="{Binding StartLocationCode}"></TextBox>
<TextBlock Grid.Column="6" <TextBlock Grid.Column="6"
VerticalAlignment="Center" VerticalAlignment="Center"
HorizontalAlignment="Right" HorizontalAlignment="Right"
@ -83,8 +106,8 @@
HorizontalAlignment="Stretch" HorizontalAlignment="Stretch"
FontSize="18" FontSize="18"
MinWidth="90" MinWidth="90"
Text="{Binding EndPoint}"></TextBox> Text="{Binding EndLocationCode}"></TextBox>
<Button Style="{StaticResource ButtonSuccess}" <Button Style="{StaticResource ButtonSuccess}"
hc:BorderElement.CornerRadius="15" hc:BorderElement.CornerRadius="15"
Grid.Column="9" Grid.Column="9"
@ -119,23 +142,16 @@
<Button MinHeight="40" <Button MinHeight="40"
FontSize="18" FontSize="18"
Margin="5" Margin="5"
Content="&#xe604;提 交" Content="&#xe652;重新下发"
FontFamily="{StaticResource IconFont}" FontFamily="{StaticResource IconFont}"
Foreground="WhiteSmoke" Foreground="WhiteSmoke"
Background="HotPink" Background="Green"
Command="{Binding BtnCommitCommand}"></Button> Command="{Binding BtnCommitCommand}"></Button>
<Button MinHeight="40" <Button MinHeight="40"
FontSize="18" FontSize="18"
Margin="5" Margin="5"
Content="&#xe612;修 " Content="&#xe64c;取 "
FontFamily="{StaticResource IconFont}"
Foreground="WhiteSmoke"
Background="CadetBlue"
Command="{Binding BtnEditCommand}"></Button>
<Button MinHeight="40"
FontSize="18"
Margin="5"
Content="&#xe8c1;删 除"
FontFamily="{StaticResource IconFont}" FontFamily="{StaticResource IconFont}"
Foreground="WhiteSmoke" Foreground="WhiteSmoke"
Command="{Binding BtnDeleteCommand}" Command="{Binding BtnDeleteCommand}"
@ -173,31 +189,27 @@
<DataGridTextColumn IsReadOnly="True" <DataGridTextColumn IsReadOnly="True"
Header="序号" Header="序号"
Binding="{Binding RowNumber}"></DataGridTextColumn> Binding="{Binding RowNumber}"></DataGridTextColumn>
<DataGridTextColumn Header="物料编码" <DataGridTextColumn Header="任务单号"
Binding="{Binding MatCode}"></DataGridTextColumn> Binding="{Binding TaskCode}"></DataGridTextColumn>
<DataGridTextColumn Header="物料名称"
MaxWidth="150" <DataGridTextColumn Header="任务状态"
Binding="{Binding MatName}"></DataGridTextColumn> Binding="{Binding TaskStatus}"></DataGridTextColumn>
<DataGridTextColumn Header="物料规格" <DataGridTextColumn IsReadOnly="True"
MaxWidth="150" Header="最后更新时间"
Binding="{Binding MatSpec}"></DataGridTextColumn> Binding="{Binding ModifyTime ,StringFormat='yyyy-MM-dd HH:mm:ss'}"></DataGridTextColumn>
<DataGridTextColumn Header="货架编号"
<DataGridTextColumn Header="货架编码"
Binding="{Binding ShelfCode}"></DataGridTextColumn> Binding="{Binding ShelfCode}"></DataGridTextColumn>
<DataGridTextColumn Header="货架区域" <DataGridTextColumn Header="起点"
Binding="{Binding ShelfArea}"></DataGridTextColumn> Binding="{Binding StartLocationCode}"></DataGridTextColumn>
<DataGridTextColumn Header="原数量" <DataGridTextColumn Header="终点"
Binding="{Binding MatQty}"></DataGridTextColumn> Binding="{Binding EndLocationCode}"></DataGridTextColumn>
<DataGridTextColumn Header="盘点数量"
Binding="{Binding StocktakingQty}"></DataGridTextColumn>
<DataGridTextColumn IsReadOnly="True" <DataGridTextColumn IsReadOnly="True"
Header="盘点人" Header="创建人"
Binding="{Binding StocktakingUser}"></DataGridTextColumn> Binding="{Binding CreateUser}"></DataGridTextColumn>
<DataGridTextColumn IsReadOnly="True" <DataGridTextColumn IsReadOnly="True"
Header="盘点时间" Header="创建时间"
Binding="{Binding StocktakingTime ,StringFormat='yyyy-MM-dd HH:mm:ss'}"></DataGridTextColumn> Binding="{Binding CreateTime ,StringFormat='yyyy-MM-dd HH:mm:ss'}"></DataGridTextColumn>
<DataGridTextColumn IsReadOnly="True"
Header="盘点状态"
Binding="{Binding StocktakingStatus}"></DataGridTextColumn>
</DataGrid.Columns> </DataGrid.Columns>
</DataGrid> </DataGrid>
<Grid Grid.Row="2"> <Grid Grid.Row="2">
@ -316,94 +328,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="&#xe866; 导 出" 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>

View File

@ -18,7 +18,7 @@ namespace 智慧物流软件系统
{ {
public partial class AGVTaskView : UserControlBase public partial class AGVTaskView : UserControlBase
{ {
public MatDetailStocktakingInfoViewModel viewModel { get; set; } = new MatDetailStocktakingInfoViewModel(); public AGVTaskViewModel viewModel { get; set; } = new AGVTaskViewModel();
public AGVTaskView() public AGVTaskView()
{ {
InitializeComponent(); InitializeComponent();