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.
 
 
 
 
 

419 lines
18 KiB

using NFine.Application.WMS;
using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using NFine.Code;
using System.Data.SqlClient;
using NFine.Data.Extensions;
using System.Data.OleDb;
using System.Configuration;
using ICS.Application.Entity;
using NFine.Domain._03_Entity.WMS;
using System.Data.Common;
using Newtonsoft.Json;
namespace NFine.Web.Areas.WMS.Controllers
{
public class PrintController : ControllerBase
{
PrintApp App = new PrintApp();
// GET: WMS/Print
public ActionResult PrintView()
{
return View();
}
/// <summary>
/// 打印数据参数:服务器的URL+打印的文件名,转化为Base64编码
/// </summary>
protected string strPrintData;
/// <summary>
/// 标识是否安装了控件
/// </summary>
protected bool bIsInstallPrintControl = true;
/// <summary>
/// 打印控件的Cookie值
/// </summary>
protected string strPrintControlCookie = "";
/// <summary>
/// 获取Url中去掉文件名的路径
/// </summary>
/// <returns></returns>
private string GetUrlPath()
{
string strUrl = Request.Url.ToString();
int iEnd = strUrl.LastIndexOf("/");
strUrl = strUrl.Substring(0, iEnd + 1);
return strUrl;
}
[HttpGet]
[HandlerAjaxOnly]
public ActionResult GetLableType()
{
DataTable dt = App.GetLableType();
return Content(dt.ToJson());
}
[HttpGet]
[HandlerAjaxOnly]
public ActionResult GetLableSourceID()
{
DataTable dt = App.GetLableSourceID();
return Content(dt.ToJson());
}
[HttpGet]
[HandlerAjaxOnly]
public ActionResult GetSys_LablesID(string LableType)
{
DataTable dt = App.GetSys_LablesID(LableType);
return Content(dt.ToJson());
}
//打印
[HttpPost]
[HandlerAjaxOnly]
public ActionResult PrintItemLot(string keyValue, string Parameter)
{
string MUSER = NFine.Code.OperatorProvider.Provider.GetCurrent().UserCode;
string ValueParameters = Parameter;
string WorkPoint = "'"+NFine.Code.OperatorProvider.Provider.GetCurrent().Location.TrimEnd(',')+"'";
string sqltxt = "";
Parameter = Parameter.Substring(1, Parameter.Length - 3);
var queryParam = keyValue.ToJObject();
List<DbParameter> parameter = new List<DbParameter>();
var Sys_LablesID = queryParam["Sys_LablesID"].ToString();
List<PrintPara> parasList = new List<PrintPara>();
keyValue = keyValue.Substring(1, keyValue.Length - 2);
string sqlValue = @"select LableSourceID,FileAddress,LableCode,LableName from Sys_Lables where ID='{0}'";
sqlValue = string.Format(sqlValue, Sys_LablesID);
DataRow drV = SqlHelper.GetDataRowBySql(sqlValue);
string LableSourceID = drV["LableSourceID"].ToString();
string FileAddress= drV["FileAddress"].ToString();
string LableCode = drV["LableCode"].ToString();
string LableName = drV["LableName"].ToString();
string sqlLableDataSource = @"SELECT ID,WorkPointCode,OtherDataBaseID,WorkPointDataFlag,
SysDataFlag,SqlTxt,SourceName,FormatSqlTxt,Paras,DbParas,LinkCols,CreateUserID,
CreateDate,ModifyUserID,ModifyDate,Link2Cols FROM dbo.Sys_LableDataSource
where ID='{0}'";
sqlLableDataSource= string.Format(sqlLableDataSource, LableSourceID);
DataRow dr = SqlHelper.GetDataRowBySql(sqlLableDataSource);
#region 打印
//string[] PrintParas = Parameter.Split('|');
//string LinkCols = string.Empty;
//foreach (var p in PrintParas)
//{
// sqltxt = dr["SqlTxt"].ToString();
// LinkCols= dr["LinkCols"].ToString();
// if (dr["Paras"].ToString() != "")
// {
// string[] ps = dr["Paras"].ToString().Split(',');
// for (int i = 0; i < ps.Length; i++)
// {
// if (!string.IsNullOrEmpty(ps[i]))
// {
// sqltxt = sqltxt.Replace(ps[i], p.ToString());
// }
// }
// }
// if (sqltxt.Contains("[WorkPoint]"))
// {
// sqltxt = sqltxt.Replace("[WorkPoint]", WorkPoint);
// }
//}
#endregion
string[] PrintParas = Parameter.Split('|');
string LinkCols = string.Empty;
string SourceName= dr["SourceName"].ToString();
string Paras = dr["Paras"].ToString();
sqltxt = dr["SqlTxt"].ToString();
LinkCols = dr["LinkCols"].ToString();
if (dr["Paras"].ToString() != "")
{
string[] ps = dr["Paras"].ToString().Split(',');
for (int i = 0; i < ps.Length; i++)
{
if (!string.IsNullOrEmpty(ps[i]))
{
sqltxt = sqltxt.Replace(ps[i], PrintParas[i]);
}
}
}
if (sqltxt.Contains("[WorkPoint]"))
{
sqltxt = sqltxt.Replace("[WorkPoint]", WorkPoint);
}
string strPrintFileName = Server.MapPath("/File/LablesFile/") + ""+ FileAddress + "";
PrintJson pJson = new PrintJson(Server.MapPath("./PrintTemp"), strPrintFileName);
pJson.CheckRegister("苏州智合诚信息科技有限公司", "56DD3B4C172D0D140841CAC98A58A819F4E28EDA5D6E45711DDD64F6A439F68B6A7870CD7DAFD69A919CB870207FE4BB206F92BE3D53C221B019E0797E739EBA4"); //注册信息
if (LinkCols!="")
{
pJson.MasterOptions(1, ""+ LinkCols + "", false); //主从关系
}
//pJson.CheckRegister("注册姓名", "8ECCCD6A1302DFEE1A6456A5D"); //注册信息
//pJson.AddPrintParam("ShopName", "测试酒楼");
//pJson.AddPrintParam("PrintDepositAdd", "说明:本单据为贵客押金收取凭证,盖章有效。退房时请出示,遗失者自负,请妥善保存。退房时间为12:00时,延时退房18:00时以前按半天房费收取,18:00时以后算全天房价。押金单有效期为一个月,过期作废。 贵重物品请交前台寄存,未寄存丢失自负。 谢谢!");
SetCookieAndURL(pJson);// 设置控件调用的Cookie值,判断是否安装了打印控件
string strSql = sqltxt;
//DataTable dtCashLog = DbHelper.ExecuteTable(DbHelper.ConnectionString, CommandType.Text, strSql, true, null);
DataSet dtCashLog = DbHelper.GetDataSet( CommandType.Text, strSql);
DataTable dt1 = null;
DataTable dt2 = null;
DataTable dt3 = null;
string strPrintTempFile = "";
if (dtCashLog.Tables.Count > 0 && dtCashLog.Tables.Count <= 1)
{
dt1 = dtCashLog.Tables[0];
strPrintTempFile = pJson.ShowReport(dt1);
}
if (dtCashLog.Tables.Count > 1 && dtCashLog.Tables.Count<=2)
{
dt1 = dtCashLog.Tables[0];
dt2 = dtCashLog.Tables[1];
strPrintTempFile = pJson.ShowReport(dt1,dt2);
}
if (dtCashLog.Tables.Count > 2)
{
dt1 = dtCashLog.Tables[0];
dt2 = dtCashLog.Tables[1];
dt3 = dtCashLog.Tables[2];
strPrintTempFile = pJson.ShowReport(dt1, dt2,dt3);
}
//string strPrintTempFile = pJson.ShowReport(dt1, dt2); //产生JSON文件内容
//把服务器的URL + 此文件名 传递给控件,由控件下载还原数据进行打印
string strServerURL = GetUrlPath() + "PrintTemp/";
string strData = strServerURL + strPrintTempFile;
strPrintData = PrintFunction.EnBase64(strData);
var JsonData = new
{
strPrintData_1 = strPrintData,
bIsInstallPrintControl_1 = bIsInstallPrintControl,
strPrintControlCookie_1 = strPrintControlCookie
};
//打印记录
//string sql = @"insert into Sys_LableTask (ID, LableCode, LableName, PrintTableID, PrintTableName, PrintKey, ValueParameters, PrintDate, PrintUserCode, WorkPoint)
// values(newid(),'{0}','{1}','{2}','{3}','{4}','{5}',getdate(),'{6}',{7})";
//sql = string.Format(sql, LableCode, LableName, LableSourceID, SourceName, Paras, ValueParameters, MUSER, WorkPoint);
//SqlHelper.ExecuteNonQuery(sql);
//多站点
//string sql = @"UPDATE dbo.ICSInventoryLot
// SET PrintTimes=ISNULL(PrintTimes,0)+1,
// LastPrintUser='',
// LastPrintTime=GETDATE()
// WHERE ID IN (" + keyValue.TrimEnd(',') + ") and WorkPoint in ('" + WorkPoint.TrimEnd(',') + "')";
//SqlHelper.ExecuteNonQuery(sql);
return Content(JsonData.ToJson());
}
[HttpPost]
[HandlerAjaxOnly]
public ActionResult YLPrintItemLot(string keyValue, string Parameter)
{
string WorkPoint = "'" + NFine.Code.OperatorProvider.Provider.GetCurrent().Location.TrimEnd(',') + "'";
string sqltxt = "";
//Parameter = Parameter.Substring(1, Parameter.Length - 3);
var queryParam = keyValue.ToJObject();
List<DbParameter> parameter = new List<DbParameter>();
var Sys_LablesID = queryParam["Sys_LablesID"].ToString();
List<PrintPara> parasList = new List<PrintPara>();
keyValue = keyValue.Substring(1, keyValue.Length - 2);
string sqlValue = @"select LableSourceID,FileAddress from Sys_Lables where ID='{0}'";
sqlValue = string.Format(sqlValue, Sys_LablesID);
DataRow drV = SqlHelper.GetDataRowBySql(sqlValue);
string LableSourceID = drV["LableSourceID"].ToString();
string FileAddress = drV["FileAddress"].ToString();
string sqlLableDataSource = @"SELECT ID,WorkPointCode,OtherDataBaseID,WorkPointDataFlag,
SysDataFlag,SqlTxt,SourceName,FormatSqlTxt,Paras,DbParas,LinkCols,CreateUserID,
CreateDate,ModifyUserID,ModifyDate,Link2Cols FROM dbo.Sys_LableDataSource
where ID='{0}'";
sqlLableDataSource = string.Format(sqlLableDataSource, LableSourceID);
DataRow dr = SqlHelper.GetDataRowBySql(sqlLableDataSource);
string LinkCols = string.Empty;
LinkCols = dr["LinkCols"].ToString();
string strPrintFileName = Server.MapPath("/File/LablesFile/") + "" + FileAddress + "";
PrintJson pJson = new PrintJson(Server.MapPath("./PrintTemp"), strPrintFileName);
pJson.CheckRegister("苏州智合诚信息科技有限公司", "56DD3B4C172D0D140841CAC98A58A819F4E28EDA5D6E45711DDD64F6A439F68B6A7870CD7DAFD69A919CB870207FE4BB206F92BE3D53C221B019E0797E739EBA4"); //注册信息
if (LinkCols != "")
{
pJson.MasterOptions(1, "" + LinkCols + "", false); //主从关系
}
//pJson.CheckRegister("注册姓名", "8ECCCD6A1302DFEE1A6456A5D"); //注册信息
//pJson.AddPrintParam("ShopName", "测试酒楼");
//pJson.AddPrintParam("PrintDepositAdd", "说明:本单据为贵客押金收取凭证,盖章有效。退房时请出示,遗失者自负,请妥善保存。退房时间为12:00时,延时退房18:00时以前按半天房费收取,18:00时以后算全天房价。押金单有效期为一个月,过期作废。 贵重物品请交前台寄存,未寄存丢失自负。 谢谢!");
SetCookieAndURL(pJson);// 设置控件调用的Cookie值,判断是否安装了打印控件
string strSql = sqltxt;
//DataTable dtCashLog = DbHelper.ExecuteTable(DbHelper.ConnectionString, CommandType.Text, strSql, true, null);
//DataSet dtCashLog = DbHelper.GetDataSet(CommandType.Text, strSql);
//var jsonData = $"[{Parameter}]";
//DataTable dt1 = JsonConvert.DeserializeObject<DataTable>(jsonData);
DataTable dt1 = JsonConvert.DeserializeObject<DataTable>(Parameter);
string strPrintTempFile = "";
//if (dtCashLog.Tables.Count > 0 && dtCashLog.Tables.Count <= 1)
//{
// dt1 = dtCashLog.Tables[0];
strPrintTempFile = pJson.ShowReport(dt1);
//}
//if (dtCashLog.Tables.Count > 1 && dtCashLog.Tables.Count <= 2)
//{
// dt1 = dtCashLog.Tables[0];
// dt2 = dtCashLog.Tables[1];
// strPrintTempFile = pJson.ShowReport(dt1, dt2);
//}
//if (dtCashLog.Tables.Count > 2)
//{
// dt1 = dtCashLog.Tables[0];
// dt2 = dtCashLog.Tables[1];
// dt3 = dtCashLog.Tables[2];
// strPrintTempFile = pJson.ShowReport(dt1, dt2, dt3);
//}
//string strPrintTempFile = pJson.ShowReport(dt1, dt2); //产生JSON文件内容
//把服务器的URL + 此文件名 传递给控件,由控件下载还原数据进行打印
string strServerURL = GetUrlPath() + "PrintTemp/";
string strData = strServerURL + strPrintTempFile;
strPrintData = PrintFunction.EnBase64(strData);
var JsonData = new
{
strPrintData_1 = strPrintData,
bIsInstallPrintControl_1 = bIsInstallPrintControl,
strPrintControlCookie_1 = strPrintControlCookie
};
//多站点
//string sql = @"UPDATE dbo.ICSInventoryLot
// SET PrintTimes=ISNULL(PrintTimes,0)+1,
// LastPrintUser='',
// LastPrintTime=GETDATE()
// WHERE ID IN (" + keyValue.TrimEnd(',') + ") and WorkPoint in ('" + WorkPoint.TrimEnd(',') + "')";
//SqlHelper.ExecuteNonQuery(sql);
return Content(JsonData.ToJson());
}
/// <summary>
/// 设置控件调用的Cookie值,判断是否安装了打印控件....
/// </summary>
/// <param name="pJson"></param>
private void SetCookieAndURL(PrintJson pJson)
{
bIsInstallPrintControl = false;
strPrintControlCookie = "";
HttpCookie pCookieInstall = Request.Cookies["InstallPrintControl"];
if (pCookieInstall != null)
{ //Cookie存在
strPrintControlCookie = pCookieInstall.Value.ToString();
//以Cookie值查找在数据表中是否存在
string strSql = @"Select * From sys_SRM_CheckInstall Where Cookie = @Cookie";
SqlParameter[] pmcCookie = { new SqlParameter("Cookie", strPrintControlCookie) };
using (SqlDataReader drCookie = DbHelper.ExecuteReader(DbHelper.ConnectionString, CommandType.Text, strSql, pmcCookie))
{
if (drCookie.Read())
{ //标识为已经安装
bIsInstallPrintControl = true;
}
drCookie.Close();
}
//更新Cookie的保存时间
pCookieInstall.Expires = DateTime.Now.AddYears(10);
Response.SetCookie(pCookieInstall);
}
else
{//Cookie不存在,则新建Cookie
strPrintControlCookie = System.Guid.NewGuid().ToString();
pCookieInstall = new HttpCookie("InstallPrintControl", strPrintControlCookie);
pCookieInstall.Expires = DateTime.Now.AddYears(10);
Response.Cookies.Add(pCookieInstall);
}
string strUrl = Server.MapPath("/PrintTemp/") + "IsCheckInstall";
pJson.SetCookieAndURL(strPrintControlCookie, strUrl);
}
[HttpGet]
public ActionResult SelectColumnName(string BeginTime, string EndTime)
{
var data = App.SelectColumnName(BeginTime, EndTime);
return Content(data.ToJson());
}
[HttpGet]
public ActionResult SelectTableColumnName(string BeginTime, string EndTime)
{
var data = App.SelectTableColumnName(BeginTime, EndTime);
return Content(data.ToJson());
}
[HttpGet]
public ActionResult GetCnValue(string Code)
{
string sql = string.Empty;
try
{
string str = App.GetCnValue(Code);
var JsonData = new
{
content = str
};
return Content(JsonData.ToJson());
}
catch (Exception ex)
{
return Error(ex.Message);
}
}
[HttpGet]
[HandlerAjaxOnly]
public ActionResult updatePrintStatus(string LotNo)
{
string msg = App.updatePrintStatus(LotNo);
if (!string.IsNullOrEmpty(msg))
{
return Error(msg);
}
else
{
return Success("打印人、打印次数、打印时间更新成功!");
}
}
}
}