|
|
using ICSharpCode.Core;
|
|
|
using Mesnac.Action.Base;
|
|
|
using Mesnac.Action.ChemicalWeighing.Entity;
|
|
|
using Mesnac.Codd.Session;
|
|
|
using System;
|
|
|
using System.Collections.Generic;
|
|
|
using System.Data;
|
|
|
using System.Linq;
|
|
|
using System.Text;
|
|
|
using System.Threading.Tasks;
|
|
|
using System.Windows.Forms;
|
|
|
|
|
|
namespace Mesnac.Action.ChemicalWeighing.Technical.XlRecipe
|
|
|
{
|
|
|
public class DelMaterialAction : ChemicalWeighingAction, IAction
|
|
|
{
|
|
|
#region 事件定义
|
|
|
|
|
|
/// <summary>
|
|
|
/// 删除配方事件定义
|
|
|
/// </summary>
|
|
|
public static event EventHandler OnDelMaterial;
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region 字段定义
|
|
|
|
|
|
private RuntimeParameter _runtime;
|
|
|
private DbMCControl _clientGridControl = null;
|
|
|
private DbMCControl _weighGridControl = null;
|
|
|
#endregion
|
|
|
|
|
|
#region IAction接口实现
|
|
|
|
|
|
public void Run(RuntimeParameter runtime)
|
|
|
{
|
|
|
base.RunIni(runtime);
|
|
|
this._runtime = runtime;
|
|
|
|
|
|
ICSharpCode.Core.LoggingService<DeleteAction>.Debug("配方管理—删除配方物料业务...");
|
|
|
|
|
|
DbMCControl clientGridControl = this.GetDbMCControlByKey(Mesnac.Basic.DataSourceFactory.MCDbType.Local, "xl_recipe").FirstOrDefault();
|
|
|
if (clientGridControl == null || !(clientGridControl.BaseControl is DataGridView))
|
|
|
{
|
|
|
ICSharpCode.Core.LoggingService<RefreshAction>.Error("{配方管理—删除配方物料}缺少配方管理控件...");
|
|
|
return;
|
|
|
}
|
|
|
this._clientGridControl = clientGridControl;
|
|
|
|
|
|
DbMCControl weighGridControl = this.GetDbMCControlByKey(Mesnac.Basic.DataSourceFactory.MCDbType.Local, "xl_weigh").FirstOrDefault();
|
|
|
if (weighGridControl == null || !(weighGridControl.BaseControl is DataGridView))
|
|
|
{
|
|
|
ICSharpCode.Core.LoggingService<RefreshAction>.Error("{配方管理—删除配方物料}缺少配方管理控件...");
|
|
|
return;
|
|
|
}
|
|
|
this._weighGridControl = weighGridControl;
|
|
|
this.DoWork();
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region 方法定义
|
|
|
|
|
|
/// <summary>
|
|
|
/// 删除计划
|
|
|
/// </summary>
|
|
|
protected void DoWork()
|
|
|
{
|
|
|
this._runtime.BaseControl.MCEnabled = false;
|
|
|
|
|
|
try
|
|
|
{
|
|
|
DataGridView clientGridView = this._clientGridControl.BaseControl as DataGridView;
|
|
|
DataGridView weighGridView = this._weighGridControl.BaseControl as DataGridView;
|
|
|
|
|
|
#region 1 变量定义
|
|
|
|
|
|
string selectRecipeName = null;
|
|
|
string selectRecipeID = string.Empty;
|
|
|
xl_recipe pmt_Recipe = null;
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region 2 判断是否选择了要修改的配方
|
|
|
|
|
|
if (clientGridView.SelectedRows.Count != 1)
|
|
|
{
|
|
|
MessageBox.Show("请选择一条要删除的配方!", Mesnac.Basic.LanguageHelper.Caption, MessageBoxButtons.OK, MessageBoxIcon.Information);
|
|
|
this._runtime.IsReturn = true;
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region 3 判断该配方是否可进行删除(如果配方正在RT_Plan表中,查不允许删除)
|
|
|
|
|
|
|
|
|
selectRecipeName = clientGridView.SelectedRows[0].Cells["Recipe_Name"].Value as string;
|
|
|
selectRecipeID = clientGridView.SelectedRows[0].Cells["ID"].Value as string;
|
|
|
|
|
|
string selectMaterName = weighGridView.SelectedRows[0].Cells["Material_Name"].Value as string;
|
|
|
|
|
|
if (Product.XlPlan.PlanHelper.PlanExistsRecipeName(selectRecipeID))
|
|
|
{
|
|
|
MessageBox.Show("该配方正在计划列表中,不能进行删除!", Mesnac.Basic.LanguageHelper.Caption, MessageBoxButtons.OK, MessageBoxIcon.Information);
|
|
|
this._runtime.IsReturn = true;
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
//删除配方前询问
|
|
|
string msg1 = "确认删除当前物料(物料名:{0})吗?"; //确认删除当前配方(配方名:{0})吗?
|
|
|
msg1 = String.Format(msg1, selectMaterName);
|
|
|
DialogResult result = MessageBox.Show(msg1, Mesnac.Basic.LanguageHelper.Caption, MessageBoxButtons.YesNo, MessageBoxIcon.Question);
|
|
|
if (result == DialogResult.Yes)
|
|
|
{
|
|
|
#region 4 获取配方实体
|
|
|
|
|
|
pmt_Recipe = RecipeHelper.GetRecipeByName(selectRecipeID);
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region 5 执行删除操作
|
|
|
|
|
|
if (pmt_Recipe != null)
|
|
|
{
|
|
|
#region 5.1 删除配方信息
|
|
|
var Id = weighGridView.SelectedRows[0].Cells["ID"].Value;
|
|
|
if (!string.IsNullOrEmpty(Id.ToString()))
|
|
|
{
|
|
|
RecipeHelper.DeleteRecipematerial(Id.ToString());
|
|
|
|
|
|
var wList = Product.XlPlan.PlanHelper.Getxl_weighList(pmt_Recipe.ID);
|
|
|
decimal totalError = wList.Sum(d => d.Set_Error);
|
|
|
decimal totalWeigh = wList.Sum(d => d.Set_Weight);
|
|
|
UpdateError(pmt_Recipe.ID, totalWeigh, totalError);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region 5.2 删除配方对应物料信息
|
|
|
|
|
|
//RecipeHelper.DelWeighByRecipeID(pmt_Recipe.ID);
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region 5.3 触发事件
|
|
|
|
|
|
if (OnDelMaterial != null)
|
|
|
{
|
|
|
OnDelMaterial(this._runtime.BaseControl.MCRoot, System.EventArgs.Empty);
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
MessageBox.Show("配方物料删除成功!");
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
}
|
|
|
|
|
|
}
|
|
|
catch (Exception ex)
|
|
|
{
|
|
|
ICSharpCode.Core.LoggingService<InsertAction>.Error("配方物料异常:" + ex.Message, ex);
|
|
|
|
|
|
#region 记录操作日志
|
|
|
|
|
|
base.DBLog(ex.Message);
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
MessageBox.Show(ex.Message, Mesnac.Basic.LanguageHelper.WarnCaption, MessageBoxButtons.OK, MessageBoxIcon.Warning);
|
|
|
}
|
|
|
finally
|
|
|
{
|
|
|
this._runtime.BaseControl.MCEnabled = true;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region 更新配方误差
|
|
|
|
|
|
/// <summary>
|
|
|
/// 删除配方的物料信息
|
|
|
/// </summary>
|
|
|
/// <param name="recipeID">配方ID</param>
|
|
|
public static void UpdateError(string Id, decimal totalWeigh, decimal Set_Error)
|
|
|
{
|
|
|
DbHelper dbHelper = Mesnac.Basic.DataSourceFactory.Instance.GetDbHelper(Mesnac.Basic.DataSourceFactory.MCDbType.Local);
|
|
|
if (dbHelper == null)
|
|
|
{
|
|
|
throw new Exception(Mesnac.Basic.LanguageHelper.DataBaseConnectError);
|
|
|
}
|
|
|
dbHelper.CommandType = CommandType.Text;
|
|
|
string sqlstr = String.Empty;
|
|
|
//添加新配方
|
|
|
sqlstr = @" update xl_recipe set Total_Weight=@TotalWeight,Total_Error=@Error where ID=@Id";
|
|
|
|
|
|
dbHelper.ClearParameter();
|
|
|
dbHelper.CommandText = sqlstr;
|
|
|
dbHelper.AddParameter("@TotalWeight", totalWeigh);
|
|
|
dbHelper.AddParameter("@Error", Set_Error);
|
|
|
dbHelper.AddParameter("@Id", Id);
|
|
|
dbHelper.ExecuteNonQuery();
|
|
|
}
|
|
|
#endregion
|
|
|
}
|
|
|
|
|
|
|
|
|
}
|