|
|
|
|
using System;
|
|
|
|
|
using System.Data;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using DSWeb.Common.DB;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using DSWeb.MvcShipping.Helper;
|
|
|
|
|
using DSWeb.Common.Helper;
|
|
|
|
|
using DSWeb.Areas.CommMng.Models;
|
|
|
|
|
using static DSWeb.Areas.CommMng.DAL.BasicDataRefDAL;
|
|
|
|
|
using DSWeb.EntityDA;
|
|
|
|
|
using Microsoft.Practices.EnterpriseLibrary.Data;
|
|
|
|
|
using DSWeb.Areas.CommMng.DAL;
|
|
|
|
|
using HcUtility.Comm;
|
|
|
|
|
using System.Web.Mvc;
|
|
|
|
|
using DSWeb.MvcShipping.DAL.DsSendmail;
|
|
|
|
|
using iTextSharp.text.pdf;
|
|
|
|
|
using iTextSharp.text;
|
|
|
|
|
using System.IO;
|
|
|
|
|
using sun.swing;
|
|
|
|
|
using DSWeb.Areas.Import.DAL.ReceiptDoc;
|
|
|
|
|
using DSWeb.Areas.SysMng.DAL.SysUser;
|
|
|
|
|
using Renci.SshNet.Common;
|
|
|
|
|
using DSWeb.MvcShipping.DAL.MsSeaeOrderDAL;
|
|
|
|
|
using System.Data.Entity.Migrations;
|
|
|
|
|
|
|
|
|
|
namespace DSWeb.MvcShipping.DAL.BillCheckOut
|
|
|
|
|
{
|
|
|
|
|
public class BillCheckOutDAL
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static List<BillCheckOut_md> GetDataList(int start, int limit, string sort, string strCondition,string userid,string username, string companyid, ref int count)
|
|
|
|
|
{
|
|
|
|
|
var rangstr = GetRangDAStr("index", userid, username, companyid);
|
|
|
|
|
|
|
|
|
|
var strSql = new StringBuilder();
|
|
|
|
|
strSql.Append(" select * from ");
|
|
|
|
|
strSql.Append(" BillCheckOut where 1=1 ");
|
|
|
|
|
|
|
|
|
|
var sortstring = DatasetSort.Getsortstring(sort);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
PagedQuaryParam pp = new PagedQuaryParam();
|
|
|
|
|
|
|
|
|
|
pp.strSql = strSql.ToString();
|
|
|
|
|
pp.start = start;
|
|
|
|
|
pp.limit = limit;
|
|
|
|
|
pp.strCondition = strCondition;
|
|
|
|
|
pp.defaultsortstr = "CREATETIME desc";
|
|
|
|
|
pp.sortstring = sortstring;
|
|
|
|
|
pp.rangestr = rangstr;
|
|
|
|
|
|
|
|
|
|
var result = PagedQuaryStr(pp);
|
|
|
|
|
|
|
|
|
|
count = PagedCount(pp);
|
|
|
|
|
|
|
|
|
|
return SetData(result);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static List<VW_BillCheckOut_Detail_md> GetBodyList(string LINKGID)
|
|
|
|
|
{
|
|
|
|
|
var cdc = new CommonDataContext();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var dataList = cdc.VW_BillCheckOut_Detail.Where(x=>x.LINKGID== LINKGID).ToList();
|
|
|
|
|
|
|
|
|
|
//var count = dataList.Count();
|
|
|
|
|
|
|
|
|
|
//var list = dataList.Skip(start).Take(limit).ToList();
|
|
|
|
|
|
|
|
|
|
return dataList;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static string GetRangDAStr(string tb, string userid, string username, string companyid)
|
|
|
|
|
{
|
|
|
|
|
string str = "";
|
|
|
|
|
var strSql = new StringBuilder();
|
|
|
|
|
strSql.Append("SELECT ");
|
|
|
|
|
strSql.Append(" VISIBLERANGE,OPERATERANGE,AUTHORITYID,VSSQL ");
|
|
|
|
|
strSql.Append(" from VW_User_Authority ");
|
|
|
|
|
strSql.Append(" where [NAME]='modBillCheckOut' and USERID='" + userid + "' and ISDELETE=0");
|
|
|
|
|
|
|
|
|
|
string visiblerange = "4";
|
|
|
|
|
string operaterange = "4";
|
|
|
|
|
string AUTHORITYID = "";
|
|
|
|
|
string VSSQL = "";
|
|
|
|
|
|
|
|
|
|
Database db = DatabaseFactory.CreateDatabase();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
while (reader.Read())
|
|
|
|
|
{
|
|
|
|
|
visiblerange = Convert.ToString(reader["VISIBLERANGE"]);
|
|
|
|
|
operaterange = Convert.ToString(reader["OPERATERANGE"]);
|
|
|
|
|
AUTHORITYID = Convert.ToString(reader["AUTHORITYID"]);
|
|
|
|
|
VSSQL = Convert.ToString(reader["VSSQL"]);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
reader.Close();
|
|
|
|
|
}
|
|
|
|
|
if (visiblerange == "4")
|
|
|
|
|
{
|
|
|
|
|
str = "1=2";
|
|
|
|
|
}
|
|
|
|
|
else if (visiblerange == "3")
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
str = " (INPUTBY='" + username + "' OR SENDER='" + username + "' OR CHECKOUTUSER='" + username + "' )";
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
else if (visiblerange == "2")
|
|
|
|
|
{
|
|
|
|
|
if (tb == "index")
|
|
|
|
|
{
|
|
|
|
|
var rangeDa = new RangeDA();
|
|
|
|
|
var deptid = rangeDa.GetDEPTGID(userid);
|
|
|
|
|
|
|
|
|
|
str = $" exists(select 1 from vw_user where deptgid='{deptid}' and SHOWNAME in(INPUTBY,SENDER,CHECKOUTUSER)) ";
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
str = " (UPPER(CORPID)='" + companyid + "' or SALECORPID='" + companyid + "') ";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
else if (visiblerange == "5")
|
|
|
|
|
{
|
|
|
|
|
if (tb == "index")
|
|
|
|
|
{
|
|
|
|
|
var userstr = new StringBuilder();
|
|
|
|
|
userstr.Append(" select COMPANYID from user_authority_range_company where userid='" + userid + "' and AUTHORITYID='" + AUTHORITYID + "' and VISIBLERANGE=1");
|
|
|
|
|
Database userdb = DatabaseFactory.CreateDatabase();
|
|
|
|
|
using (IDataReader reader = userdb.ExecuteReader(CommandType.Text, userstr.ToString()))
|
|
|
|
|
{
|
|
|
|
|
str = "";
|
|
|
|
|
while (reader.Read())
|
|
|
|
|
{
|
|
|
|
|
if (str == "")
|
|
|
|
|
{
|
|
|
|
|
str = " (CORPID='" + Convert.ToString(reader["COMPANYID"]) + "' or SALECORPID='" + Convert.ToString(reader["COMPANYID"]) + "' ";
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
str = str + " or CORPID='" + Convert.ToString(reader["COMPANYID"]) + "' or SALECORPID='" + Convert.ToString(reader["COMPANYID"]) + "'";
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
str = str + ")";
|
|
|
|
|
reader.Close();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
str = " (UPPER(CORPID)='" + companyid + "' or SALECORPID='" + companyid + "') ";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
else if (visiblerange == "6")
|
|
|
|
|
{
|
|
|
|
|
if (tb == "index")
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
str = " EXISTS (select 1 from user_authority_range_op P left join [user] u on (u.GID=P.OPID) where (INPUTBY=U.SHOWNAME OR SENDER=U.SHOWNAME OR CHECKOUTUSER=U.SHOWNAME ) AND P.userid='" + userid + "' and P.AUTHORITYID='" + AUTHORITYID + "' and P.VISIBLERANGE=1) ";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
str = " (UPPER(CORPID)='" + companyid + "' or SALECORPID='" + companyid + "') ";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
else if (visiblerange == "1")
|
|
|
|
|
{
|
|
|
|
|
str = " (UPPER(B.Corpid)='" + companyid + "' or B.SALECORPID='" + companyid + "') ";
|
|
|
|
|
}
|
|
|
|
|
VSSQL = VSSQL.Trim();
|
|
|
|
|
if (!string.IsNullOrEmpty(VSSQL))
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
if (!string.IsNullOrEmpty(str))
|
|
|
|
|
{
|
|
|
|
|
str = str + " and (" + VSSQL + ") ";
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
str = " (" + VSSQL + ") ";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return str;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static List<BillCheckOut_md> SetData(StringBuilder strSql, bool isNoForward = false)
|
|
|
|
|
{
|
|
|
|
|
var headList = new List<BillCheckOut_md>();
|
|
|
|
|
Database db = DatabaseFactory.CreateDatabase();
|
|
|
|
|
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
|
|
|
|
|
{
|
|
|
|
|
while (reader.Read())
|
|
|
|
|
{
|
|
|
|
|
BillCheckOut_md data = new BillCheckOut_md();
|
|
|
|
|
#region Set DB data to Object
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
data.GID = Convert.ToString(reader["GID"]);
|
|
|
|
|
data.CHECKOUTNO = Convert.ToString(reader["CHECKOUTNO"]);
|
|
|
|
|
data.CUSTOMERNAME = Convert.ToString(reader["CUSTOMERNAME"]);
|
|
|
|
|
data.CORPID = Convert.ToString(reader["CORPID"]);
|
|
|
|
|
data.SALECORPID = Convert.ToString(reader["SALECORPID"]);
|
|
|
|
|
data.INPUTBY = Convert.ToString(reader["INPUTBY"]);
|
|
|
|
|
if (reader["CREATETIME"] != DBNull.Value)
|
|
|
|
|
data.CREATETIME = Convert.ToDateTime(reader["CREATETIME"]);
|
|
|
|
|
data.MODIFIER = Convert.ToString(reader["MODIFIER"]);
|
|
|
|
|
if (reader["MODIFYTIME"] != DBNull.Value)
|
|
|
|
|
data.MODIFYTIME = Convert.ToDateTime(reader["MODIFYTIME"]);
|
|
|
|
|
//if (reader["SENDED"] != DBNull.Value)
|
|
|
|
|
// data.SENDED = Convert.ToBoolean(reader["SENDED"]);
|
|
|
|
|
data.SENDED =(bool) getValue(reader, "SENDED");
|
|
|
|
|
data.SENDER = Convert.ToString(reader["SENDER"]);
|
|
|
|
|
if (reader["SENDTIME"] != DBNull.Value)
|
|
|
|
|
data.SENDTIME = Convert.ToDateTime(reader["SENDTIME"]);
|
|
|
|
|
data.RECEIVER = Convert.ToString(reader["RECEIVER"]);
|
|
|
|
|
data.RECEIVEEMAIL = Convert.ToString(reader["RECEIVEEMAIL"]);
|
|
|
|
|
//if (reader["ISCHECKOUT"] != DBNull.Value)
|
|
|
|
|
// data.ISCHECKOUT = Convert.ToBoolean(reader["ISCHECKOUT"]);
|
|
|
|
|
data.ISCHECKOUT = (bool)getValue(reader, "ISCHECKOUT");
|
|
|
|
|
if (reader["CHECKOUTTIME"] != DBNull.Value)
|
|
|
|
|
data.CHECKOUTTIME = Convert.ToDateTime(reader["CHECKOUTTIME"]);
|
|
|
|
|
|
|
|
|
|
data.CHECKOUTUSER = Convert.ToString(reader["CHECKOUTUSER"]);
|
|
|
|
|
data.MAILPDFURL = Convert.ToString(reader["MAILPDFURL"]);
|
|
|
|
|
data.SIGNPDFURL = Convert.ToString(reader["SIGNPDFURL"]);
|
|
|
|
|
#endregion
|
|
|
|
|
headList.Add(data);
|
|
|
|
|
}
|
|
|
|
|
reader.Close();
|
|
|
|
|
}
|
|
|
|
|
return headList;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#region 通知签单
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// 向客户发出签单条
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="BSNOs"></param>
|
|
|
|
|
/// <returns></returns>
|
|
|
|
|
public static DBResult NoticeCustomerToCheckOut(string BSNOs,string path,string username)
|
|
|
|
|
{
|
|
|
|
|
var result = new DBResult();
|
|
|
|
|
|
|
|
|
|
var gidList= BSNOs.Split(',').ToList();
|
|
|
|
|
|
|
|
|
|
var cdc = new CommonDataContext();
|
|
|
|
|
|
|
|
|
|
var headList = cdc.BillCheckOut.Where(x => gidList.Contains(x.GID)).ToList();
|
|
|
|
|
|
|
|
|
|
foreach (var item in headList) {
|
|
|
|
|
|
|
|
|
|
var cansend = CanSend(item);
|
|
|
|
|
if (!cansend.Success) return cansend;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
foreach (var item in headList)
|
|
|
|
|
{
|
|
|
|
|
var _r= DoSendMail(item,path);
|
|
|
|
|
if (_r.Success) {
|
|
|
|
|
item.SENDED = true;
|
|
|
|
|
item.SENDTIME = DateTime.Now;
|
|
|
|
|
item.SENDER = username;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
cdc.SaveChanges();
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static DBResult SaveSignPdf(string GID, string Base64Str, string path, string username) {
|
|
|
|
|
var result = new DBResult();
|
|
|
|
|
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
var cdc = new CommonDataContext();
|
|
|
|
|
|
|
|
|
|
var head = cdc.BillCheckOut.FirstOrDefault(x => x.GID == GID);
|
|
|
|
|
|
|
|
|
|
byte[] bytes = Convert.FromBase64String(Base64Str);
|
|
|
|
|
|
|
|
|
|
string location = path+"/"+ head.CHECKOUTNO + "_Sign.pdf";
|
|
|
|
|
|
|
|
|
|
if (File.Exists(location))
|
|
|
|
|
{
|
|
|
|
|
File.Delete(location);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
System.IO.FileStream stream = new FileStream(location, FileMode.CreateNew);
|
|
|
|
|
System.IO.BinaryWriter writer = new BinaryWriter(stream);
|
|
|
|
|
writer.Write(bytes, 0, bytes.Length);
|
|
|
|
|
writer.Close();
|
|
|
|
|
|
|
|
|
|
head.CHECKOUTUSER=username;
|
|
|
|
|
head.CHECKOUTTIME=DateTime.Now;
|
|
|
|
|
head.SIGNPDFURL = location;
|
|
|
|
|
cdc.BillCheckOut.AddOrUpdate(head);
|
|
|
|
|
cdc.SaveChanges();
|
|
|
|
|
|
|
|
|
|
result.OK();
|
|
|
|
|
}
|
|
|
|
|
catch (Exception e) {
|
|
|
|
|
result.SetErrorInfo(e.Message);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
public static DBResult CanSend(BillCheckOut_md head) {
|
|
|
|
|
var result = new DBResult();
|
|
|
|
|
result.OK();
|
|
|
|
|
if (string.IsNullOrWhiteSpace(head.RECEIVEEMAIL)) {
|
|
|
|
|
result.SetErrorInfo("未指定收件人邮箱");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static DBResult DoSendMail(BillCheckOut_md head, string path)
|
|
|
|
|
{
|
|
|
|
|
var result = new DBResult();
|
|
|
|
|
//1根据业务的明细 生成一个pdf
|
|
|
|
|
|
|
|
|
|
result=MakeCheckOutPdf( head, path);
|
|
|
|
|
|
|
|
|
|
if (!result.Success) return result;
|
|
|
|
|
|
|
|
|
|
var filename = result.Message;
|
|
|
|
|
|
|
|
|
|
//2作为附件发出
|
|
|
|
|
//result = SendCheckOutEmail(head);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static DBResult MakeCheckOutPdf(BillCheckOut_md head, string path) {
|
|
|
|
|
var result = new DBResult();
|
|
|
|
|
|
|
|
|
|
//读取基本dpf 在其中增加内容
|
|
|
|
|
PDFHelper ph = new PDFHelper();
|
|
|
|
|
|
|
|
|
|
result = ph.MakePdf_BillCheckOut(head, path);
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static DBResult SendCheckOutEmail(BillCheckOut_md head)
|
|
|
|
|
{
|
|
|
|
|
var cdc = new CommonDataContext();
|
|
|
|
|
var result = new DBResult(true, "");
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
head = cdc.BillCheckOut.FirstOrDefault(x => x.GID == head.GID);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var mailtitle = "签单表";
|
|
|
|
|
|
|
|
|
|
var Body = new StringBuilder();
|
|
|
|
|
Body.Append("<html> <Body>");
|
|
|
|
|
Body.Append("<br />签单表内容:<br />业务编号:");
|
|
|
|
|
//Body.Append("<br />客户名称:" + headData.CUSTOMERNAME);
|
|
|
|
|
//Body.Append("<br />揽货人" + headData.SALE);
|
|
|
|
|
//Body.Append("<br />录入人" + headData.INPUTBY);
|
|
|
|
|
//Body.Append("<br />港口:" + headData.DESTINATION);
|
|
|
|
|
//Body.Append("<br />船期:" + headData.ETD);
|
|
|
|
|
//Body.Append("<br />船公司:" + headData.CARRIER);
|
|
|
|
|
//Body.Append("<br />箱量:" + headData.CNTRTOTAL);
|
|
|
|
|
//Body.Append("<br />备注:" + OrderData.REMARK);
|
|
|
|
|
Body.Append("</Body></html> ");
|
|
|
|
|
var mailto = head.RECEIVEEMAIL;
|
|
|
|
|
//var oplist = SysUserDAL.GetDataList("U.SHOWNAME='" + op + "' or U.SHOWNAME='" + headData.SALE + "' or U.SHOWNAME='" + OrderData.INPUTBY + "' ");
|
|
|
|
|
//foreach (var opbs in oplist)
|
|
|
|
|
//{
|
|
|
|
|
// if (opbs.EMAIL1 != "")
|
|
|
|
|
// {
|
|
|
|
|
// if (mailto == "")
|
|
|
|
|
// mailto = opbs.EMAIL1;
|
|
|
|
|
// else
|
|
|
|
|
// mailto = mailto + ";" + opbs.EMAIL1;
|
|
|
|
|
// }
|
|
|
|
|
//}
|
|
|
|
|
|
|
|
|
|
//if (mailto != "")
|
|
|
|
|
//{
|
|
|
|
|
// var j = 0;
|
|
|
|
|
// var filepath = "";
|
|
|
|
|
// var doclist = ReceiptDocDAL.GetDocList("BSNO='" + headData.BSNO + "'", " MODIFIEDTIME DESC ");
|
|
|
|
|
// foreach (var doc in doclist)
|
|
|
|
|
// {
|
|
|
|
|
// if (j == 0)
|
|
|
|
|
// {
|
|
|
|
|
// filepath = doc.Driect_URL;
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
// j = j = 1;
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
// result = MsSeaeOrderDAL.SendMailWithFile(mailtitle, Body.ToString(), filepath, mailto, Convert.ToString(Session["SHOWNAME"]));
|
|
|
|
|
//}
|
|
|
|
|
result = MsSeaeOrderDAL.MsSeaeOrderDAL.SendMailWithFile(mailtitle, Body.ToString(), head.MAILPDFURL, mailto, head.SENDER);
|
|
|
|
|
|
|
|
|
|
result.OK("发送成功");
|
|
|
|
|
}
|
|
|
|
|
catch (Exception e)
|
|
|
|
|
{
|
|
|
|
|
result.Success = false;
|
|
|
|
|
result.Message = e.Message;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
}
|
|
|
|
|
}
|