You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

523 lines
19 KiB

using NFine.Data.Extensions;
using System;
using System.Collections.Generic;
using System.Data;
using System.Text;
using NFine.Code;
using NFine.Repository;
using System.Data.Common;
using NFine.Domain._03_Entity.SRM;
using Newtonsoft.Json;
using System.Configuration;
using System.Net;
using System.IO;
using Newtonsoft.Json.Linq;
using System.Linq;
namespace NFine.Application.OMAY
{
public class OMAYApsApp : RepositoryFactory<ICSVendor>
{
public DataTable GetGridJsonChengPing(string queryJson, ref Pagination jqgridparam)
{
DataTable dt = new DataTable();
var queryParam = queryJson.ToJObject();
List<DbParameter> parameter = new List<DbParameter>();
//object Figure = GetDecimalDigits();
#region [SQL]
string sql = @" select
a.*
from
(
select '' isSelect
,a.ID
,a.EATTRIBUTE5 as PreOrderNo --预订单号
,a.EATTRIBUTE6 as BusinessName --业务员
,a.MOCode
,a.Sequence MoSeq
,a.MODetailID
,a.EATTRIBUTE1 MoTypeValue
,a.DepCode
,b.DepName --生产部门
,a.CreateDateTime --生产日期
,a.EATTRIBUTE3 PackageAsk --包装要求
,a.EATTRIBUTE4 SpecialAsk--特殊要求
,a.EATTRIBUTE2 Useage--用途
,a.InvCode ItemCode
,c.EATTRIBUTE2 ItemAddCode
,c.InvName ItemName
,c.InvStd ItemStd
,c.InvUnit ItemUnit
,a.Amount
,CONVERT(varchar(10), a.StartDate,120) StartDate
,CONVERT(varchar(10), a.DueDate,120) DueDate
,case when a.PlanStartDate is null then CONVERT(varchar(10), a.StartDate,120)
else CONVERT(varchar(10), a.PlanStartDate,120) end as PlanStartDate
,case when a.PlanEndDate is null then CONVERT(varchar(10), a.DueDate,120)
else CONVERT(varchar(10), a.PlanEndDate,120) end as PlanEndDate
,a.ApsOrderDate
,a.APSStatus
from ICSMO a with(nolock)
left join ICSDepartment b with(nolock) on a.DepCode=b.DepCode
left join ICSInventory c with(nolock) on a.InvCode=c.InvCode
where 1=1
<1>
--order by a.CreateDateTime desc
) a
where 1=1
";
// sql += " WHERE 1=1 and a.MOStatus<>'3' ";
//sql = string.Format(sql, Figure);
//sql = string.Format(sql, DbHelper.GetErpIp(), DbHelper.GetErpName());
#endregion
if (!string.IsNullOrWhiteSpace(queryJson))
{
if (!string.IsNullOrWhiteSpace(queryParam["ItemCode"].ToString()))
{
sql += " and a.ItemCode like '%" + queryParam["ItemCode"].ToString() + "%' ";
}
if (!string.IsNullOrWhiteSpace(queryParam["ItemName"].ToString()))
{
sql += " and a.ItemName like '%" + queryParam["ItemName"].ToString() + "%' ";
}
var ssName1 = queryParam["SSName"].ToString();
var ssName2 = queryParam["SSName2"].ToString();
if (string.IsNullOrEmpty(ssName1)&& string.IsNullOrEmpty(ssName2))
{
sql = sql.Replace("<1>", "and a.APSStatus is null ");
}
else
{
if(!string.IsNullOrEmpty(ssName1) && !string.IsNullOrEmpty(ssName2))
{
sql += " and a.DepName ='" + ssName1 + "' and a.APSStatus='Y' ";
sql = sql.Replace("<1>", " ");
}
if (!string.IsNullOrEmpty(ssName1))
{
sql += " and a.DepName ='" + ssName1 + "' and a.APSStatus='Y' ";
sql = sql.Replace("<1>", " ");
}
if (!string.IsNullOrEmpty(ssName2))
{
sql += " and a.DepName ='" + ssName2 + "' ";
sql = sql.Replace("<1>", " and a.APSStatus is null ");
}
}
//if (!string.IsNullOrWhiteSpace(queryParam["SSName"].ToString()))
//{
// sql += " and a.DepName ='"+ queryParam["SSName"].ToString() + "' and a.APSStatus='Y' ";
// sql = sql.Replace("<1>", " ");
//}
//else
//{
// sql = sql.Replace("<1>", "and a.APSStatus is null ");
//}
}
//if (NFine.Code.OperatorProvider.Provider.GetCurrent().RoleEnCode != "admin")
//{
// sql = sql.Replace("{0}", "and a.WorkPoint = '" + NFine.Code.OperatorProvider.Provider.GetCurrent().Location + "'");
// // sql += " and a.WorkPoint='" + NFine.Code.OperatorProvider.Provider.GetCurrent().Location + "'";
//}
//else
//{
// sql = sql.Replace("{0}", "");
//}
//if (NFine.Code.OperatorProvider.Provider.GetCurrent().RoleEnCode == "Vendor")
//{
// sql += " and a.VenCode='" + NFine.Code.OperatorProvider.Provider.GetCurrent().UserCode + "'";
//}
return Repository().FindTablePageBySql(sql.ToString(), parameter.ToArray(), ref jqgridparam);
}
public string GetOrgAName()
{
string returnValue = string.Empty;
string sql = @"select
b.F_FullName as OrgName
,b.F_EnCode as OrgCode
,a.*
from [dbo].[Sys_SRM_Role] a
left join Sys_SRM_Organize b on a.F_OrganizeId=b.F_Id
where 1=1
and a.F_EnCode='{0}'
";
sql = string.Format(sql, NFine.Code.OperatorProvider.Provider.GetCurrent().RoleEnCode);
var dt = Repository().FindDataSetBySql(sql.ToString()).Tables[0];
if (dt == null || dt.Rows.Count == 0)
{
return returnValue;
}
returnValue = dt.Rows[0]["OrgName"].ToStringExt();
return returnValue;
}
public string UpdateMoPlan2(string keyValue)
{
string returnValue = string.Empty;
var queryParam = keyValue.ToJObject();
string MUSER = NFine.Code.OperatorProvider.Provider.GetCurrent().UserCode;
string MUSERNAME = NFine.Code.OperatorProvider.Provider.GetCurrent().UserName;
string WorkPoint = NFine.Code.OperatorProvider.Provider.GetCurrent().Location;
string sql = string.Empty;
sql = @"
UPDATE dbo.ICSMO set MTIME=GETDATE(),MUSER='{0}',WorkPoint='{1}'
<1>
<2>
<3>
WHERE ID in ('{2}')";
var ids = queryParam["ids"].ToString().Split(',');
sql = string.Format(sql, MUSER, WorkPoint, string.Join("','", ids));
if (!string.IsNullOrEmpty(queryParam["orderDate"].ToString()))
{
sql = sql.Replace("<1>", ",ApsOrderDate='"+ queryParam["orderDate"].ToString() + "'");
}
if (!string.IsNullOrEmpty(queryParam["planStartDate"].ToString()))
{
sql = sql.Replace("<2>", ",planStartDate='"+ queryParam["planStartDate"].ToString() + "'");
}
if (!string.IsNullOrEmpty(queryParam["planEndDate"].ToString()))
{
sql = sql.Replace("<3>", ",planEndDate='" + queryParam["planEndDate"].ToString() + "'");
}
var rows = SqlHelper.CmdExecuteNonQueryLi(sql) > 0;
if (!rows)
{
throw new Exception("修改失败");
}
return returnValue;
}
public string UpdateMoPlan(string keyValue)
{
string returnValue = string.Empty;
var queryParam = keyValue.ToJObject();
var isCanUpdateStatus = queryParam["isCanUpdateStatus"].ToBool();
string MUSER = NFine.Code.OperatorProvider.Provider.GetCurrent().UserCode;
string MUSERNAME = NFine.Code.OperatorProvider.Provider.GetCurrent().UserName;
string WorkPoint = NFine.Code.OperatorProvider.Provider.GetCurrent().Location;
string sql = string.Empty;
sql = @"
declare @DepCode nvarchar(100)
select @DepCode= DepCode from ICSDepartment
where DepName='{0}'
--select @DepCode
UPDATE dbo.ICSMO set DepCode=@DepCode, MTIME=GETDATE(),MUSER='{1}',WorkPoint='{2}',APSStatus='Y' <1> <2> <3> WHERE ID in ('{3}')";
var ids = queryParam["ids"].ToString().Split(',');
string APIURL = ConfigurationManager.ConnectionStrings["ERPAPIURL"].ConnectionString + "MOHKWam/Update";
var planStartDate = queryParam["planStartDate"].ToStringExt();
var planEndDate = queryParam["planEndDate"].ToStringExt();
sql = string.Format(sql, queryParam["line"].ToString(), MUSER, WorkPoint, string.Join("','", ids), queryParam["orderDate"].ToString());
if (!string.IsNullOrEmpty(queryParam["orderDate"].ToString()))
{
sql= sql.Replace("<1>", ",ApsOrderDate='"+ queryParam["orderDate"].ToString() + "' ");
}
else
{
sql=sql.Replace("<1>", ",ApsOrderDate=getdate()");
}
if (!string.IsNullOrEmpty(planStartDate))
{
sql = sql.Replace("<2>", ",PlanStartDate='" + planStartDate + "'");
}
else
{
sql = sql.Replace("<2>", " ,PlanStartDate=StartDate");
}
if (!string.IsNullOrEmpty(planEndDate))
{
sql = sql.Replace("<3>", ",PlanEndDate='" + planEndDate + "'");
}
else
{
sql = sql.Replace("<3>", " ,PlanEndDate=DueDate");
}
//string sql11 = @"select a.* from ICSMO a where a.ID in ('0')";
//sql11 = string.Format(sql11, string.Join("','", ids));
//var dt11 = Repository().FindDataSetBySql(sql11.ToString()).Tables[0];
//if (dt11 == null || dt11.Rows.Count == 0)
//{
// throw new Exception("获取工单数据失败");
//}
//foreach (DataRow item in dt11.Rows)
//{
//}
try
{
string sql3 = @"
declare @DepCode nvarchar(100)
select @DepCode= DepCode from ICSDepartment
where DepName='{0}'
select @DepCode as DepCode ";
sql3 = string.Format(sql3, queryParam["line"].ToString());
var dt5 = Repository().FindDataSetBySql(sql3.ToString()).Tables[0];
if (dt5 == null || dt5.Rows.Count == 0)
{
throw new Exception("当前部门获取失败");
}
var deptCode = dt5.Rows[0]["DepCode"].ToString();
if (!isCanUpdateStatus)
{
sql = sql.Replace(",APSStatus='Y'", " ");
//var rows2 = SqlHelper.CmdExecuteNonQueryLi(sql) > 0;
//if (!rows2)
//{
// throw new Exception("修改失败");
//}
//return returnValue;
}
string objsql = @"
declare @WorkPointCode varchar(100)
select @WorkPointCode=WorkPointCode from Sys_WorkPoint
select
@WorkPointCode as WorkPoint
,a.MODetailID as MoDid
,CONVERT(varchar(10), a.StartDate,120) StartDate
,CONVERT(varchar(10), a.DueDate,120) DueDate
,a.DepCode cDept
from ICSMO a with(nolock)
where a.ID in ('{0}')
";
objsql = string.Format(objsql, string.Join("','", ids));
var dt = Repository().FindDataSetBySql(objsql.ToString()).Tables[0];
if (dt == null || dt.Rows.Count == 0)
{
return returnValue;
}
List<object> objList = new List<object>();
foreach (DataRow item in dt.Rows)
{
if (!string.IsNullOrEmpty(planStartDate))
{
}
object obj = new
{
WorkPoint = item["WorkPoint"].ToString(),
MoDid = item["MoDid"].ToString(),
StartDate =string.IsNullOrEmpty( planStartDate)? item["StartDate"].ToString(): planStartDate,
DueDate = string.IsNullOrEmpty(planEndDate) ? item["DueDate"].ToString() : planEndDate,
cDept = deptCode,
};
objList.Add(obj);
}
var result = HttpMethods.Post<ResultDto>(APIURL, objList).Result;
if (!result.Success)
{
return result.Message;
}
var rows = SqlHelper.CmdExecuteNonQueryLi(sql) > 0;
if (!rows)
{
throw new Exception("修改失败");
}
}
catch (Exception ex)
{
returnValue = ex.Message;
}
return returnValue;
}
public DataTable GetApsPlanSelectSubItemList(string ids, ref Pagination pagination)
{
DataTable dt = new DataTable();
// var queryParam = queryJson.ToJObject();
List<DbParameter> parameter = new List<DbParameter>();
//object Figure = GetDecimalDigits();
#region [SQL]
string sql = @"select
a.SubItemCode,a.SubItemName,a.SubItemStd,a.InvUnit,a.AmountUnit
,sum( a.Quantity) Quantity
,sum( a.Amount) Amount
,max(a.ID) ID
from
(
select 0 Code
--a.*
,a.ID
,c.InvCode SubItemCode
,c.InvName SubItemName
,c.InvStd SubItemStd
,a.Quantity --主数量
,c.InvUnit --主单位
,a.Amount --辅计量
,c.AmountUnit --辅单位
from ICSMOPick a with(nolock)
left join ICSMO b with(nolock) on a.MODetailID=b.MODetailID
left join ICSInventory c with(nolock) on a.InvCode =c.InvCode
where 1=1
<1>
and a.EATTRIBUTE1=0
) a
group by a.SubItemCode,a.SubItemName,a.SubItemStd,a.InvUnit,a.AmountUnit
order by a.SubItemCode,a.SubItemName,a.SubItemStd
";
// sql += " WHERE 1=1 and a.MOStatus<>'3' ";
var list = ids.Split(',');
sql = sql.Replace("<1>", " and b.ID in ('" + string.Join("','", list) + "')");
//sql = sql.Replace("<2>", "and b.Sequence=" + moSeq + "");
//sql = string.Format(sql, DbHelper.GetErpIp(), DbHelper.GetErpName());
#endregion
//if (NFine.Code.OperatorProvider.Provider.GetCurrent().RoleEnCode != "admin")
//{
// sql = sql.Replace("<3>", "and a.WorkPoint = '" + NFine.Code.OperatorProvider.Provider.GetCurrent().Location + "'");
// // sql += " and a.WorkPoint='" + NFine.Code.OperatorProvider.Provider.GetCurrent().Location + "'";
//}
//else
//{
// sql = sql.Replace("<3>", "");
//}
//if (NFine.Code.OperatorProvider.Provider.GetCurrent().RoleEnCode == "Vendor")
//{
// sql += " and a.VenCode='" + NFine.Code.OperatorProvider.Provider.GetCurrent().UserCode + "'";
//}
return Repository().FindDataSetBySql(sql.ToString(), parameter.ToArray()).Tables[0];
}
public DataTable GetApsPlanSubGridJsonList(string moCode, int moSeq, ref Pagination pagination)
{
DataTable dt = new DataTable();
// var queryParam = queryJson.ToJObject();
List<DbParameter> parameter = new List<DbParameter>();
//object Figure = GetDecimalDigits();
#region [SQL]
string sql = @"select 0 Code
--a.*
,a.ID
,a.Sequence SubSeq
,c.InvCode SubItemCode
,c.InvName SubItemName
--,c.ClassCode
--,c.ClassName
,c.InvStd SubItemDtd
,convert(nvarchar(100), floor (isnull( a.EATTRIBUTE3,0) *100)) +'%' as Rate --比例
,a.Quantity --主数量
,c.InvUnit --主单位
,a.Amount --辅计量
,c.AmountUnit --辅单位
from ICSMOPick a with(nolock)
left join ICSMO b with(nolock) on a.MODetailID=b.MODetailID
left join ICSInventory c with(nolock) on a.InvCode =c.InvCode and a.WorkPoint=c.WorkPoint
where 1=1
<1>
<2>
and a.EATTRIBUTE1=0
--and left( c.ClassCode,2)='01'
order by a.Sequence
";
// sql += " WHERE 1=1 and a.MOStatus<>'3' ";
sql = sql.Replace("<1>", "and b.MOCode='" + moCode + "'");
sql = sql.Replace("<2>", "and b.Sequence=" + moSeq + "");
//sql = string.Format(sql, DbHelper.GetErpIp(), DbHelper.GetErpName());
#endregion
//if (!string.IsNullOrWhiteSpace(queryJson))
//{
// if (!string.IsNullOrWhiteSpace(queryParam["ItemCode"].ToString()))
// {
// sql += " and a.ItemCode like '%" + queryParam["ItemCode"].ToString() + "%' ";
// }
// if (!string.IsNullOrWhiteSpace(queryParam["ItemName"].ToString()))
// {
// sql += " and a.ItemName like '%" + queryParam["ItemName"].ToString() + "%' ";
// }
// //if (!string.IsNullOrWhiteSpace(queryParam["InvName"].ToString()))
// //{
// // sql += " and b.InvName like '%" + queryParam["InvName"].ToString() + "%' ";
// //}
// //if (!string.IsNullOrWhiteSpace(queryParam["BatchCode"].ToString()))
// //{
// // sql += " and f.BatchCode like '%" + queryParam["BatchCode"].ToString() + "%' ";
// //}
// //if (!string.IsNullOrWhiteSpace(queryParam["SelGDLX"].ToString()))
// //{
// // sql += " and a.MOType like '%" + queryParam["SelGDLX"].ToString() + "%' ";
// //}
// //if (!string.IsNullOrWhiteSpace(queryParam["POStatus"].ToString()))
// //{
// // string POStatus = queryParam["POStatus"].ToString();
// // if (POStatus == "0")
// // {
// // //sql += " and a.Quantity=ISNULL(c.LotQty,0)";
// // }
// // else if (POStatus == "1")
// // {
// // sql += " and ISNULL(c.LOTQTY,0)>=a.Quantity";
// // }
// // else
// // {
// // sql += " and ISNULL(c.LOTQTY,0)<a.Quantity";
// // }
// //}
//}
//if (NFine.Code.OperatorProvider.Provider.GetCurrent().RoleEnCode != "admin")
//{
// sql = sql.Replace("<3>", "and a.WorkPoint = '" + NFine.Code.OperatorProvider.Provider.GetCurrent().Location + "'");
// // sql += " and a.WorkPoint='" + NFine.Code.OperatorProvider.Provider.GetCurrent().Location + "'";
//}
//else
//{
// sql = sql.Replace("<3>", "");
//}
//if (NFine.Code.OperatorProvider.Provider.GetCurrent().RoleEnCode == "Vendor")
//{
// sql += " and a.VenCode='" + NFine.Code.OperatorProvider.Provider.GetCurrent().UserCode + "'";
//}
return Repository().FindDataSetBySql(sql.ToString(), parameter.ToArray()).Tables[0];
}
}
}