|
|
using System;
|
|
|
using System.Linq;
|
|
|
using System.Web.Mvc;
|
|
|
using DSWeb.MvcShipping.DAL.MsOpSeaiDAL;
|
|
|
using DSWeb.MvcShipping.Models.MsOpSeai;
|
|
|
using DSWeb.MvcShipping.Helper;
|
|
|
using DSWeb.MvcShipping.Comm.Cookie;
|
|
|
using HcUtility.Comm;
|
|
|
using HcUtility.Core;
|
|
|
using System.Collections.Generic;
|
|
|
using DSWeb.MvcShipping.DAL.MsBaseInfoDAL;
|
|
|
using DSWeb.EntityDA;
|
|
|
using System.IO;
|
|
|
using System.Text;
|
|
|
using System.Data;
|
|
|
using System.Text.RegularExpressions;
|
|
|
using com.sun.org.apache.bcel.@internal.generic;
|
|
|
using DSWeb.Areas.CommMng.DAL;
|
|
|
using DSWeb.Areas.RptMng.Comm;
|
|
|
using DSWeb.MvcShipping.DAL.MsCodeFtpSet;
|
|
|
using DSWeb.MvcShipping.DAL.MsSysBillNoSet;
|
|
|
using DSWeb.MvcShipping.Models.MsSysBillNoSet;
|
|
|
using DSWeb.MvcShipping.Models.MsOpApply;
|
|
|
using DSWeb.MvcShipping.DAL.MsOpApplyDAL;
|
|
|
using DSWeb.MvcShipping.DAL.MsSysParamSet;
|
|
|
using DSWeb.MvcShipping.Models.MsOpSeaeToSeai;
|
|
|
using DSWeb.SoftMng.DAL.SoftSysTable;
|
|
|
using DSWeb.MvcShipping.Models.MsChFee;
|
|
|
using DSWeb.MvcShipping.DAL.MsChFeeDAL;
|
|
|
using DSWeb.MvcShipping.DAL.MsInfoClient;
|
|
|
using Terminal_CDMA;
|
|
|
using Microsoft.Office.Interop.Excel;
|
|
|
using DSWeb.Areas.CommMng.Models;
|
|
|
|
|
|
using DSWeb.MvcShipping.Models.WMSNew;
|
|
|
using DSWeb.TruckMng.Helper.Repository;
|
|
|
using sun.font;
|
|
|
using Type = System.Type;
|
|
|
using DSWeb.MvcShipping.DAL.MsCodeOpTemplate;
|
|
|
using DSWeb.MvcShipping.DAL.ChMonthCloseDAL;
|
|
|
using ikvm.extensions;
|
|
|
using java.util.regex;
|
|
|
using DSWeb.Common.DB;
|
|
|
using DSWeb.Common.Helper;
|
|
|
using DSWeb.Areas.SysMng.DAL.SysUser;
|
|
|
|
|
|
namespace DSWeb.MvcShipping.Controllers
|
|
|
{
|
|
|
[JsonRequestBehavior]
|
|
|
public class MsOpSeaiController : Controller
|
|
|
{
|
|
|
#region 窗口页面
|
|
|
public ActionResult Index()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult HistryFeeIndex()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult Edit()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult FeeEdit()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult SeaiFeeView()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult FeeAmendEdit()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult ReceiptEdit()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult WMSIN()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult WMSINEdit()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult WMSOUT()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult WMSOUTEdit()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult PiLiangFeeEdit()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult EditView()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult SaleIndex()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult Seae2SeaiIndex()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult SaleEdit()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
|
|
|
public ActionResult AmendIndex()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult AmendFeeEdit()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
public ActionResult BillLSEdit()
|
|
|
{
|
|
|
return View();
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region 基本函数
|
|
|
public ContentResult GetDataList(int start, int limit, string sort, string condition)
|
|
|
{
|
|
|
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
}
|
|
|
var dataList = MsOpSeaiDAL.GetDataList(start, limit, condition, Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]), sort);
|
|
|
int count = MsOpSeaiDAL.getTotalCount(condition, Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
var json = JsonConvert.Serialize(new { Success = true, Message = "查询成功", totalCount = count, data = dataList.ToList() });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
public ContentResult GetSaleDataList(int start, int limit, string sort, string condition)
|
|
|
{
|
|
|
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
}
|
|
|
var dataList = MsOpSeaiDAL.GetSaleDataList(condition, Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]), sort, Convert.ToString(Session["USERID"]));
|
|
|
var list = dataList.Skip(start).Take(limit);
|
|
|
var json = JsonConvert.Serialize(new { Success = true, Message = "查询成功", totalCount = dataList.Count, data = list.ToList() });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
public ContentResult GetAmendDataList(int start, int limit, string sort, string condition, string load)
|
|
|
{
|
|
|
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
}
|
|
|
|
|
|
var dataList = MsOpSeaiDAL.GetAmendDataList(start, limit, condition, Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]), sort);
|
|
|
int count = MsOpSeaiDAL.getAmendTotalCount(condition, Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
var json = JsonConvert.Serialize(new { Success = true, Message = "查询成功", totalCount = count, data = dataList.ToList() });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
public ContentResult GetAmendDataListStr(string sort, string condition)
|
|
|
{
|
|
|
var dataListStr = MsOpSeaiDAL.GetAmendDataStr(condition, Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]), sort);
|
|
|
var json = JsonConvert.Serialize(new { Success = true, Message = dataListStr.Message, data = dataListStr.Data });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
|
|
|
|
|
|
public ContentResult GetFenList(int start, int limit, string sort, string condition)
|
|
|
{
|
|
|
var dataList = MsOpSeaiDAL.GetFenList(condition, Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]), sort);
|
|
|
var list = dataList.Skip(start).Take(limit);
|
|
|
var json = JsonConvert.Serialize(new { Success = true, Message = "查询成功", totalCount = dataList.Count, data = list.ToList() });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
|
|
|
public ContentResult GetDataListStr(string sort, string condition)
|
|
|
{
|
|
|
var dataListStr = MsOpSeaiDAL.GetDataListStr(condition, Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]), sort);
|
|
|
var json = JsonConvert.Serialize(new { Success = true, Message = "查询成功", data = dataListStr });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
|
|
|
public ContentResult GetData(string handle, string condition)
|
|
|
{
|
|
|
string userid = Convert.ToString(Session["USERID"]);
|
|
|
if (userid == "" || userid == null)
|
|
|
{
|
|
|
var jsonRespose = new JsonResponse { Success = false, Message = "登陆状态失效,请重新登陆进行操作!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
|
|
|
MsOpSeai head = null;
|
|
|
if (handle == "edit" || handle == "copyadd")
|
|
|
{
|
|
|
head = MsOpSeaiDAL.GetData(condition);
|
|
|
}
|
|
|
if (head == null)
|
|
|
{
|
|
|
head = new MsOpSeai();
|
|
|
head.OP = Convert.ToString(Session["SHOWNAME"]);
|
|
|
head.BSTYPE = "2";
|
|
|
var SALEORDERDEPTBYOP = MsSysParamSetDAL.GetData("PARAMNAME='SALEORDERDEPTBYOP'");
|
|
|
if (SALEORDERDEPTBYOP.PARAMVALUE == "1")
|
|
|
{
|
|
|
head.SALEDEPT = Convert.ToString(Session["DEPTNAME"]);
|
|
|
}
|
|
|
}
|
|
|
if (handle == "copyadd") {
|
|
|
var copyfieldlist = MsCodeOpTemplateDAL.GetCodeOpTemplateDetail(" LINKGID in (select top 1 GID from CODE_OP_TEMPLATE where BSTYPE='海运进口' and op='" + CookieConfig.GetCookie_UserId(Request) + "' or ISPUBLIC='是' order by ISPUBLIC)");
|
|
|
if (copyfieldlist.Count != 0)
|
|
|
{
|
|
|
|
|
|
|
|
|
}
|
|
|
}
|
|
|
|
|
|
|
|
|
var json = JsonConvert.Serialize(
|
|
|
new { Success = true, Message = "查询成功", data = head });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
|
|
|
public ContentResult GetCountryForWMSIn(string condition)
|
|
|
{
|
|
|
CountryModel head = null;
|
|
|
head = MsOpSeaiDAL.GetCountryModelData(condition);
|
|
|
var json = JsonConvert.Serialize(
|
|
|
new { Success = true, Message = "查询成功", data = head });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
public ContentResult GetAmendData(string condition)
|
|
|
{
|
|
|
MsOpSeai head = null;
|
|
|
|
|
|
var headlist = MsOpSeaiDAL.GetAmendDataList(0, 1, condition, Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
if (headlist.Count > 0)
|
|
|
head = headlist[0];
|
|
|
else
|
|
|
head = new MsOpSeai();
|
|
|
|
|
|
var json = JsonConvert.Serialize(
|
|
|
new { Success = true, Message = "查询成功", data = head });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
|
|
|
public ContentResult GetCopyData(string condition, string copyfee = "false", string copybill="false")
|
|
|
{
|
|
|
MsOpSeai head = null;
|
|
|
|
|
|
var oldhead = MsOpSeaiDAL.GetData(condition);
|
|
|
|
|
|
var copyfieldlist = MsCodeOpTemplateDAL.GetCodeOpTemplateDetail(" LINKGID in (select top 1 GID from CODE_OP_TEMPLATE where BSTYPE='海运进口' and (op='" + CookieConfig.GetCookie_UserId(Request) + "' or ISPUBLIC='是') order by ISPUBLIC)");
|
|
|
if (copyfieldlist.Count == 0)
|
|
|
{
|
|
|
head = oldhead;
|
|
|
head.BSNO = "topseai" + Guid.NewGuid().ToString();
|
|
|
head.MASTERNO = "";
|
|
|
head.CUSTNO = "";
|
|
|
head.ORDERNO = "";
|
|
|
head.ORDERTYPE = "操作录入";
|
|
|
head.OP = Convert.ToString(Session["SHOWNAME"]);
|
|
|
head.INPUTBY = Convert.ToString(Session["SHOWNAME"]);
|
|
|
head.OP = Convert.ToString(Session["SHOWNAME"]);
|
|
|
head.BSTYPE = "2";
|
|
|
var SALEORDERDEPTBYOP = MsSysParamSetDAL.GetData("PARAMNAME='SALEORDERDEPTBYOP'");
|
|
|
if (SALEORDERDEPTBYOP.PARAMVALUE == "1")
|
|
|
{
|
|
|
head.SALEDEPT = Convert.ToString(Session["DEPTNAME"]);
|
|
|
}
|
|
|
head.BSSTATUS = false;
|
|
|
head.FEESTATUS = false;
|
|
|
head.BSSTATUSREF = "未锁定";
|
|
|
head.FEESTATUSREF = "未锁定";
|
|
|
if (copyfee == "true")
|
|
|
{
|
|
|
//var feelist = MsChFeeDAL.GetAllDataList(condition);
|
|
|
var feelist = MsChFeeDAL.GetDataList(condition, 1, "op_seai", Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
|
|
|
if (feelist != null)
|
|
|
{
|
|
|
for (int _i = 0; _i < feelist.Count; _i++)
|
|
|
{
|
|
|
feelist[_i].BsNo = "*";
|
|
|
}
|
|
|
MsChFeeDAL.SaveFee(feelist, head.BSNO, CookieConfig.GetCookie_UserId(Request));
|
|
|
}
|
|
|
}
|
|
|
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
|
|
|
if (head == null)
|
|
|
{
|
|
|
head = new MsOpSeai();
|
|
|
head.BSNO = "topseai" + Guid.NewGuid().ToString();
|
|
|
head.ORDERTYPE = "操作录入";
|
|
|
head.OP = Convert.ToString(Session["SHOWNAME"]);
|
|
|
head.DOC = Convert.ToString(Session["SHOWNAME"]);
|
|
|
head.INPUTBY = Convert.ToString(Session["SHOWNAME"]);
|
|
|
head.CUSTSERVICE = Convert.ToString(Session["SHOWNAME"]);
|
|
|
var period = ChMonthCloseDAL.GetData("", Convert.ToString(Session["COMPANYID"]));
|
|
|
if (Convert.ToDateTime(period.FDAY) > DateTime.Now)
|
|
|
{
|
|
|
head.ACCDATE = period.PERIOD;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
head.ACCDATE = DateTime.Now.ToString("yyyy-MM");
|
|
|
|
|
|
}
|
|
|
foreach (var enumValue in copyfieldlist)
|
|
|
{
|
|
|
if (enumValue.FIELDNAME == "ORDERTYPE") head.ORDERTYPE = oldhead.ORDERTYPE;
|
|
|
if (enumValue.FIELDNAME == "CUSTOMERNAME") head.CUSTOMERNAME = oldhead.CUSTOMERNAME;
|
|
|
if (enumValue.FIELDNAME == "BSSOURCEDETAIL") head.BSSOURCEDETAIL = oldhead.BSSOURCEDETAIL;
|
|
|
if (enumValue.FIELDNAME == "BSSOURCE") head.BSSOURCE = oldhead.BSSOURCE;
|
|
|
if (enumValue.FIELDNAME == "OP") head.OP = oldhead.OP;
|
|
|
if (enumValue.FIELDNAME == "CUSTSERVICE") head.CUSTSERVICE = oldhead.CUSTSERVICE;
|
|
|
if (enumValue.FIELDNAME == "SALE") head.SALE = oldhead.SALE;
|
|
|
if (enumValue.FIELDNAME == "VESSEL") head.VESSEL = oldhead.VESSEL;
|
|
|
if (enumValue.FIELDNAME == "VOYNO") head.VOYNO = oldhead.VOYNO;
|
|
|
if (enumValue.FIELDNAME == "ETD") head.ETD = oldhead.ETD;
|
|
|
if (enumValue.FIELDNAME == "PORTLOADID") head.PORTLOADID = oldhead.PORTLOADID;
|
|
|
if (enumValue.FIELDNAME == "PORTLOAD") head.PORTLOAD = oldhead.PORTLOAD;
|
|
|
if (enumValue.FIELDNAME == "PORTDISCHARGEID") head.PORTDISCHARGEID = oldhead.PORTDISCHARGEID;
|
|
|
if (enumValue.FIELDNAME == "PORTDISCHARGE") head.PORTDISCHARGE = oldhead.PORTDISCHARGE;
|
|
|
if (enumValue.FIELDNAME == "GOODSNAME") head.GOODSNAME = oldhead.GOODSNAME;
|
|
|
if (enumValue.FIELDNAME == "CONTRACTNO") head.CONTRACTNO = oldhead.CONTRACTNO;
|
|
|
if (enumValue.FIELDNAME == "KGS") head.KGS = oldhead.KGS;
|
|
|
if (enumValue.FIELDNAME == "PKGS") head.PKGS = oldhead.PKGS;
|
|
|
if (enumValue.FIELDNAME == "KINDPKGS") head.KINDPKGS = oldhead.KINDPKGS;
|
|
|
if (enumValue.FIELDNAME == "REMARK") head.REMARK = oldhead.REMARK;
|
|
|
if (enumValue.FIELDNAME == "YARD") head.YARD = oldhead.YARD;
|
|
|
if (enumValue.FIELDNAME == "BLTYPE") head.BLTYPE = oldhead.BLTYPE;
|
|
|
if (enumValue.FIELDNAME == "CBM") head.CBM = oldhead.CBM;
|
|
|
if (enumValue.FIELDNAME == "CARRIER") head.CARRIER = oldhead.CARRIER;
|
|
|
if (enumValue.FIELDNAME == "TRUCKER") head.TRUCKER = oldhead.TRUCKER;
|
|
|
if (enumValue.FIELDNAME == "CUSTOMSNUM") head.CUSTOMSNUM = oldhead.CUSTOMSNUM;
|
|
|
if (enumValue.FIELDNAME == "NOPKGS") head.NOPKGS = oldhead.NOPKGS;
|
|
|
if (enumValue.FIELDNAME == "GROSSWEIGHT") head.GROSSWEIGHT = oldhead.GROSSWEIGHT;
|
|
|
if (enumValue.FIELDNAME == "MEASUREMENT") head.MEASUREMENT = oldhead.MEASUREMENT;
|
|
|
if (enumValue.FIELDNAME == "DESCRIPTION") head.DESCRIPTION = oldhead.DESCRIPTION;
|
|
|
if (enumValue.FIELDNAME == "TOTALNO") head.TOTALNO = oldhead.TOTALNO;
|
|
|
if (enumValue.FIELDNAME == "TRANSNO") head.TRANSNO = oldhead.TRANSNO;
|
|
|
if (enumValue.FIELDNAME == "SHIPPERID") head.SHIPPERID = oldhead.SHIPPERID;
|
|
|
if (enumValue.FIELDNAME == "CONSIGNEEID") head.CONSIGNEEID = oldhead.CONSIGNEEID;
|
|
|
if (enumValue.FIELDNAME == "NOTIFYPARTYID") head.NOTIFYPARTYID = oldhead.NOTIFYPARTYID;
|
|
|
if (enumValue.FIELDNAME == "SHIPPER") head.SHIPPER = oldhead.SHIPPER;
|
|
|
if (enumValue.FIELDNAME == "CONSIGNEE") head.CONSIGNEE = oldhead.CONSIGNEE;
|
|
|
if (enumValue.FIELDNAME == "NOTIFYPARTY") head.NOTIFYPARTY = oldhead.NOTIFYPARTY;
|
|
|
if (enumValue.FIELDNAME == "AGENTID") head.AGENTID = oldhead.AGENTID;
|
|
|
if (enumValue.FIELDNAME == "AGENT") head.AGENT = oldhead.AGENT;
|
|
|
if (enumValue.FIELDNAME == "CLOSINGDATE") head.CLOSINGDATE = oldhead.CLOSINGDATE;
|
|
|
if (enumValue.FIELDNAME == "ETA") head.ETA = oldhead.ETA;
|
|
|
if (enumValue.FIELDNAME == "PLACERECEIPT" || enumValue.FIELDNAME == "PlACERECEIPT") head.PlACERECEIPT = oldhead.PlACERECEIPT;
|
|
|
if (enumValue.FIELDNAME == "PLACERECEIPTID") head.PLACERECEIPTID = oldhead.PLACERECEIPTID;
|
|
|
if (enumValue.FIELDNAME == "PLACEDELIVERYID") head.PLACEDELIVERYID = oldhead.PLACEDELIVERYID;
|
|
|
if (enumValue.FIELDNAME == "PLACEDELIVERY") head.PLACEDELIVERY = oldhead.PLACEDELIVERY;
|
|
|
if (enumValue.FIELDNAME == "DESTINATIONID") head.DESTINATIONID = oldhead.DESTINATIONID;
|
|
|
if (enumValue.FIELDNAME == "DESTINATION") head.DESTINATION = oldhead.DESTINATION;
|
|
|
if (enumValue.FIELDNAME == "NOBILL") head.NOBILL = oldhead.NOBILL;
|
|
|
if (enumValue.FIELDNAME == "ISSUEDATE") head.ISSUEDATE = oldhead.ISSUEDATE;
|
|
|
if (enumValue.FIELDNAME == "ISSUEPLACE") head.ISSUEPLACE = oldhead.ISSUEPLACE;
|
|
|
if (enumValue.FIELDNAME == "BLFRT") head.BLFRT = oldhead.BLFRT;
|
|
|
if (enumValue.FIELDNAME == "PREPARDAT") head.PREPARDAT = oldhead.PREPARDAT;
|
|
|
if (enumValue.FIELDNAME == "PAYABLEAT") head.PAYABLEAT = oldhead.PAYABLEAT;
|
|
|
if (enumValue.FIELDNAME == "SERVICE") head.SERVICE = oldhead.SERVICE;
|
|
|
if (enumValue.FIELDNAME == "MARKS") head.MARKS = oldhead.MARKS;
|
|
|
if (enumValue.FIELDNAME == "LANE") head.LANE = oldhead.LANE;
|
|
|
if (enumValue.FIELDNAME == "FORWARDER") head.FORWARDER = oldhead.FORWARDER;
|
|
|
if (enumValue.FIELDNAME == "INVNO") head.INVNO = oldhead.INVNO;
|
|
|
if (enumValue.FIELDNAME == "CARGOID") head.CARGOID = oldhead.CARGOID;
|
|
|
if (enumValue.FIELDNAME == "DCLASS") head.DCLASS = oldhead.DCLASS;
|
|
|
if (enumValue.FIELDNAME == "DUNNO") head.DUNNO = oldhead.DUNNO;
|
|
|
if (enumValue.FIELDNAME == "REEFERF") head.REEFERF = oldhead.REEFERF;
|
|
|
if (enumValue.FIELDNAME == "TEMPID") head.TEMPID = oldhead.TEMPID;
|
|
|
if (enumValue.FIELDNAME == "TEMPSET") head.TEMPSET = oldhead.TEMPSET;
|
|
|
if (enumValue.FIELDNAME == "TEMPMAX") head.TEMPMAX = oldhead.TEMPMAX;
|
|
|
if (enumValue.FIELDNAME == "TEMPMIN") head.TEMPMIN = oldhead.TEMPMIN;
|
|
|
if (enumValue.FIELDNAME == "ORDTYPE") head.ORDTYPE = oldhead.ORDTYPE;
|
|
|
if (enumValue.FIELDNAME == "ORDERNO") head.ORDERNO = oldhead.ORDERNO;
|
|
|
if (enumValue.FIELDNAME == "INSURANCEER") head.INSURANCEER = oldhead.INSURANCEER;
|
|
|
if (enumValue.FIELDNAME == "INSURANCENO") head.INSURANCENO = oldhead.INSURANCENO;
|
|
|
if (enumValue.FIELDNAME == "INAMOUT") head.INAMOUT = oldhead.INAMOUT;
|
|
|
if (enumValue.FIELDNAME == "ISFUMIGATION") head.ISFUMIGATION = oldhead.ISFUMIGATION;
|
|
|
if (enumValue.FIELDNAME == "ISSTORAGE") head.ISSTORAGE = oldhead.ISSTORAGE;
|
|
|
if (enumValue.FIELDNAME == "ISLAND") head.ISLAND = oldhead.ISLAND;
|
|
|
if (enumValue.FIELDNAME == "ISCUSTOMS") head.ISCUSTOMS = oldhead.ISCUSTOMS;
|
|
|
if (enumValue.FIELDNAME == "ISINSPECTION") head.ISINSPECTION = oldhead.ISINSPECTION;
|
|
|
if (enumValue.FIELDNAME == "ISBOOKING") head.ISBOOKING = oldhead.ISBOOKING;
|
|
|
if (enumValue.FIELDNAME == "ISAGENT") head.ISAGENT = oldhead.ISAGENT;
|
|
|
if (enumValue.FIELDNAME == "ISHBLNO") head.ISHBLNO = oldhead.ISHBLNO;
|
|
|
if (enumValue.FIELDNAME == "SERVICE9") head.SERVICE9 = oldhead.SERVICE9;
|
|
|
if (enumValue.FIELDNAME == "SERVICE10") head.SERVICE10 = oldhead.SERVICE10;
|
|
|
if (enumValue.FIELDNAME == "DOC") head.DOC = oldhead.DOC;
|
|
|
if (enumValue.FIELDNAME == "PACKINGTYPE") head.PACKINGTYPE = oldhead.PACKINGTYPE;
|
|
|
if (enumValue.FIELDNAME == "WAREHOUSE") head.WAREHOUSE = oldhead.WAREHOUSE;
|
|
|
if (enumValue.FIELDNAME == "CLOSEDOCDATE") head.CLOSEDOCDATE = oldhead.CLOSEDOCDATE;
|
|
|
if (enumValue.FIELDNAME == "INTOPORTDATE") head.INTOPORTDATE = oldhead.INTOPORTDATE;
|
|
|
if (enumValue.FIELDNAME == "MBLFRT") head.MBLFRT = oldhead.MBLFRT;
|
|
|
if (enumValue.FIELDNAME == "STLNAME") head.STLNAME = oldhead.STLNAME;
|
|
|
if (enumValue.FIELDNAME == "STLDATE") head.STLDATE = oldhead.STLDATE;
|
|
|
if (enumValue.FIELDNAME == "OPERATOR") head.OPERATOR = oldhead.OPERATOR;
|
|
|
if (enumValue.FIELDNAME == "OPERATORTEL") head.OPERATORTEL = oldhead.OPERATORTEL;
|
|
|
if (enumValue.FIELDNAME == "FINANCIALSTAFF") head.FINANCIALSTAFF = oldhead.FINANCIALSTAFF;
|
|
|
if (enumValue.FIELDNAME == "SOURCECODE") head.SOURCECODE = oldhead.SOURCECODE;
|
|
|
if (enumValue.FIELDNAME == "ISCONTAINERSOC") head.ISCONTAINERSOC = oldhead.ISCONTAINERSOC;
|
|
|
if (enumValue.FIELDNAME == "DPAGE") head.DPAGE = oldhead.DPAGE;
|
|
|
if (enumValue.FIELDNAME == "DLABEL") head.DLABEL = oldhead.DLABEL;
|
|
|
if (enumValue.FIELDNAME == "LINKMAN") head.LINKMAN = oldhead.LINKMAN;
|
|
|
if (enumValue.FIELDNAME == "VESSELID") head.VESSELID = oldhead.VESSELID;
|
|
|
if (enumValue.FIELDNAME == "ISSUEPLACEID") head.ISSUEPLACEID = oldhead.ISSUEPLACEID;
|
|
|
if (enumValue.FIELDNAME == "CUSTOMNO") head.CUSTOMNO = oldhead.CUSTOMNO;
|
|
|
if (enumValue.FIELDNAME == "CUSTOMDATE") head.CUSTOMDATE = oldhead.CUSTOMDATE;
|
|
|
if (enumValue.FIELDNAME == "INSPECTIONNO") head.INSPECTIONNO = oldhead.INSPECTIONNO;
|
|
|
if (enumValue.FIELDNAME == "INSPECTIONDATE") head.INSPECTIONDATE = oldhead.INSPECTIONDATE;
|
|
|
if (enumValue.FIELDNAME == "ENTERP") head.ENTERP = oldhead.ENTERP;
|
|
|
if (enumValue.FIELDNAME == "TERMSDELIVERY") head.TERMSDELIVERY = oldhead.TERMSDELIVERY;
|
|
|
if (enumValue.FIELDNAME == "INSPECTSERVICE") head.INSPECTSERVICE = oldhead.INSPECTSERVICE;
|
|
|
if (enumValue.FIELDNAME == "TRADETERM") head.TRADETERM = oldhead.TRADETERM;
|
|
|
if (enumValue.FIELDNAME == "SHIPAGENCY") head.SHIPAGENCY = oldhead.SHIPAGENCY;
|
|
|
if (enumValue.FIELDNAME == "ISMOREGOOD") head.ISMOREGOOD = oldhead.ISMOREGOOD;
|
|
|
if (enumValue.FIELDNAME == "CUSTNO") head.CUSTNO = oldhead.CUSTNO;
|
|
|
if (enumValue.FIELDNAME == "MBLNO") head.MBLNO = oldhead.MBLNO;
|
|
|
if (enumValue.FIELDNAME == "HBLNO") head.HBLNO = oldhead.HBLNO;
|
|
|
if (enumValue.FIELDNAME == "APPLYNO") head.APPLYNO = oldhead.APPLYNO;
|
|
|
if (enumValue.FIELDNAME == "UNITOFWEIGHT") head.UNITOFWEIGHT = oldhead.UNITOFWEIGHT;
|
|
|
if (enumValue.FIELDNAME == "ISSUETYPE") head.ISSUETYPE = oldhead.ISSUETYPE;
|
|
|
if (enumValue.FIELDNAME == "VESSELID") head.VESSELID = oldhead.VESSELID;
|
|
|
if (enumValue.FIELDNAME == "SALECORPID") head.SALECORPID = oldhead.SALECORPID;
|
|
|
if (enumValue.FIELDNAME == "COUNTRYOFORIGIN") head.COUNTRYOFORIGIN = oldhead.COUNTRYOFORIGIN;
|
|
|
if (enumValue.FIELDNAME == "NUMBERPLATE") head.NUMBERPLATE = oldhead.NUMBERPLATE;
|
|
|
if (enumValue.FIELDNAME == "UNITS") head.UNITS = oldhead.UNITS;
|
|
|
if (enumValue.FIELDNAME == "TRANSKINDPKGS") head.TRANSKINDPKGS = oldhead.TRANSKINDPKGS;
|
|
|
if (enumValue.FIELDNAME == "BALES") head.BALES = oldhead.BALES;
|
|
|
if (enumValue.FIELDNAME == "CUSTOMSER") head.CUSTOMSER = oldhead.CUSTOMSER;
|
|
|
if (enumValue.FIELDNAME == "INSPECTION") head.INSPECTION = oldhead.INSPECTION;
|
|
|
if (enumValue.FIELDNAME == "INSPECTIONNO") head.INSPECTIONNO = oldhead.INSPECTIONNO;
|
|
|
if (enumValue.FIELDNAME == "INSPECTIONDATE") head.INSPECTIONDATE = oldhead.INSPECTIONDATE;
|
|
|
if (enumValue.FIELDNAME == "FBP") head.FBP = oldhead.FBP;
|
|
|
if (enumValue.FIELDNAME == "BMDDATE") head.BMDDATE = oldhead.BMDDATE;
|
|
|
if (enumValue.FIELDNAME == "MDTDATE") head.MDTDATE = oldhead.MDTDATE;
|
|
|
if (enumValue.FIELDNAME == "MT") head.MT = oldhead.MT;
|
|
|
if (enumValue.FIELDNAME == "TRADINGAGENCY") head.TRADINGAGENCY = oldhead.TRADINGAGENCY;
|
|
|
if (enumValue.FIELDNAME == "GOODSTYPENAME") head.GOODSTYPENAME = oldhead.GOODSTYPENAME;
|
|
|
if (enumValue.FIELDNAME == "SHOWNAME") head.SHOWNAME = oldhead.SHOWNAME;
|
|
|
if (enumValue.FIELDNAME == "APPROVENO") head.APPROVENO = oldhead.APPROVENO;
|
|
|
if (enumValue.FIELDNAME == "GRADE") head.GRADE = oldhead.GRADE;
|
|
|
if (enumValue.FIELDNAME == "NOR") head.NOR = oldhead.NOR;
|
|
|
if (enumValue.FIELDNAME == "STORAGENAME") head.STORAGENAME = oldhead.STORAGENAME;
|
|
|
if (enumValue.FIELDNAME == "ISFORCEDTODESPATCH") head.ISFORCEDTODESPATCH = oldhead.ISFORCEDTODESPATCH;
|
|
|
if (enumValue.FIELDNAME == "BSKGS") head.BSKGS = oldhead.BSKGS;
|
|
|
if (enumValue.FIELDNAME == "ACTUALKGS") head.ACTUALKGS = oldhead.ACTUALKGS;
|
|
|
if (enumValue.FIELDNAME == "DRAFTKGS") head.DRAFTKGS = oldhead.DRAFTKGS;
|
|
|
if (enumValue.FIELDNAME == "WHARFSKGS") head.WHARFSKGS = oldhead.WHARFSKGS;
|
|
|
if (enumValue.FIELDNAME == "WMSINKGS") head.WMSINKGS = oldhead.WMSINKGS;
|
|
|
if (enumValue.FIELDNAME == "WMSOUTKGS") head.WMSOUTKGS = oldhead.WMSOUTKGS;
|
|
|
if (enumValue.FIELDNAME == "DIFFERENCEKGS") head.DIFFERENCEKGS = oldhead.DIFFERENCEKGS;
|
|
|
if (enumValue.FIELDNAME == "WATERCONTENT") head.WATERCONTENT = oldhead.WATERCONTENT;
|
|
|
if (enumValue.FIELDNAME == "WATERDENSITY") head.WATERDENSITY = oldhead.WATERDENSITY;
|
|
|
if (enumValue.FIELDNAME == "WMSTYPE") head.WMSTYPE = oldhead.WMSTYPE;
|
|
|
if (enumValue.FIELDNAME == "ISMOREGOOD") head.ISMOREGOOD = oldhead.ISMOREGOOD;
|
|
|
if (enumValue.FIELDNAME == "CHANGEDOCDATE") head.CHANGEDOCDATE = oldhead.CHANGEDOCDATE;
|
|
|
if (enumValue.FIELDNAME == "ISMOREGOOD") head.ISMOREGOOD = oldhead.ISMOREGOOD;
|
|
|
if (enumValue.FIELDNAME == "TERMSDELIVERY") head.TERMSDELIVERY = oldhead.TERMSDELIVERY;
|
|
|
if (enumValue.FIELDNAME == "INSPECTSERVICE") head.INSPECTSERVICE = oldhead.INSPECTSERVICE;
|
|
|
if (enumValue.FIELDNAME == "SHIPAGENCY") head.SHIPAGENCY = oldhead.SHIPAGENCY;
|
|
|
if (enumValue.FIELDNAME == "ISBONDED") head.ISBONDED = oldhead.ISBONDED;
|
|
|
if (enumValue.FIELDNAME == "TIHUOTIME") head.TIHUOTIME = oldhead.TIHUOTIME;
|
|
|
if (enumValue.FIELDNAME == "SJYHDATE") head.SJYHDATE = oldhead.SJYHDATE;
|
|
|
if (enumValue.FIELDNAME == "YaXiangDate") head.YaXiangDate = oldhead.YaXiangDate;
|
|
|
if (enumValue.FIELDNAME == "YaXiangDiDian") head.YaXiangDiDian = oldhead.YaXiangDiDian;
|
|
|
if (enumValue.FIELDNAME == "YaXiangJinE") head.YaXiangJinE = oldhead.YaXiangJinE;
|
|
|
if (enumValue.FIELDNAME == "CTNNUM") head.CTNNUM = oldhead.CTNNUM;
|
|
|
if (enumValue.FIELDNAME == "WMSCTNNUM") head.WMSCTNNUM = oldhead.WMSCTNNUM;
|
|
|
if (enumValue.FIELDNAME == "MaTou") head.MaTou = oldhead.MaTou;
|
|
|
if (enumValue.FIELDNAME == "TRADETYPE") head.TRADETYPE = oldhead.TRADETYPE;
|
|
|
}
|
|
|
if (copyfee == "true")
|
|
|
{
|
|
|
var feelist = MsChFeeDAL.GetAllDataList(condition);
|
|
|
if (feelist != null)
|
|
|
{
|
|
|
for (int _i = 0; _i < feelist.Count; _i++)
|
|
|
{
|
|
|
feelist[_i].BsNo = "*";
|
|
|
}
|
|
|
MsChFeeDAL.SaveFee(feelist, head.BSNO, CookieConfig.GetCookie_UserId(Request));
|
|
|
}
|
|
|
}
|
|
|
|
|
|
}
|
|
|
}
|
|
|
var json = JsonConvert.Serialize(
|
|
|
new { Success = true, Message = "查询成功", data = head });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public ContentResult GetBodyList(string condition)
|
|
|
{
|
|
|
var dataList = MsOpSeaiDAL.GetBodyList(condition);
|
|
|
var json = JsonConvert.Serialize(new { Success = true, Message = "查询成功", totalCount = dataList.Count, data = dataList.ToList() });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
|
|
|
|
|
|
#region 保存
|
|
|
public ContentResult Save(string opstatus, string data, string data2, string data3, string body, string goodsbody)
|
|
|
{
|
|
|
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
}
|
|
|
//
|
|
|
var headData = JsonConvert.Deserialize<MsOpSeai>(data.Replace("}", ",") + data2.Replace("{", "").Replace("}", ",") + data3.Replace("{", ""));
|
|
|
var bodyList = JsonConvert.Deserialize<List<MsOpSeaiDetail>>(body);
|
|
|
var goodsbodyList = JsonConvert.Deserialize<List<MsOpApplyDetail>>(goodsbody);
|
|
|
|
|
|
var isPost = true;
|
|
|
var errorstr = "";
|
|
|
var iscreatecustno = false;
|
|
|
#region 默认值
|
|
|
T_ALL_DA T_ALL_DA = new EntityDA.T_ALL_DA();
|
|
|
string rq = T_ALL_DA.GetStrSQL("rq", "select getdate() as rq");
|
|
|
if (headData.INPUTBY.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.INPUTBY = Convert.ToString(Session["SHOWNAME"]);
|
|
|
}
|
|
|
if (headData.CORPID == "" || headData.CORPID ==null)
|
|
|
{
|
|
|
headData.CORPID = Convert.ToString(Session["COMPANYID"]);
|
|
|
}
|
|
|
var isuse = false;
|
|
|
var billnoset = MsSysBillNoSetDAL.GetData("OPLBNAME='海运进口'", Convert.ToString(Session["COMPANYID"]));
|
|
|
if (billnoset.BILLTYPE != "")
|
|
|
isuse = true;
|
|
|
else
|
|
|
isuse = MsBaseInfoDAL.GetRuleUse("委托编号", "2");
|
|
|
if (headData.CUSTNO.Trim() == "" || headData.CUSTNO ==null)
|
|
|
{
|
|
|
|
|
|
if (isuse)
|
|
|
{
|
|
|
if (billnoset.BILLTYPE != "")
|
|
|
{
|
|
|
var FENCUSTNOE = MsSysParamSetDAL.GetData("PARAMNAME='FENCUSTNOE'");
|
|
|
if (FENCUSTNOE.PARAMVALUE == "1" && headData.MASTERNO != "" && headData.BSNO != headData.MASTERNO)
|
|
|
{
|
|
|
headData.CUSTNO = MsSysBillNoSetDAL.GetFenCustNo(headData.MASTERNO, "op_seai");
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
|
|
|
var CUSTOMHEAD = "";
|
|
|
if (billnoset.CUSTOMHEAD != "")
|
|
|
{
|
|
|
var HBLCUSTOMHEAD = billnoset.CUSTOMHEAD;
|
|
|
if ((HBLCUSTOMHEAD.IndexOf("[SALE]") >= 0) && !string.IsNullOrEmpty(headData.SALE))
|
|
|
{
|
|
|
var user = SysUserDAL.GetData("u.SHOWNAME='" + headData.SALE + "'");
|
|
|
if (!string.IsNullOrEmpty(user.NOCODE))
|
|
|
HBLCUSTOMHEAD = HBLCUSTOMHEAD.Replace("[SALE]", user.NOCODE);
|
|
|
|
|
|
}
|
|
|
if ((HBLCUSTOMHEAD.IndexOf("[OP]") >= 0) && !string.IsNullOrEmpty(headData.OP))
|
|
|
{
|
|
|
var user = SysUserDAL.GetData("u.SHOWNAME='" + headData.OP + "'");
|
|
|
if (!string.IsNullOrEmpty(user.NOCODE))
|
|
|
HBLCUSTOMHEAD = HBLCUSTOMHEAD.Replace("[OP]", user.NOCODE);
|
|
|
}
|
|
|
CUSTOMHEAD = HBLCUSTOMHEAD;
|
|
|
var CUST = MsInfoClientDAL.GetData("SHORTNAME='" + headData.CUSTOMERNAME + "'");
|
|
|
CUSTOMHEAD = CUSTOMHEAD.Replace("[CUSTCODE]", CUST.CODENAME);
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
headData.CUSTNO = MsSysBillNoSetDAL.GetBillNo(billnoset, headData.ETD.ToString().Trim(), headData.ACCDATE.ToString().Trim(), "", headData.OP, headData.SALECORPID, CUSTOMHEAD);
|
|
|
iscreatecustno = true;
|
|
|
|
|
|
}
|
|
|
}
|
|
|
else
|
|
|
headData.CUSTNO = MsOpSeaiDAL.getCodeRule("委托编号", "CUSTNO", headData.BSDATE.ToString().Trim(), headData.ACCDATE.ToString().Trim(), Convert.ToString(Session["USERID"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
}
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
|
|
|
var ct = MsOpSeaiDAL.GetRdCount("BSNO<>'" + headData.BSNO + "' AND CUSTNO='" + headData.CUSTNO + "' and CORPID='" + Convert.ToString(Session["COMPANYID"]) + "'");
|
|
|
if (ct != 0)
|
|
|
{
|
|
|
isPost = false;
|
|
|
errorstr = "委托编号重复";
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
if (headData.CUSTNO == "")
|
|
|
{
|
|
|
isPost = false;
|
|
|
errorstr = "委托编号为空";
|
|
|
}
|
|
|
|
|
|
//
|
|
|
if (headData.MBLNO != "" && headData.MBLNO != null && headData.BLTYPE != "拼箱分票")
|
|
|
{
|
|
|
var mblreapeat = MsSysParamSetDAL.GetData("PARAMNAME='SeaiMblrepeat'");
|
|
|
if (mblreapeat.PARAMVALUE != "1")
|
|
|
{
|
|
|
var ct = MsOpSeaiDAL.GetRdCount("BSNO<>'" + headData.BSNO + "' AND MBLNO='" + headData.MBLNO + "' and CORPID='" + Convert.ToString(Session["COMPANYID"]) + "'");
|
|
|
if (ct != 0)
|
|
|
{
|
|
|
isPost = false;
|
|
|
errorstr = "主提单号重复";
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
isuse = MsBaseInfoDAL.GetRuleUse("主提单号", "2");
|
|
|
if (isuse)
|
|
|
{
|
|
|
headData.CUSTNO = MsOpSeaiDAL.getCodeRule("主提单号", "MBLNO", headData.BSDATE.ToString().Trim(), headData.ACCDATE.ToString().Trim(), Convert.ToString(Session["USERID"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
}
|
|
|
}
|
|
|
//
|
|
|
if (headData.HBLNO != "" && headData.HBLNO != null)
|
|
|
{
|
|
|
var mblreapeat = MsSysParamSetDAL.GetData("PARAMNAME='SeaiHblrepeat'");
|
|
|
if (mblreapeat.PARAMVALUE != "1")
|
|
|
{
|
|
|
var ct = MsOpSeaiDAL.GetRdCount("BSNO<>'" + headData.BSNO + "' AND HBLNO='" + headData.HBLNO + "' and CORPID='" + Convert.ToString(Session["COMPANYID"]) + "'");
|
|
|
if (ct != 0)
|
|
|
{
|
|
|
isPost = false;
|
|
|
errorstr = "分提单号重复";
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
var billnosethblno = MsSysBillNoSetDAL.GetData("OPLBNAME='海运进口' AND RULEBLNO='分提单号' ", Convert.ToString(Session["COMPANYID"]));
|
|
|
if (billnosethblno.BILLTYPE != "" && billnosethblno.ISAUTO == "1")
|
|
|
{
|
|
|
if (billnosethblno.CUSTOMHEAD != "")
|
|
|
{
|
|
|
var HBLCUSTOMHEAD = billnosethblno.CUSTOMHEAD;
|
|
|
var bssource = BasicDataRefDAL.GetSourceData("SOURCENAME='" + headData.BSSOURCE + "'");
|
|
|
var lanelist = BasicDataRefDAL.GetCodeLaneList("");
|
|
|
var lane = lanelist.Find(x => x.LANE == headData.LANE);
|
|
|
var bstypelist = PubSysDAL.GetEnumValueList(97042, "");
|
|
|
var bstype = bstypelist.Find(x => x.EnumValueName == headData.BLTYPE);
|
|
|
HBLCUSTOMHEAD = HBLCUSTOMHEAD.Replace("[BS]", bssource.SOURCECODE);
|
|
|
HBLCUSTOMHEAD = HBLCUSTOMHEAD.Replace("[LN]", lane.LANEID);
|
|
|
HBLCUSTOMHEAD = HBLCUSTOMHEAD.Replace("[BT]", bstype.EnumValueName_2);
|
|
|
// HBLCUSTOMHEAD = HBLCUSTOMHEAD.Replace("[BS]", bssource.SOURCECODE);
|
|
|
// HBLCUSTOMHEAD = HBLCUSTOMHEAD.Replace("[BS]", bssource.SOURCECODE);
|
|
|
|
|
|
var hblno = MsSysBillNoSetDAL.GetBillNoHblno(billnosethblno, headData.ETD.ToString().Trim(), headData.ACCDATE.ToString().Trim(), HBLCUSTOMHEAD);
|
|
|
headData.HBLNO = hblno;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
var hblno = MsSysBillNoSetDAL.GetBillNo(billnosethblno, headData.ETD.ToString().Trim(), headData.ACCDATE.ToString().Trim(), "", headData.OP, headData.SALECORPID);
|
|
|
headData.HBLNO = hblno;
|
|
|
}
|
|
|
|
|
|
}
|
|
|
}
|
|
|
|
|
|
if (headData.ORDERNO != "" && headData.ORDERNO != null)
|
|
|
{
|
|
|
var ct = MsOpSeaiDAL.GetRdCount("BSNO<>'" + headData.BSNO + "' AND ORDERNO='" + headData.ORDERNO + "'");
|
|
|
if (ct != 0)
|
|
|
{
|
|
|
isPost = false;
|
|
|
errorstr = "订舱编号重复";
|
|
|
}
|
|
|
}
|
|
|
|
|
|
//
|
|
|
if (headData.ACCDATE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.ACCDATE = DateTime.Parse(rq).ToString("yyyy-MM");
|
|
|
}
|
|
|
if (headData.BSDATE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.BSDATE = rq;
|
|
|
}
|
|
|
//
|
|
|
if (headData.ETD != null)
|
|
|
{
|
|
|
if (headData.ETD.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.ETD = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.ETA != null)
|
|
|
{
|
|
|
if (headData.ETA.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.ETA = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.CUSTOMDATE != null)
|
|
|
{
|
|
|
if (headData.CUSTOMDATE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.CUSTOMDATE = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.INSPECTIONDATE != null)
|
|
|
{
|
|
|
if (headData.INSPECTIONDATE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.INSPECTIONDATE = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.BMDDATE != null)
|
|
|
{
|
|
|
if (headData.BMDDATE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.BMDDATE = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.MDTDATE != null)
|
|
|
{
|
|
|
if (headData.MDTDATE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.MDTDATE = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.UPDATETIME != null)
|
|
|
{
|
|
|
if (headData.UPDATETIME.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.UPDATETIME = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.CLOSINGDATE != null)
|
|
|
{
|
|
|
if (headData.CLOSINGDATE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.CLOSINGDATE = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.ISSUEDATE != null)
|
|
|
{
|
|
|
if (headData.ISSUEDATE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.ISSUEDATE = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.CLOSEDOCDATE != null)
|
|
|
{
|
|
|
if (headData.CLOSEDOCDATE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.CLOSEDOCDATE = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.INTOPORTDATE != null)
|
|
|
{
|
|
|
if (headData.INTOPORTDATE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.INTOPORTDATE = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.TARRIFSPAIEDTIEM != null)
|
|
|
{
|
|
|
if (headData.TARRIFSPAIEDTIEM.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.TARRIFSPAIEDTIEM = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.NOR != null)
|
|
|
{
|
|
|
if (headData.NOR.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.NOR = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.STLDATE != null)
|
|
|
{
|
|
|
if (headData.STLDATE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.STLDATE = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.PORTLOAD == null)
|
|
|
{
|
|
|
headData.PORTLOAD = "";
|
|
|
}
|
|
|
if (headData.PORTDISCHARGE == null)
|
|
|
{
|
|
|
headData.PORTDISCHARGE = "";
|
|
|
}
|
|
|
if (headData.GOODSNAME == null)
|
|
|
{
|
|
|
headData.GOODSNAME = "";
|
|
|
}
|
|
|
if (headData.CUSTOMSER == null)
|
|
|
{
|
|
|
headData.CUSTOMSER = "";
|
|
|
}
|
|
|
if (headData.INSPECTION == null)
|
|
|
{
|
|
|
headData.INSPECTION = "";
|
|
|
}
|
|
|
if (headData.KINDPKGS == null)
|
|
|
{
|
|
|
headData.KINDPKGS = "";
|
|
|
}
|
|
|
if (headData.CARRIER == null)
|
|
|
{
|
|
|
headData.CARRIER = "";
|
|
|
}
|
|
|
if (headData.TRUCKER == null)
|
|
|
{
|
|
|
headData.TRUCKER = "";
|
|
|
}
|
|
|
if (headData.GOODSTYPENAME == null)
|
|
|
{
|
|
|
headData.GOODSTYPENAME = "";
|
|
|
}
|
|
|
if (headData.CURRENCY == null)
|
|
|
{
|
|
|
headData.CURRENCY = "";
|
|
|
}
|
|
|
if (headData.WMSTYPE == null)
|
|
|
{
|
|
|
headData.WMSTYPE = "";
|
|
|
}
|
|
|
if (headData.CHANGEDOCDATE == "") headData.CHANGEDOCDATE = null;
|
|
|
if (headData.HGCYDATE == "") headData.HGCYDATE = null;
|
|
|
if (headData.CONTRACTDATE == "") headData.CONTRACTDATE = null;
|
|
|
//需求编号:SR2017071700004
|
|
|
if (headData.SJYHDATE != null)
|
|
|
{
|
|
|
if (headData.SJYHDATE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.SJYHDATE = null;
|
|
|
}
|
|
|
}
|
|
|
if (headData.YaXiangDate != null)
|
|
|
{
|
|
|
if (headData.YaXiangDate.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.YaXiangDate = null;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
//
|
|
|
|
|
|
var nowperiod = ChMonthCloseDAL.GetData("", Convert.ToString(Session["COMPANYID"]));
|
|
|
if (opstatus == "add")
|
|
|
{
|
|
|
#region 默认值
|
|
|
headData.ORDERTYPE = "操作录入";
|
|
|
headData.CREATETIME = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
|
|
|
if (headData.BSTYPE == null)
|
|
|
{
|
|
|
headData.BSTYPE = "普通货";
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
if (headData.BSTYPE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.BSTYPE = "普通货";
|
|
|
}
|
|
|
}
|
|
|
//
|
|
|
if (headData.BLTYPE == null)
|
|
|
{
|
|
|
headData.BLTYPE = "整箱";
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
if (headData.BLTYPE.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.BLTYPE = "整箱";
|
|
|
}
|
|
|
}
|
|
|
//
|
|
|
if (headData.MASTERNO == null)
|
|
|
{
|
|
|
headData.MASTERNO = headData.BSNO;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
if (headData.MASTERNO.ToString().Trim() == "")
|
|
|
{
|
|
|
headData.MASTERNO = headData.BSNO;
|
|
|
}
|
|
|
}
|
|
|
#endregion
|
|
|
//
|
|
|
headData.DbOperationType = DbOperationType.DbotIns;
|
|
|
if (Convert.ToDateTime(nowperiod.PERIOD + "-01") > Convert.ToDateTime(headData.ACCDATE + "-01"))
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse
|
|
|
{
|
|
|
Success = false,
|
|
|
Message = "已月末结转,不允许添加业务!",
|
|
|
};
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
else if (opstatus == "edit")
|
|
|
{
|
|
|
headData.DbOperationType = DbOperationType.DbotUpd;
|
|
|
headData.ModelUIStatus = "E";
|
|
|
if (Convert.ToDateTime(nowperiod.PERIOD + "-01") > Convert.ToDateTime(headData.ACCDATE + "-01"))
|
|
|
{
|
|
|
|
|
|
var ACCDATE = T_ALL_DA.GetStrSQL("ACCDATE", "select ACCDATE from v_op_bill WHERE BSNO='" + headData.BSNO + "'");
|
|
|
if (ACCDATE != headData.ACCDATE)
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse
|
|
|
{
|
|
|
Success = false,
|
|
|
Message = "已月末结转,不允许修改会计期间!",
|
|
|
};
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
headData.DbOperationType = DbOperationType.DbotDel;
|
|
|
}
|
|
|
|
|
|
if (opstatus == "add" || opstatus == "edit") {
|
|
|
|
|
|
//var _r1 = QY_addWarehouseNotice(headData);
|
|
|
|
|
|
var _r2 = QY_ETA_SEND(headData);
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
if (headData.ETD != "" && headData.CUSTOMERNAME != "")// headData.STLDATE == "" &&
|
|
|
{
|
|
|
//根据客户、开船日计算账期
|
|
|
|
|
|
var _dmb = MsInfoClientDAL.GetSTLDATE(headData.CUSTOMERNAME, "海运出口", headData.ETD, headData.SALE);
|
|
|
headData.STLNAME = _dmb.STLNAME;
|
|
|
headData.STLDATE = _dmb.STLDATE;
|
|
|
|
|
|
if (_dmb.STLNAME == "")
|
|
|
{
|
|
|
headData.STLNAME = "现结买单";
|
|
|
headData.STLDATE = headData.ETD;
|
|
|
}
|
|
|
if (_dmb.BSSOURCE != "") headData.BSSOURCE = _dmb.BSSOURCE;
|
|
|
}
|
|
|
headData.BSSOURCE = headData.BSSOURCE.Trim();
|
|
|
|
|
|
if (headData.MASTERNO == null) { headData.MASTERNO = headData.BSNO; }
|
|
|
if (headData.ETA == "") headData.ETA = null;
|
|
|
if (headData.ETD == "") headData.ETD = null;
|
|
|
if (headData.STLDATE == "") headData.STLDATE = null;
|
|
|
if (headData.CUSTOMDATE == "") headData.CUSTOMDATE = null;
|
|
|
if (headData.INSPECTIONDATE == "") headData.INSPECTIONDATE = null;
|
|
|
if (headData.ISSUEDATE == "") headData.ISSUEDATE = null;
|
|
|
if (headData.CLOSEDOCDATE == "") headData.CLOSEDOCDATE = null;
|
|
|
if (headData.INTOPORTDATE == "") headData.INTOPORTDATE = null;
|
|
|
if (headData.BMDDATE == "") headData.BMDDATE = null;
|
|
|
if (headData.MDTDATE == "") headData.MDTDATE = null;
|
|
|
if (headData.TARRIFSPAIEDTIEM == "") headData.TARRIFSPAIEDTIEM = null;
|
|
|
if (headData.NOR == "") headData.NOR = null;
|
|
|
if (headData.UPDATETIME == "") headData.UPDATETIME = null;
|
|
|
if (headData.TIHUOTIME == "") headData.TIHUOTIME = null;
|
|
|
|
|
|
//需求编号:SR2017071700004
|
|
|
if (headData.SJYHDATE == "") headData.SJYHDATE = null;
|
|
|
if (headData.YaXiangDate == "") headData.YaXiangDate = null;
|
|
|
|
|
|
|
|
|
#region 判断字段长度
|
|
|
if (isPost)
|
|
|
{
|
|
|
var seaefield = MsSoftSysTableDAL.GetDefTableDetailList("OP_SEAI");
|
|
|
foreach (var enumValue in seaefield)
|
|
|
{
|
|
|
if (enumValue.FIELDNAME == "MBLNO" && headData.MBLNO.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "主提单号超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "HBLNO" && headData.HBLNO.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "分提单号超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "CUSTNO" && headData.CUSTNO.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "委托编号超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "ORDERNO" && headData.ORDERNO != null && headData.ORDERNO.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "订舱编号超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "SHIPPERID" && headData.SHIPPERID != null && headData.SHIPPERID.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "发货人代码超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "CONSIGNEEID" && headData.CONSIGNEEID != null && headData.CONSIGNEEID.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "收货人代码超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "NOTIFYPARTYID" && headData.NOTIFYPARTYID != null && headData.NOTIFYPARTYID.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "通知人代码超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "SHIPPER" && headData.SHIPPER != null && headData.SHIPPER.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "发货人超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "CONSIGNEE" && headData.CONSIGNEE != null && headData.CONSIGNEE.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "收货人超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "NOTIFYPARTY" && headData.NOTIFYPARTY != null && headData.NOTIFYPARTY.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "通知人超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "AGENTID" && headData.AGENTID != null && headData.AGENTID.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "代理名称超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "AGENT" && headData.AGENT != null && headData.AGENT.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "代理超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "VESSEL" && headData.VESSEL != null && headData.VESSEL.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "船名超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "VOYNO" && headData.VOYNO != null && headData.VOYNO.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "航次超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "PORTLOADID" && headData.PORTLOADID != null && headData.PORTLOADID.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "装货港代码超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "PORTLOAD" && headData.PORTLOAD != null && headData.PORTLOAD.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "装货港超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "PORTDISCHARGEID" && headData.PORTDISCHARGEID != null && headData.PORTDISCHARGEID.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "卸货港代码超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "PORTDISCHARGE" && headData.PORTDISCHARGE != null && headData.PORTDISCHARGE.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "卸货港超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "PLACEDELIVERYID" && headData.PLACEDELIVERYID != null && headData.PLACEDELIVERYID.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "交货地代码超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "PLACEDELIVERY" && headData.PLACEDELIVERY != null && headData.PLACEDELIVERY.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "交货地超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "DESTINATIONID" && headData.DESTINATIONID != null && headData.DESTINATIONID.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "目的地代码超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "DESTINATION" && headData.DESTINATION != null && headData.DESTINATION.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "目的地超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "ISSUEPLACE" && headData.ISSUEPLACE != null && headData.ISSUEPLACE.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "签单地点超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "BLFRT" && headData.BLFRT != null && headData.BLFRT.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "付费方式超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "PREPARDAT" && headData.PREPARDAT != null && headData.PREPARDAT.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "预付地点超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "PAYABLEAT" && headData.PAYABLEAT != null && headData.PAYABLEAT.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "到付地点超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "SERVICE" && headData.SERVICE != null && headData.SERVICE.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "运输条款超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "MARKS" && headData.MARKS != null && headData.MARKS.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "唛头超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "NOPKGS" && headData.NOPKGS != null && headData.NOPKGS.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "件数包装超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "DESCRIPTION" && headData.DESCRIPTION != null && headData.DESCRIPTION.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "货物描述超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "GOODSNAME" && headData.GOODSNAME != null && headData.GOODSNAME.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "品名超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "KINDPKGS" && headData.KINDPKGS != null && headData.KINDPKGS.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "包装超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "LANE" && headData.LANE != null && headData.LANE.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "航线超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "INVNO" && headData.INVNO != null && headData.INVNO.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "发票号超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "DCLASS" && headData.DCLASS != null && headData.DCLASS.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "危险品类别超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "DUNNO" && headData.DUNNO != null && headData.DUNNO.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "危险品编号超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "REEFERF" && headData.REEFERF != null && headData.REEFERF.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "冷藏通风量超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "TEMPID" && headData.TEMPID != null && headData.TEMPID.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "温度单位超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "TEMPSET" && headData.TEMPSET != null && headData.TEMPSET.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "设置温度超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "TEMPMAX" && headData.TEMPMAX != null && headData.TEMPMAX.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "最高温度超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "TEMPMIN" && headData.TEMPMIN != null && headData.TEMPMIN.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "最低温度超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "CONTRACTNO" && headData.CONTRACTNO != null && headData.CONTRACTNO.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "运费协议号超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "INSURANCEER" && headData.INSURANCEER != null && headData.INSURANCEER.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "保险人超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "INSURANCENO" && headData.INSURANCENO != null && headData.INSURANCENO.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "保险单号超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "REMARK" && headData.REMARK != null && headData.REMARK.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "备注超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "STLNAME" && headData.STLNAME != null && headData.STLNAME.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "结算方式超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "ENTERP" && headData.ENTERP != null && headData.ENTERP.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "经营单位超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "LINKMAN" && headData.LINKMAN != null && headData.LINKMAN.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "客户联系人超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "INSPECTSERVICE" && headData.INSPECTSERVICE != null && headData.INSPECTSERVICE.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "报检项目超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "APPLYNO" && headData.APPLYNO != null && headData.APPLYNO.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "申请放箱号超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "CUSTOMNO" && headData.CUSTOMNO != null && headData.CUSTOMNO.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "报关单号超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "INSPECTIONNO" && headData.INSPECTIONNO != null && headData.INSPECTIONNO.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "商检单号超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "PLACERECEIPTID" && headData.PLACERECEIPTID != null && headData.PLACERECEIPTID.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "收货地代码超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "TRADETERM" && headData.TRADETERM != null && headData.TRADETERM.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "贸易条款超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "VESSELID" && headData.VESSELID != null && headData.VESSELID.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "船舶呼号超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "DPAGE" && headData.DPAGE != null && headData.DPAGE.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "危险品页号超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "TERMSDELIVERY" && headData.TERMSDELIVERY != null && headData.TERMSDELIVERY.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "贸易方式超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
if (enumValue.FIELDNAME == "DLABEL" && headData.DLABEL != null && headData.DLABEL.Length > Convert.ToInt32(enumValue.FIELDLEN)) { isPost = false; errorstr = "危险品标签超长,字段长度限制" + enumValue.FIELDLEN; }
|
|
|
}
|
|
|
|
|
|
}
|
|
|
#endregion
|
|
|
|
|
|
if (isPost) {
|
|
|
|
|
|
if (goodsbodyList != null)
|
|
|
{
|
|
|
foreach (var enumValue in goodsbodyList)
|
|
|
{
|
|
|
if (enumValue.PONO != "") {
|
|
|
if (MsOpSeaiDAL.GetPONOCount(enumValue.BsNo, enumValue.PONO)) {
|
|
|
isPost = false;
|
|
|
errorstr = errorstr+ " PONO重复";
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
if (isPost)
|
|
|
{
|
|
|
var modb = new ModelObjectDB();
|
|
|
DBResult result = modb.Save(headData);
|
|
|
var BSNO = headData.BSNO;
|
|
|
if (result.Success == true)
|
|
|
{
|
|
|
result = MsOpSeaiDAL.SaveGoodsDetail(headData, goodsbodyList, Convert.ToString(Session["USERID"]));
|
|
|
|
|
|
if (headData.APPLYNO != "" && headData.APPLYNO.IndexOf("CPN") > 0 && bodyList.Count == 0)
|
|
|
{
|
|
|
var applyctnlist = MvcContainer.DAL.MsOpCtnApply.MsOpCtnApplyDAL.GetCtnApplyCtnItemsList("LINKGID in (SELECT GID FROM op_ctnapply WHERE BSNO='" + headData.APPLYNO + "') ");
|
|
|
if (applyctnlist.Count != 0)
|
|
|
{
|
|
|
foreach (var applyctn in applyctnlist)
|
|
|
{
|
|
|
if (bodyList.FindAll(x => x.CNTRNO == applyctn.CTNNO).Count == 0)
|
|
|
{
|
|
|
var ctn = new MsOpSeaiDetail();
|
|
|
ctn.BSNO = "*";
|
|
|
ctn.CNTRNO = applyctn.CTNNO;
|
|
|
ctn.CTNALL = "20TK";
|
|
|
ctn.CTNNUM = 1;
|
|
|
ctn.CTNSTATUS = "F";
|
|
|
ctn.CTN_ID = Guid.NewGuid().ToString();
|
|
|
bodyList.Add(ctn);
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
result = MsOpSeaiDAL.SaveDetail(headData, bodyList, Convert.ToString(Session["USERID"]));
|
|
|
//if (headData.APPLYNO != "" && headData.ETA != null)
|
|
|
//{
|
|
|
// var blUpSQL1 = " update op_ctnbscard set I_ETD='" + headData.ETA + "' where IS_RETURE_EMPTY=1 and APPLYNO='" + headData.APPLYNO + "' ";
|
|
|
// bool bl1 = T_ALL_DA.GetExecuteSqlCommand(blUpSQL1);
|
|
|
//}
|
|
|
var istrue = MsBaseInfoDAL.GetUserModuleEnable("modWxOpStatusMsg", Convert.ToString(Session["USERID"]));
|
|
|
if (istrue) {
|
|
|
if (headData.BSDATE != null && headData.BSDATE != "") {
|
|
|
var blUpSQL = " if (select ST_ID from op_status where BSNO='" + headData.BSNO + "' AND STATUS='接单完成') is null insert into op_status(ST_ID,BSNO,STATUS,ISCOMP,COMPTIME,INPUTTIME,STTYPE,COMPOP) values(NEWID(),'" + headData.BSNO + "','接单完成',1,'" +Convert.ToDateTime(headData.BSDATE).ToString("yyyy-MM-dd HH:mm:ss") + "','" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "','1','"+ Convert.ToString(Session["SHOWNAME"]) + "')";
|
|
|
bool bl = T_ALL_DA.GetExecuteSqlCommand(blUpSQL);
|
|
|
}
|
|
|
if (headData.CUSTOMDATE != null&& headData.CUSTOMDATE!="")
|
|
|
{
|
|
|
var blUpSQL = " if (select ST_ID from op_status where BSNO='" + headData.BSNO + "' AND STATUS='通关完成') is null insert into op_status(ST_ID,BSNO,STATUS,ISCOMP,COMPTIME,INPUTTIME,STTYPE,COMPOP) values(NEWID(),'" + headData.BSNO + "','通关完成',1,'" + Convert.ToDateTime(headData.CUSTOMDATE).ToString("yyyy-MM-dd HH:mm:ss") + "','" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "','1','" + Convert.ToString(Session["SHOWNAME"]) + "')";
|
|
|
bool bl = T_ALL_DA.GetExecuteSqlCommand(blUpSQL);
|
|
|
}
|
|
|
if (headData.TIHUOTIME != null && headData.TIHUOTIME != "")
|
|
|
{
|
|
|
var blUpSQL = " if (select ST_ID from op_status where BSNO='" + headData.BSNO + "' AND STATUS='入库状态') is null insert into op_status(ST_ID,BSNO,STATUS,ISCOMP,COMPTIME,INPUTTIME,STTYPE,COMPOP) values(NEWID(),'" + headData.BSNO + "','入库状态',1,'" + Convert.ToDateTime(headData.TIHUOTIME).ToString("yyyy-MM-dd HH:mm:ss") + "','" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "','1','" + Convert.ToString(Session["SHOWNAME"]) + "')";
|
|
|
bool bl = T_ALL_DA.GetExecuteSqlCommand(blUpSQL);
|
|
|
}
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
}
|
|
|
else {
|
|
|
MsSysBillNoSetDAL.DeleteBsNo(headData.CUSTNO);
|
|
|
}
|
|
|
|
|
|
var jsonRespose = new JsonResponse
|
|
|
{
|
|
|
Success = result.Success,
|
|
|
Message = result.Message,
|
|
|
Data = MsOpSeaiDAL.GetData("BSNO='" + BSNO + "'")
|
|
|
};
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
else {
|
|
|
if (iscreatecustno == true)
|
|
|
MsSysBillNoSetDAL.DeleteBsNo(headData.CUSTNO);
|
|
|
|
|
|
var jsonRespose = new JsonResponse { Success = false, Message =errorstr+",不允许保存!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
}
|
|
|
|
|
|
public ContentResult DeleteDetail(string data)
|
|
|
{
|
|
|
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
}
|
|
|
//
|
|
|
var head = JsonConvert.Deserialize<MsOpSeaiDetail>(data);
|
|
|
DBResult result = MsOpSeaiDAL.DeleteDetail2(head);
|
|
|
var jsonRespose = new JsonResponse { Success = result.Success, Message = result.Message };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
|
|
|
public ContentResult Delete(string data)
|
|
|
{
|
|
|
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
}
|
|
|
//
|
|
|
var head = JsonConvert.Deserialize<MsOpSeai>(data);
|
|
|
var isfee = MsOpSeaiDAL.GetFeeCount(head.BSNO);
|
|
|
if (isfee)
|
|
|
{
|
|
|
var jsonRespose = new JsonResponse { Success = false, Message ="此票业务存在费用,请先删除费用才能删除此票业务!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
else {
|
|
|
DBResult result=null;
|
|
|
if (head.ORDERTYPE != "网上订舱")
|
|
|
{
|
|
|
if (head.BLTYPE == "拼箱主票")
|
|
|
{
|
|
|
T_ALL_DA T_ALL_DA = new T_ALL_DA();
|
|
|
var BLCOUNT = T_ALL_DA.GetStrSQL("BLCOUNT", "select count(*) BLCOUNT from OP_SEAI WHERE MASTERNO='" + head.BSNO + "' AND BSNO<>'" + head.BSNO + "'");
|
|
|
if (BLCOUNT == "0")
|
|
|
{
|
|
|
var BSNO = head.BSNO;
|
|
|
var modb = new ModelObjectDB();
|
|
|
result = modb.Delete(head);
|
|
|
if (result.Success == true) { MsOpSeaiDAL.DeleteDetail(head); MsSysBillNoSetDAL.DeleteBsNo(head.CUSTNO); }
|
|
|
var jsonRespose3 = new JsonResponse { Success = result.Success, Message = result.Message };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose3) };
|
|
|
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse { Success = false, Message = "此票拼箱主票存在分票业务,请先删除分票信息!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
|
|
|
var BSNO = head.BSNO;
|
|
|
var modb = new ModelObjectDB();
|
|
|
result = modb.Delete(head);
|
|
|
if (result.Success == true) { MsSysBillNoSetDAL.DeleteBsNo(head.CUSTNO); }
|
|
|
|
|
|
if (result.Success == true) { MsOpSeaiDAL.DeleteDetail(head); }
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
else {
|
|
|
result.Success = false;
|
|
|
result.Message = "网上订舱不能删除";
|
|
|
}
|
|
|
var jsonRespose = new JsonResponse { Success = result.Success, Message = result.Message };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
public ContentResult GetCtnSum(string condition)
|
|
|
{
|
|
|
var rangstr = MsOpSeaiDAL.GetRangDAStr("index", Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
if (!string.IsNullOrEmpty(rangstr))
|
|
|
{
|
|
|
if (!string.IsNullOrEmpty(condition))
|
|
|
{
|
|
|
condition = condition + " and " + rangstr;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
condition = rangstr;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
condition = condition.Replace("'", "''");
|
|
|
|
|
|
var strSql = new StringBuilder();
|
|
|
strSql.Append(" declare @sql NVARCHAR(max) ");
|
|
|
strSql.Append(" set @sql='select S.NOBILL,S.PKGS,S.KGS,S.CBM,S.NETKGS,S.WMSCTNNUM ' ");
|
|
|
strSql.Append(" select @sql=@sql+',sum(case C.CTNALL when '''+t.CTN+''' then C.CTNNUM else 0 end) as C'+t.CTN ");
|
|
|
strSql.Append(" from (select CTN from code_ctn ) as t");
|
|
|
strSql.Append(" set @sql=@sql+',sum(C.TEU) TEU from op_ctn C left join op_seai B on (B.bsno=C.bsno) ");
|
|
|
strSql.Append(" left join (SELECT COUNT(BSNO) AS NOBILL,SUM(KGS) KGS,SUM(PKGS) PKGS,SUM(CBM) CBM,SUM(NETWEIGHT) NETKGS,SUM(ISNULL(W.WMSCTNNUM,0)) WMSCTNNUM");
|
|
|
strSql.Append(" from op_seai B LEFT JOIN (SELECT ASSOCIATEDNO,COUNT(DISTINCT CNTRNO) WMSCTNNUM FROM WMS_IN WHERE ISNULL(CNTRNO,'''')<>'''' GROUP BY ASSOCIATEDNO) W ON W.ASSOCIATEDNO=B.BSNO ");
|
|
|
if (!string.IsNullOrEmpty(condition))
|
|
|
{
|
|
|
strSql.Append(" Where " + condition);
|
|
|
}
|
|
|
|
|
|
strSql.Append(" ) S ON (1=1) ");
|
|
|
|
|
|
if (!string.IsNullOrEmpty(condition))
|
|
|
{
|
|
|
strSql.Append(" Where B.BSNO IS NOT NULL AND " + condition);
|
|
|
}
|
|
|
else {
|
|
|
strSql.Append(" Where B.BSNO IS NOT NULL ");
|
|
|
|
|
|
}
|
|
|
|
|
|
strSql.Append(" GROUP BY S.NOBILL,S.KGS,S.PKGS,S.CBM,S.NETKGS,S.WMSCTNNUM ' ");
|
|
|
strSql.Append(" exec(@sql) ");
|
|
|
|
|
|
var dbparams = new List<CustomDbParamter>();
|
|
|
|
|
|
var paramps_sSQL = new CustomDbParamter();
|
|
|
paramps_sSQL.ParameterName = "@sSQL";
|
|
|
paramps_sSQL.DbType = DbType.String;
|
|
|
paramps_sSQL.Direction = ParameterDirection.Input;
|
|
|
paramps_sSQL.Value = strSql.ToString();
|
|
|
dbparams.Add(paramps_sSQL);
|
|
|
|
|
|
var dbRptResult = PubSysDAL.GetMsSqlPrcDataSet("sMsExesqlQry", dbparams, "Result_Set");
|
|
|
var json = RptHelper.GetRptJsonResult(0, 1, dbRptResult, "Result_Set", true);
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
public ContentResult GetSaleCtnSum(string condition)
|
|
|
{
|
|
|
|
|
|
|
|
|
condition = condition.Replace("'", "''");
|
|
|
|
|
|
var strSql = new StringBuilder();
|
|
|
strSql.Append(" declare @sql NVARCHAR(max) ");
|
|
|
strSql.Append(" set @sql='select S.NOBILL,S.PKGS,S.KGS,S.CBM' ");
|
|
|
strSql.Append(" select @sql=@sql+',sum(case C.CTNALL when '''+t.CTN+''' then C.CTNNUM else 0 end) as C'+t.CTN ");
|
|
|
strSql.Append(" from (select CTN from code_ctn ) as t");
|
|
|
strSql.Append(" set @sql=@sql+',sum(C.TEU) TEU from op_ctn C left join op_seai B on (B.bsno=C.bsno) ");
|
|
|
strSql.Append(" left join (SELECT COUNT(BSNO) AS NOBILL,SUM(KGS) KGS,SUM(PKGS) PKGS,SUM(CBM) CBM from op_seai B ");
|
|
|
if (!string.IsNullOrEmpty(condition))
|
|
|
{
|
|
|
strSql.Append(" Where " + condition);
|
|
|
}
|
|
|
|
|
|
strSql.Append(" ) S ON (1=1) ");
|
|
|
|
|
|
if (!string.IsNullOrEmpty(condition))
|
|
|
{
|
|
|
strSql.Append(" Where " + condition);
|
|
|
}
|
|
|
|
|
|
strSql.Append(" GROUP BY S.NOBILL,S.KGS,S.PKGS,S.CBM ' ");
|
|
|
strSql.Append(" exec(@sql) ");
|
|
|
|
|
|
var dbparams = new List<CustomDbParamter>();
|
|
|
|
|
|
var paramps_sSQL = new CustomDbParamter();
|
|
|
paramps_sSQL.ParameterName = "@sSQL";
|
|
|
paramps_sSQL.DbType = DbType.String;
|
|
|
paramps_sSQL.Direction = ParameterDirection.Input;
|
|
|
paramps_sSQL.Value = strSql.ToString();
|
|
|
dbparams.Add(paramps_sSQL);
|
|
|
|
|
|
var dbRptResult = PubSysDAL.GetMsSqlPrcDataSet("sMsExesqlQry", dbparams, "Result_Set");
|
|
|
var json = RptHelper.GetRptJsonResult(0, 1, dbRptResult, "Result_Set", true);
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
|
|
|
|
|
|
public ContentResult GetCtnList(string condition)
|
|
|
{
|
|
|
var rangstr = MsOpSeaiDAL.GetRangDAStr("index", Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
if (!string.IsNullOrEmpty(rangstr))
|
|
|
{
|
|
|
if (!string.IsNullOrEmpty(condition))
|
|
|
{
|
|
|
condition = condition + " and " + rangstr;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
condition = rangstr;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
|
|
|
var strSql = new StringBuilder();
|
|
|
strSql.Append(" SELECT DISTINCT C.CTNALL from op_ctn C left join op_seai B on (B.bsno=C.bsno) ");
|
|
|
if (!string.IsNullOrEmpty(condition))
|
|
|
{
|
|
|
strSql.Append(" Where " + condition);
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
var dbparams = new List<CustomDbParamter>();
|
|
|
|
|
|
var paramps_sSQL = new CustomDbParamter();
|
|
|
paramps_sSQL.ParameterName = "@sSQL";
|
|
|
paramps_sSQL.DbType = DbType.String;
|
|
|
paramps_sSQL.Direction = ParameterDirection.Input;
|
|
|
paramps_sSQL.Value = strSql.ToString();
|
|
|
dbparams.Add(paramps_sSQL);
|
|
|
|
|
|
var dbRptResult = PubSysDAL.GetMsSqlPrcDataSet("sMsExesqlQry", dbparams, "Result_Set");
|
|
|
var json = RptHelper.GetRptJsonResult(0, 20, dbRptResult, "Result_Set", true);
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
|
|
|
|
|
|
public ContentResult GetCtnDetailList(string condition)
|
|
|
{
|
|
|
var rangstr = MsOpSeaiDAL.GetRangDAStr("index", Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
if (!string.IsNullOrEmpty(rangstr))
|
|
|
{
|
|
|
if (!string.IsNullOrEmpty(condition))
|
|
|
{
|
|
|
condition = condition + " and " + rangstr;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
condition = rangstr;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
|
|
|
var strSql = new StringBuilder();
|
|
|
strSql.Append("SELECT g.GID as GOODSNAMEID,b.GOODSNAME,b.UNITOFWEIGHT,c.CTN_ID,c.CTNCODE,c.SIZE,c.CTN,c.CTNNUM,c.CTNALL, ");
|
|
|
strSql.Append(" c.CNTRNO,c.SEALNO,c.PKGS,c.KGS,c.CBM from op_ctn c inner join op_seai b on (b.bsno=c.bsno) ");
|
|
|
strSql.Append(" left join code_goods g on (g.GOODNAME=b.GOODSNAME) ");
|
|
|
if (!string.IsNullOrEmpty(condition))
|
|
|
{
|
|
|
strSql.Append(" Where " + condition);
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
var dbparams = new List<CustomDbParamter>();
|
|
|
|
|
|
var paramps_sSQL = new CustomDbParamter();
|
|
|
paramps_sSQL.ParameterName = "@sSQL";
|
|
|
paramps_sSQL.DbType = DbType.String;
|
|
|
paramps_sSQL.Direction = ParameterDirection.Input;
|
|
|
paramps_sSQL.Value = strSql.ToString();
|
|
|
dbparams.Add(paramps_sSQL);
|
|
|
|
|
|
var dbRptResult = PubSysDAL.GetMsSqlPrcDataSet("sMsExesqlQry", dbparams, "Result_Set");
|
|
|
var json = RptHelper.GetRptJsonResult(0, 1000, dbRptResult, "Result_Set", true);
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
|
|
|
public ContentResult CreateCtnFee(string bsno, string body)
|
|
|
{
|
|
|
var iResult = 0;
|
|
|
var headList = new List<MsChFee>();
|
|
|
var bodyList = JsonConvert.Deserialize<List<MsOpSeaiDetail>>(body);
|
|
|
if (bodyList != null)
|
|
|
{
|
|
|
foreach (var enumValue in bodyList)
|
|
|
{
|
|
|
if (enumValue.TRUCKFEE != "0" && enumValue.TRUCKFEE != "")
|
|
|
{
|
|
|
MsChFee data = new MsChFee();
|
|
|
data.BsNo = "*";
|
|
|
data.GId = Guid.NewGuid().ToString();
|
|
|
data.FeeType = 2;
|
|
|
data.FeeName = "陆运费";
|
|
|
data.CustomerType = "车队";
|
|
|
data.CustomerName = enumValue.TRUCKER;
|
|
|
data.Unit = enumValue.CTNALL;
|
|
|
data.UnitPrice = Convert.ToDecimal(enumValue.TRUCKFEE);
|
|
|
data.Quantity = 1;
|
|
|
data.Amount = Convert.ToDecimal(enumValue.TRUCKFEE);
|
|
|
data.Currency = "RMB";
|
|
|
data.ExChangerate = 1;
|
|
|
data.EnteroPerator = Convert.ToString(Session["USERID"]);
|
|
|
data.IsOpen = "0";
|
|
|
data.IsAdvancedpay = "0";
|
|
|
data.FeeStatus = 1;
|
|
|
data.TaxRate = 0;
|
|
|
data.NoTaxAmount = Convert.ToDecimal(enumValue.TRUCKFEE);
|
|
|
data.TaxUnitPrice = Convert.ToDecimal(enumValue.TRUCKFEE);
|
|
|
data.AccTaxRate = 0;
|
|
|
data.IsInvoice = "0";
|
|
|
data.LOCALCURR = "RMB";
|
|
|
headList.Add(data);
|
|
|
}
|
|
|
|
|
|
if (enumValue.CTNFEE != "0" && enumValue.CTNFEE != "")
|
|
|
{
|
|
|
if (Convert.ToDecimal(enumValue.CTNFEE) != 0)
|
|
|
{
|
|
|
MsChFee data = new MsChFee();
|
|
|
data.BsNo = "*";
|
|
|
data.GId = Guid.NewGuid().ToString();
|
|
|
data.FeeType = 2;
|
|
|
data.FeeName = "箱使费";
|
|
|
data.CustomerType = "车队";
|
|
|
data.CustomerName = enumValue.TRUCKER;
|
|
|
data.Unit = "天";
|
|
|
data.UnitPrice = Convert.ToDecimal(enumValue.CTNPRICE);
|
|
|
data.Quantity = Convert.ToInt16(enumValue.CTNDAY) - Convert.ToInt16(enumValue.FREECTNDAY);
|
|
|
data.Amount = Convert.ToDecimal(enumValue.CTNFEE);
|
|
|
data.Currency = "RMB";
|
|
|
data.ExChangerate = 1;
|
|
|
data.EnteroPerator = Convert.ToString(Session["USERID"]);
|
|
|
data.IsOpen = "0";
|
|
|
data.IsAdvancedpay = "0";
|
|
|
data.FeeStatus = 1;
|
|
|
data.TaxRate = 0;
|
|
|
data.NoTaxAmount = Convert.ToDecimal(enumValue.CTNFEE);
|
|
|
data.TaxUnitPrice = Convert.ToDecimal(enumValue.CTNPRICE);
|
|
|
data.AccTaxRate = 0;
|
|
|
data.IsInvoice = "0";
|
|
|
data.LOCALCURR = "RMB";
|
|
|
headList.Add(data);
|
|
|
}
|
|
|
|
|
|
}
|
|
|
}
|
|
|
if (headList != null)
|
|
|
{
|
|
|
iResult = MsChFeeDAL.SaveUpdateFee(headList, bsno, CookieConfig.GetCookie_UserId(Request));
|
|
|
}
|
|
|
}
|
|
|
if (iResult == 0 || iResult == 1)
|
|
|
{
|
|
|
var jsonRespose = new JsonResponse { Success = true, Message = "已生成费用!", Data = "" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
var jsonRespose = new JsonResponse { Success = false, Message = "生成费用时出错!", Data = "" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
}
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region EDI引入
|
|
|
[HttpPost]
|
|
|
public ContentResult ImportEdi()
|
|
|
{
|
|
|
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
}
|
|
|
//
|
|
|
var jsonRespose = new JsonResponse { Success = false, Message = "" };
|
|
|
|
|
|
if (Request.Files.Count != 1)
|
|
|
{
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "请选择上传的文件";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
|
|
|
var file = Request.Files["file"];
|
|
|
if (file == null)
|
|
|
{
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "上传文件发生未知错误,请重新上传";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
}
|
|
|
string ext = Path.GetExtension(file.FileName).ToLower();
|
|
|
if (ext == ".asp" || ext == ".aspx")
|
|
|
{
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "不允许上传ASP或ASPX文件";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
var path = Server.MapPath("../../UploadFiles/Edi");
|
|
|
|
|
|
if (!Directory.Exists(path))
|
|
|
{
|
|
|
Directory.CreateDirectory(path);
|
|
|
}
|
|
|
|
|
|
var size = file.ContentLength;
|
|
|
var name = Path.GetFileName(file.FileName);
|
|
|
|
|
|
var usercode = CookieConfig.GetCookie_UserCode(Request);
|
|
|
string filename = path + "\\" + usercode + DateTime.Now.ToString("yyyyMMddHHmmssfff") + name;
|
|
|
|
|
|
if (System.IO.File.Exists(filename))
|
|
|
{
|
|
|
System.IO.File.Delete(filename);
|
|
|
}
|
|
|
file.SaveAs(filename);
|
|
|
|
|
|
try
|
|
|
{
|
|
|
|
|
|
var headList = MsOpSeaiDAL.ImportEdiList(filename, Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
//var headList = new List<MsOpSeai>();
|
|
|
|
|
|
if (headList.Count != 0)
|
|
|
{
|
|
|
|
|
|
var json = JsonConvert.Serialize(new { Success = true, Message = "导入成功" + headList.Count.ToString()+"票", data = headList.ToList() });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
else {
|
|
|
var json = JsonConvert.Serialize(new { Success =false, Message = "未导入数据,请确认是否已经有此业务!" });
|
|
|
return new ContentResult() { Content = json };
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
catch (Exception)
|
|
|
{
|
|
|
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "读取EDI文件出错,请确认文件正确性";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
|
|
|
}
|
|
|
#endregion
|
|
|
|
|
|
#region EDI导出
|
|
|
public ContentResult CreateEDIList(string headData, string mblno, string type, string filetype, string filerole, int isbill, int isnoctn)
|
|
|
{
|
|
|
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
}
|
|
|
//
|
|
|
var headList = JsonConvert.Deserialize<List<MsOpSeai>>(headData);
|
|
|
|
|
|
|
|
|
var path = Server.MapPath("../../EDIFiles/SeaiEdi");
|
|
|
|
|
|
if (!Directory.Exists(path))
|
|
|
{
|
|
|
Directory.CreateDirectory(path);
|
|
|
}
|
|
|
|
|
|
var result = new DBResult();
|
|
|
var error = MsOpSeaiDAL.IsCreateEdi(headList, type, filetype, filerole,"");
|
|
|
if (error == "")
|
|
|
{
|
|
|
var ftpset = MsCodeFtpSetDAL.GetData("EDINAME='" + type + "'", Convert.ToString(Session["COMPANYID"]));
|
|
|
|
|
|
var filename = MsOpSeaiDAL.CreateEdi(headList, Convert.ToString(Session["USERCODE"]), path, mblno, filerole, ftpset, type, isbill, isnoctn, "", "");
|
|
|
|
|
|
|
|
|
if (ftpset.SERVERIP != "" && ftpset.SERVERIP != null)
|
|
|
result = MsOpSeaiDAL.FtpFile(filename, ftpset);
|
|
|
else
|
|
|
{
|
|
|
result.Success = false;
|
|
|
result.Message = "FTP参数没有设置,请先设置FTP参数!";
|
|
|
}
|
|
|
|
|
|
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
result.Success = false;
|
|
|
result.Message = error;
|
|
|
|
|
|
}
|
|
|
var jsonRespose = new JsonResponse { Success = result.Success, Message = result.Message };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
public ContentResult SaveEDIList(string headData, string mblno, string type, string filetype, string filerole, int isbill, int isnoctn)
|
|
|
{
|
|
|
|
|
|
var headList = JsonConvert.Deserialize<List<MsOpSeai>>(headData);
|
|
|
|
|
|
|
|
|
var path = Server.MapPath("../../EDIFiles/SeaiEdi");
|
|
|
|
|
|
if (!Directory.Exists(path))
|
|
|
{
|
|
|
Directory.CreateDirectory(path);
|
|
|
}
|
|
|
|
|
|
var result = new DBResult();
|
|
|
var error = MsOpSeaiDAL.IsCreateEdi(headList, type, filetype, filerole,"");
|
|
|
if (error == "")
|
|
|
{
|
|
|
var ftpset = MsCodeFtpSetDAL.GetData("EDINAME='" + type + "'", Convert.ToString(Session["COMPANYID"]));
|
|
|
var filename = MsOpSeaiDAL.CreateEdi(headList, Convert.ToString(Session["USERCODE"]), path, mblno, filerole, ftpset, type, isbill, isnoctn, "", "");
|
|
|
|
|
|
filename = Path.GetFileName(filename);
|
|
|
|
|
|
result.Success = true;
|
|
|
result.Data = "../../EDIFiles/SeaiEdi/" + filename;
|
|
|
|
|
|
result.Message = filename;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
result.Success = false;
|
|
|
result.Message = error;
|
|
|
|
|
|
}
|
|
|
var jsonRespose = new JsonResponse { Success = result.Success, Message = result.Message,Data=result.Data };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
|
|
|
|
|
|
}
|
|
|
#endregion
|
|
|
|
|
|
#region DHL EDI
|
|
|
public ContentResult CreateDHLList(string bsnos, string mblno, string filerole)
|
|
|
{
|
|
|
bsnos = bsnos.Replace(",", "','");
|
|
|
var headList = MsOpSeaiDAL.GetDataList("BSNO IN ('" + bsnos + "')", Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
var path = Server.MapPath("../../EDIFiles/SeaiEdi");
|
|
|
if (!Directory.Exists(path))
|
|
|
{
|
|
|
Directory.CreateDirectory(path);
|
|
|
}
|
|
|
|
|
|
var result = new DBResult();
|
|
|
var error = MsOpSeaiDAL.IsCreateEdiDHL(headList,filerole);
|
|
|
if (error == "")
|
|
|
{
|
|
|
var ftpset = MsCodeFtpSetDAL.GetData("EDINAME='DHL' ", Convert.ToString(Session["COMPANYID"]));
|
|
|
var filename = "";
|
|
|
if (ftpset.SERVERIP != "" && ftpset.SERVERIP != null)
|
|
|
{
|
|
|
foreach (var bill in headList)
|
|
|
{
|
|
|
filename = MsOpSeaiDAL.CreateEdiDHL(bill, Convert.ToString(Session["USERCODE"]), path, mblno, filerole, ftpset);
|
|
|
result = MsOpSeaiDAL.SFtpFile(filename, ftpset);
|
|
|
}
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
result.Success = false;
|
|
|
result.Message = "FTP参数没有设置,请先设置FTP参数!";
|
|
|
}
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
result.Success = false;
|
|
|
result.Message = error;
|
|
|
}
|
|
|
var jsonRespose = new JsonResponse { Success = result.Success, Message = result.Message };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
|
|
|
public ContentResult SaveDHLList(string bsnos, string mblno, string filerole)
|
|
|
{
|
|
|
bsnos = bsnos.Replace(",", "','");
|
|
|
var headList = MsOpSeaiDAL.GetDataList("BSNO IN ('" + bsnos + "')", Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
var path = Server.MapPath("../../EDIFiles/SeaiEdi");
|
|
|
if (!Directory.Exists(path))
|
|
|
{
|
|
|
Directory.CreateDirectory(path);
|
|
|
}
|
|
|
|
|
|
var result = new DBResult();
|
|
|
var error = MsOpSeaiDAL.IsCreateEdiDHL(headList, filerole);
|
|
|
if (error == "")
|
|
|
{
|
|
|
var ftpset = MsCodeFtpSetDAL.GetData("EDINAME='DHL' ", Convert.ToString(Session["COMPANYID"]));
|
|
|
var filename = "";
|
|
|
if (ftpset.SENDCODE == "")
|
|
|
{
|
|
|
result.Success = false;
|
|
|
result.Message = "EDI参数没有设置,请先设置EDI参数!";
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
filename = MsOpSeaiDAL.CreateEdiDHL(headList[0], Convert.ToString(Session["USERCODE"]), path, mblno, filerole, ftpset);
|
|
|
filename = Path.GetFileName(filename);
|
|
|
result.Data = "../../EDIFiles/SeaiEdi/" + filename;
|
|
|
result.Success = true;
|
|
|
result.Message = filename;
|
|
|
}
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
result.Success = false;
|
|
|
result.Message = error;
|
|
|
}
|
|
|
var jsonRespose = new JsonResponse { Success = result.Success, Message = result.Message,Data = result.Data };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region 舱单申报
|
|
|
|
|
|
public ContentResult CreateCustomList(string bsnos, string type)
|
|
|
{
|
|
|
bsnos = bsnos.Replace(",", "','");
|
|
|
var billList = MsOpSeaiDAL.GetDataList("BSNO IN ('" + bsnos + "')", CookieConfig.GetCookie_UserId(Request), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
|
|
|
|
|
|
|
|
|
var result = new DBResult();
|
|
|
var error = "";
|
|
|
if (error == "")
|
|
|
{
|
|
|
result = MsOpSeaiDAL.CreateCustomList(billList, type, CookieConfig.GetCookie_UserId(Request), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
result.Success = false;
|
|
|
result.Message = error;
|
|
|
|
|
|
}
|
|
|
|
|
|
var json = JsonConvert.Serialize(result);
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region 交通部2.0 EDI导出
|
|
|
public ContentResult CreateIFTMBFList(string bsnos, string mblno, string filerole, string carrier)
|
|
|
{
|
|
|
bsnos = bsnos.Replace(",", "','");
|
|
|
var headList = MsOpSeaiDAL.GetDataList("BSNO IN ('" + bsnos + "')", Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
var path = Server.MapPath("../../EDIFiles/SeaiEdi");
|
|
|
if (!Directory.Exists(path))
|
|
|
{
|
|
|
Directory.CreateDirectory(path);
|
|
|
}
|
|
|
|
|
|
var result = new DBResult();
|
|
|
var error = MsOpSeaiDAL.IsCreateEdi(headList, "IFTMBF", "", filerole, carrier);
|
|
|
if (error == "")
|
|
|
{
|
|
|
var ftpset = MsCodeFtpSetDAL.GetData("EDINAME='IFTMBF' AND CARRIERID='" + carrier + "'", Convert.ToString(Session["COMPANYID"]));
|
|
|
var filename = "";
|
|
|
filename = MsOpSeaiDAL.CreateEdi(headList, Convert.ToString(Session["USERCODE"]), path, mblno, filerole, ftpset, "IFTMBF", 0, 0, carrier, "");
|
|
|
|
|
|
if (ftpset.SERVERIP != "" && ftpset.SERVERIP != null)
|
|
|
result = MsOpSeaiDAL.FtpFile(filename, ftpset);
|
|
|
else
|
|
|
{
|
|
|
result.Success = false;
|
|
|
result.Message = "FTP参数没有设置,请先设置FTP参数!";
|
|
|
}
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
result.Success = false;
|
|
|
result.Message = error;
|
|
|
}
|
|
|
var jsonRespose = new JsonResponse { Success = result.Success, Message = result.Message };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
|
|
|
public ContentResult SaveIFTMBFList(string bsnos, string mblno, string filerole, string carrier)
|
|
|
{
|
|
|
bsnos = bsnos.Replace(",", "','");
|
|
|
var headList = MsOpSeaiDAL.GetDataList("BSNO IN ('" + bsnos + "')", Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
var path = Server.MapPath("../../EDIFiles/SeaiEdi");
|
|
|
if (!Directory.Exists(path))
|
|
|
{
|
|
|
Directory.CreateDirectory(path);
|
|
|
}
|
|
|
|
|
|
var result = new DBResult();
|
|
|
var error = MsOpSeaiDAL.IsCreateEdi(headList, "IFTMBF", "", filerole, carrier);
|
|
|
if (error == "")
|
|
|
{
|
|
|
var ftpset = MsCodeFtpSetDAL.GetData("EDINAME='IFTMBF' AND CARRIERID='" + carrier + "'", Convert.ToString(Session["COMPANYID"]));
|
|
|
if (ftpset.SENDCODE == "" || ftpset.RECEIVECODE == "")
|
|
|
{
|
|
|
result.Success = false;
|
|
|
result.Message = "EDI参数没有设置,请先设置EDI参数!";
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
var filename = "";
|
|
|
//filename = MsOpSeaiDAL.CreateEdi(headList, Convert.ToString(Session["USERCODE"]), path, mblno, filerole, ftpset, "IFTMBF", isbill, 0, carrier, "", "", filetype);
|
|
|
filename = MsOpSeaiDAL.CreateEdi(headList, Convert.ToString(Session["USERCODE"]), path, mblno, filerole, ftpset, "IFTMBF", 0, 0, carrier, "");
|
|
|
filename = Path.GetFileName(filename);
|
|
|
result.Data = "../../EDIFiles/SeaiEdi/" + filename;
|
|
|
result.Success = true;
|
|
|
result.Message = filename;
|
|
|
}
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
result.Success = false;
|
|
|
result.Message = error;
|
|
|
}
|
|
|
var jsonRespose = new JsonResponse { Success = result.Success, Message = result.Message, Data = result.Data };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
#endregion
|
|
|
|
|
|
#region 生成报关信息
|
|
|
public ContentResult SaveBG(string data, string data2, string data3)
|
|
|
{
|
|
|
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
}
|
|
|
//
|
|
|
var aaa = "";
|
|
|
|
|
|
var head = JsonConvert.Deserialize<MsOpSeai>(data.Replace("}", ",") + data2.Replace("{", "").Replace("}", ",") + data3.Replace("{", ""));
|
|
|
|
|
|
var headData = new MsOpApply();
|
|
|
|
|
|
|
|
|
|
|
|
if (headData.CORPID == "" || headData.CORPID == null)
|
|
|
{
|
|
|
headData.CORPID = Convert.ToString(Session["COMPANYID"]);
|
|
|
}
|
|
|
headData.MASTERNO = head.BSNO;
|
|
|
headData.INPUTBY = Convert.ToString(Session["SHOWNAME"]);
|
|
|
|
|
|
headData.BSDATE = DateTime.Now;
|
|
|
headData.DbOperationType = DbOperationType.DbotIns;
|
|
|
headData.CUSTOMERNAME = head.CUSTOMERNAME;
|
|
|
headData.MBLNO = head.MBLNO;
|
|
|
headData.VESSEL = head.VESSEL;
|
|
|
headData.VOYNO = head.VOYNO;
|
|
|
headData.BSSOURCE = head.BSSOURCE;
|
|
|
headData.BSSOURCEDETAIL = head.BSSOURCEDETAIL;
|
|
|
headData.ETD = head.ETD;
|
|
|
headData.ETA = head.ETA;
|
|
|
headData.PKGS = head.PKGS;
|
|
|
headData.KGS = head.KGS;
|
|
|
headData.CBM = head.CBM;
|
|
|
headData.PORTLOAD = head.PORTLOAD;
|
|
|
headData.PORTDISCHARGE = head.PORTDISCHARGE;
|
|
|
headData.SALE = head.SALE;
|
|
|
headData.SALEDEPT = head.SALEDEPT;
|
|
|
headData.BSTYPE = "2";
|
|
|
headData.CUSTOMDATE = head.CUSTOMDATE;
|
|
|
var isuse = MsBaseInfoDAL.GetRuleUse("委托编号", "4");
|
|
|
if (isuse)
|
|
|
{
|
|
|
var _r = MsOpApplyDAL.getCUSTNO(headData, Session["USERID"].ToString(), Session["SHOWNAME"].ToString(), Session["COMPANYID"].ToString());
|
|
|
headData.CUSTNO = _r.Data.ToString();
|
|
|
}
|
|
|
var modb = new ModelObjectDB();
|
|
|
DBResult result = modb.Save(headData);
|
|
|
|
|
|
if (result.Success == true)
|
|
|
{
|
|
|
result.Success = true;
|
|
|
result.Message = "生成成功";
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
result.Success = false;
|
|
|
result.Message = "生成过程发生错误";
|
|
|
|
|
|
}
|
|
|
|
|
|
var jsonRespose = new JsonResponse
|
|
|
{
|
|
|
Success = result.Success,
|
|
|
Message = result.Message
|
|
|
};
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
|
|
|
}
|
|
|
#endregion
|
|
|
|
|
|
#region 集团委托引入
|
|
|
public ContentResult GetImpDataList(int start, int limit, string sort, string condition)
|
|
|
{
|
|
|
//var dataList = MsOpSeaiDAL.GetDataList(condition, Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]), sort);
|
|
|
//var list = dataList.Skip(start).Take(limit);
|
|
|
var dataList = MsOpSeaiDAL.GetImpDataList(start, limit, condition, Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]), sort);
|
|
|
int count = MsOpSeaiDAL.getImpTotalCount(condition, Convert.ToString(Session["USERID"]), Convert.ToString(Session["SHOWNAME"]), Convert.ToString(Session["COMPANYID"]));
|
|
|
var json = JsonConvert.Serialize(new { Success = true, Message = "查询成功", totalCount = count, data = dataList.ToList() });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
|
|
|
#region 导入excel
|
|
|
|
|
|
private bool IsNumber(string wmsdate)
|
|
|
{
|
|
|
{
|
|
|
if (String.IsNullOrEmpty(wmsdate))
|
|
|
|
|
|
return false; //是,就返回False
|
|
|
ASCIIEncoding ascii = new ASCIIEncoding();//new ASCIIEncoding 的实例
|
|
|
byte[] bytestr = ascii.GetBytes(wmsdate); //把string类型的参数保存到数组里
|
|
|
|
|
|
foreach (byte c in bytestr) //遍历这个数组里的内容
|
|
|
{
|
|
|
if (c == 46) continue;
|
|
|
if (c < 48 || c > 57) //判断是否为数字
|
|
|
{
|
|
|
return false; //不是,就返回False
|
|
|
}
|
|
|
}
|
|
|
return true; //是,就返回True
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
///海运进口 导入excel
|
|
|
[HttpPost]
|
|
|
public ContentResult ImportExcel(string CtnrData, string data, string data2, string data3)
|
|
|
{
|
|
|
var jsonRespose = new JsonResponse { Success = false, Message = "" };
|
|
|
|
|
|
if (Request.Files.Count != 1)
|
|
|
{
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "请选择上传的文件";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
|
|
|
var file = Request.Files["LoadExcel"];
|
|
|
if (file == null || file.ContentLength == 0 || string.IsNullOrEmpty(file.FileName))
|
|
|
{
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "上传文件发生未知错误,请重新上传";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
if (Convert.ToString(Session["COMPANYID"]).ToString().Trim() == "" || Convert.ToString(Session["USERID"]).ToString().Trim() == "" || Convert.ToString(Session["CODENAME"]).ToString().Trim() == "" || Convert.ToString(Session["SHOWNAME"]).ToString().Trim() == "" || Convert.ToString(Session["DEPTNAME"]).ToString().Trim() == "")
|
|
|
{
|
|
|
var jsonRespose2 = new JsonResponse { Success = false, Message = "登录超时,请退出系统重新登录!" };
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose2) };
|
|
|
}
|
|
|
string ext = Path.GetExtension(file.FileName).ToLower();
|
|
|
if (ext == ".asp" || ext == ".aspx")
|
|
|
{
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "不允许上传ASP或ASPX文件";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
|
|
|
/*
|
|
|
|
|
|
Stream stream = file.InputStream;
|
|
|
|
|
|
StreamReader reader = new StreamReader(stream, Encoding.UTF8);
|
|
|
|
|
|
string str = "";
|
|
|
|
|
|
while (str != null)
|
|
|
{
|
|
|
str = reader.ReadLine();
|
|
|
string[] xu = new String[3];
|
|
|
xu = str.Split(',');
|
|
|
string ctrnno = xu[0];
|
|
|
string pack = xu[1];
|
|
|
string pkgs = xu[2];
|
|
|
|
|
|
|
|
|
reader.Close();
|
|
|
|
|
|
*/
|
|
|
|
|
|
var path = Server.MapPath("../../UploadFiles/CtrnExcel");
|
|
|
var path2 = Server.MapPath("../../UploadFiles/CtrnExcel/");
|
|
|
|
|
|
if (!Directory.Exists(path))
|
|
|
{
|
|
|
Directory.CreateDirectory(path);
|
|
|
}
|
|
|
|
|
|
var size = file.ContentLength;
|
|
|
var name = Path.GetFileName(file.FileName);
|
|
|
var bsno = Request.Form["BSNO"];
|
|
|
|
|
|
var usercode = CookieConfig.GetCookie_UserCode(Request);
|
|
|
string filenamepath = usercode + DateTime.Now.ToString("yyyyMMddHHmmssfff") + name;
|
|
|
|
|
|
string filename = path + "\\" + filenamepath;
|
|
|
|
|
|
string excelFilePath = path2 + filenamepath;
|
|
|
|
|
|
|
|
|
if (System.IO.File.Exists(filename))
|
|
|
{
|
|
|
System.IO.File.Delete(filename);
|
|
|
}
|
|
|
file.SaveAs(filename);
|
|
|
|
|
|
if (!System.IO.File.Exists(filename))
|
|
|
{
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "上传的Excel不包含数据01";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
|
|
|
Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
|
|
|
|
|
|
if (excel == null)
|
|
|
{
|
|
|
if (System.IO.File.Exists(filename))
|
|
|
{
|
|
|
System.IO.File.Delete(filename);
|
|
|
}
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "无法创建Excel对象,可能您的服务器计算机未安装Excel!!";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
|
|
|
Workbook workbook = excel.Workbooks.Open(excelFilePath, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
|
|
|
|
|
|
Worksheet mySheet = workbook.Sheets[1] as Worksheet;
|
|
|
|
|
|
try
|
|
|
{
|
|
|
var isuse = false;
|
|
|
|
|
|
var CtrnList = JsonConvert.Deserialize<List<MsOpSeaiDetail>>(CtnrData);
|
|
|
var HeadData = JsonConvert.Deserialize<MsOpSeai>(data.Replace("}", ",") + data2.Replace("{", "").Replace("}", ",") + data3.Replace("{", ""));
|
|
|
|
|
|
int rowsint = mySheet.UsedRange.Cells.Rows.Count;
|
|
|
|
|
|
if (rowsint < 3)
|
|
|
{
|
|
|
if (System.IO.File.Exists(filename))
|
|
|
{
|
|
|
System.IO.File.Delete(filename);
|
|
|
}
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "请检查excel文件数据是否正确";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
|
|
|
var CtrnExcelList = new List<MsOpCtrnExcel>();
|
|
|
|
|
|
for (int i = 3; i < rowsint + 1; i++)
|
|
|
{
|
|
|
MsOpCtrnExcel CtrnExcel = new MsOpCtrnExcel();
|
|
|
object objDate = mySheet.Cells.get_Range("B" + i).Value2; //入库时间
|
|
|
|
|
|
object objCtrno = mySheet.Cells.get_Range("D" + i).Value2; //箱号
|
|
|
object objPack = mySheet.Cells.get_Range("E" + i).Value2; //件数
|
|
|
object objKgs = mySheet.Cells.get_Range("F" + i).Value2; //毛重
|
|
|
|
|
|
object objblno = mySheet.Cells.get_Range("C" + i).Value2; //提单号
|
|
|
object objarea = mySheet.Cells.get_Range("G" + i).Value2; //储位
|
|
|
|
|
|
object obj_INVOICENO = mySheet.Cells.get_Range("H" + i).Value2; //发票号
|
|
|
object obj_GOODSMODEL = mySheet.Cells.get_Range("I" + i).Value2; //规格型号
|
|
|
object obj_BZTCHNO = mySheet.Cells.get_Range("J" + i).Value2; //批次号
|
|
|
object obj_PRODUCTIONDATE = mySheet.Cells.get_Range("K" + i).Value2; //生产日期
|
|
|
object obj_KINDPKGS = mySheet.Cells.get_Range("L" + i).Value2; //包装
|
|
|
|
|
|
if (objCtrno != null && objPack != null && objPack != null && objDate != null && objblno != null && !string.IsNullOrWhiteSpace(objCtrno.ToString() ) && !string.IsNullOrWhiteSpace(objPack.ToString() ) && !string.IsNullOrWhiteSpace(objKgs.ToString()) && !string.IsNullOrWhiteSpace(objDate.ToString()) && !string.IsNullOrWhiteSpace( objblno.ToString()) )
|
|
|
{
|
|
|
CtrnExcel.CtrnNo = objCtrno.ToString();
|
|
|
CtrnExcel.Pkgs = objPack.ToString();
|
|
|
CtrnExcel.Kgs = objKgs.ToString();
|
|
|
string tmpDate = objDate.ToString();
|
|
|
if (IsNumber(tmpDate) )
|
|
|
CtrnExcel.WMSDate = DateTime.FromOADate(Convert.ToDouble(objDate)).ToString("d");
|
|
|
else
|
|
|
CtrnExcel.WMSDate = objDate.ToString();
|
|
|
|
|
|
if (objarea != null)
|
|
|
CtrnExcel.AreaName = objarea.ToString();
|
|
|
else
|
|
|
CtrnExcel.AreaName = "";
|
|
|
|
|
|
CtrnExcel.INVOICENO = (obj_INVOICENO == null ? "" : obj_INVOICENO.ToString());
|
|
|
CtrnExcel.GOODSMODEL = (obj_GOODSMODEL == null ? "" : obj_GOODSMODEL.ToString());
|
|
|
CtrnExcel.BZTCHNO = (obj_BZTCHNO == null ? "" : obj_BZTCHNO.ToString());
|
|
|
CtrnExcel.KINDPKGS = (obj_KINDPKGS == null ? "" : obj_KINDPKGS.ToString());
|
|
|
|
|
|
if (obj_PRODUCTIONDATE != null)
|
|
|
{
|
|
|
if (IsNumber(obj_PRODUCTIONDATE.ToString()))
|
|
|
CtrnExcel.PRODUCTIONDATE = DateTime.FromOADate(Convert.ToDouble(obj_PRODUCTIONDATE)).ToString("d");
|
|
|
else
|
|
|
CtrnExcel.PRODUCTIONDATE = obj_PRODUCTIONDATE.ToString();
|
|
|
}
|
|
|
else { CtrnExcel.PRODUCTIONDATE = ""; }
|
|
|
CtrnExcelList.Add(CtrnExcel);
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
break;
|
|
|
}
|
|
|
|
|
|
if ( objblno.ToString().Trim() != HeadData.MBLNO.Trim())
|
|
|
{
|
|
|
//if (System.IO.File.Exists(filename))
|
|
|
//{
|
|
|
// System.IO.File.Delete(filename);
|
|
|
//}
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "请检查提单号是否正确";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
|
|
|
|
|
|
foreach (MsOpSeaiDetail item in CtrnList)
|
|
|
{
|
|
|
if (item.CNTRNO == CtrnExcel.CtrnNo)
|
|
|
{
|
|
|
item.PKGS = Convert.ToInt32(CtrnExcel.Pkgs);
|
|
|
item.KGS = Convert.ToDecimal(CtrnExcel.Kgs)*1000;
|
|
|
item.WMSDATE = CtrnExcel.WMSDate.ToString();
|
|
|
item.ISWMS = "0";
|
|
|
item.AREANAME = CtrnExcel.AreaName.ToString();
|
|
|
isuse = true;
|
|
|
break;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
workbook.Close(false, filename, Type.Missing);
|
|
|
workbook = null;
|
|
|
excel.Quit();
|
|
|
excel = null;
|
|
|
|
|
|
bool isSucess = true;
|
|
|
|
|
|
|
|
|
if (System.IO.File.Exists(filename))
|
|
|
{
|
|
|
System.IO.File.Delete(filename);
|
|
|
}
|
|
|
|
|
|
if (!isuse)
|
|
|
{
|
|
|
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "请检查excel数据,数据不匹配,更新失败";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
|
|
|
}
|
|
|
|
|
|
DBResult resultCtrn = MsOpSeaiDAL.UpdateCtrnDetail(CtrnList);
|
|
|
|
|
|
if (HeadData.STORAGENAME == "" || HeadData.GOODSNAME == "")
|
|
|
{
|
|
|
System.IO.File.Delete(filename);
|
|
|
JsonConvert.Serialize(new { success = true, Message = "提单箱数据更新成功,入库失败,请检查品名和仓库", data = CtrnList, });
|
|
|
}
|
|
|
|
|
|
if (resultCtrn.Success)
|
|
|
{
|
|
|
|
|
|
//按照入库时间、储位分别生成入库单
|
|
|
if (HeadData.BSNO == "")
|
|
|
HeadData.BSNO = HeadData.MASTERNO;
|
|
|
int ctrnNum = MsOpSeaiDAL.CtrnToWMS_DATENUM(HeadData.BSNO);
|
|
|
if (ctrnNum == 0)
|
|
|
{
|
|
|
{
|
|
|
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "提单箱数据更新成功,入库失败,请联系管理员!";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
|
|
|
}
|
|
|
}
|
|
|
|
|
|
for (int i = 1; i <= ctrnNum; i++)
|
|
|
{
|
|
|
List<MsOpSeaiDetail> dateList = CtrnToWMSDateList(CtrnList);
|
|
|
if (dateList.Count != 0)
|
|
|
{
|
|
|
for (int j = 1; j <= dateList.Count(); j++)
|
|
|
{
|
|
|
List<MsOpSeaiDetail> areaList = CtrnToAreaList(dateList);
|
|
|
if (areaList.Count != 0)
|
|
|
{
|
|
|
resultCtrn = CtrnToWMS(areaList, HeadData, CtrnExcelList);
|
|
|
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
|
|
|
//20191206 更新主业务的毛重和件数
|
|
|
Decimal KGS = 0;
|
|
|
Decimal PKGS = 0;
|
|
|
foreach (var _ctn in CtrnExcelList)
|
|
|
{
|
|
|
KGS += Convert.ToDecimal(_ctn.Kgs)*1000;
|
|
|
PKGS += Convert.ToDecimal(_ctn.Pkgs);
|
|
|
}
|
|
|
HeadData.KGS = KGS;
|
|
|
HeadData.PKGS = PKGS;
|
|
|
HeadData.DbOperationType = DbOperationType.DbotUpd;
|
|
|
|
|
|
var modb = new ModelObjectDB();
|
|
|
DBResult result = modb.Save(HeadData);
|
|
|
|
|
|
if (!resultCtrn.Success)
|
|
|
{
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "入库失败!";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
var json = JsonConvert.Serialize(new { success = true, Message = "入库成功", data = CtrnList, });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
catch (Exception execError)
|
|
|
{
|
|
|
workbook.Close(true, Type.Missing, Type.Missing);
|
|
|
workbook = null;
|
|
|
excel.Quit();
|
|
|
excel = null;
|
|
|
System.IO.File.Delete(filename);
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "读取Excel文件出错,请确认文件正确性" + execError.Message;
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
|
/// 从一组海运进口的集装箱信息中,
|
|
|
/// 找到并返回一组与【第一条“ISWMS==0”】的WMSDATE相一致的一组ctn
|
|
|
/// 他们的ISWMS被标记为“D”;
|
|
|
/// </summary>
|
|
|
/// <param name="ctrnList"></param>
|
|
|
/// <returns></returns>
|
|
|
public List<MsOpSeaiDetail> CtrnToWMSDateList(List<MsOpSeaiDetail> ctrnList)
|
|
|
{
|
|
|
List<MsOpSeaiDetail> dateList = new List<MsOpSeaiDetail>();
|
|
|
string wmsdate = "";
|
|
|
foreach (var enumValue in ctrnList)
|
|
|
{
|
|
|
|
|
|
if (enumValue.ISWMS == "0" && dateList.Count == 0)
|
|
|
{
|
|
|
wmsdate = enumValue.WMSDATE;
|
|
|
enumValue.ISWMS = "D";
|
|
|
dateList.Add(enumValue);
|
|
|
}
|
|
|
else if (enumValue.ISWMS == "0" && enumValue.ISWMS !="" && enumValue.WMSDATE == wmsdate)
|
|
|
{
|
|
|
enumValue.ISWMS = "D";
|
|
|
dateList.Add(enumValue);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
return dateList;
|
|
|
}
|
|
|
|
|
|
|
|
|
public List<MsOpSeaiDetail> CtrnToAreaList(List<MsOpSeaiDetail> ctrnList)
|
|
|
{
|
|
|
List<MsOpSeaiDetail> areaList = new List<MsOpSeaiDetail>();
|
|
|
string areaname = "";
|
|
|
foreach (var enumValue in ctrnList)
|
|
|
{
|
|
|
|
|
|
if (enumValue.ISWMS == "D" && areaList.Count == 0)
|
|
|
{
|
|
|
areaname = enumValue.AREANAME;
|
|
|
enumValue.ISWMS = "1";
|
|
|
areaList.Add(enumValue);
|
|
|
}
|
|
|
else if (enumValue.ISWMS == "D" && enumValue.AREANAME == areaname)
|
|
|
{
|
|
|
enumValue.ISWMS = "1";
|
|
|
areaList.Add(enumValue);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
return areaList;
|
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
|
/// 通过海运进口的集装箱信息 生成相应的入库信息
|
|
|
/// </summary>
|
|
|
/// <param name="ctrnList"></param>
|
|
|
/// <param name="headData"></param>
|
|
|
/// <returns></returns>
|
|
|
public DBResult CtrnToWMS(List<MsOpSeaiDetail> ctrnList, MsOpSeai headData, List<MsOpCtrnExcel> CtrnExcelList = null)
|
|
|
{
|
|
|
DBResult result = null;
|
|
|
|
|
|
if (ctrnList.Count == 0)
|
|
|
return result;
|
|
|
|
|
|
|
|
|
WMSNew wms = new WMSNew();
|
|
|
wms.GID = "Wms" + Guid.NewGuid().ToString().Replace("-", "");
|
|
|
wms.WMSDATE = ctrnList[0].WMSDATE;
|
|
|
wms.ACCDATE = wms.WMSDATE.Substring(0, 7);
|
|
|
var billnoset = MsSysBillNoSetDAL.GetData("OPLBNAME='仓储入库'", Convert.ToString(Session["COMPANYID"]));
|
|
|
wms.WMSNO = MsSysBillNoSetDAL.GetBillNo(billnoset, ctrnList[0].WMSDATE.ToString().Trim(), wms.ACCDATE.ToString().Trim());
|
|
|
|
|
|
wms.DbOperationType = DbOperationType.DbotIns;
|
|
|
wms.ModelUIStatus = "I";
|
|
|
wms.CORPID = Convert.ToString(Session["COMPANYID"]).Trim();//CORPID
|
|
|
wms.WMSOP = CookieConfig.GetCookie_UserName(Request);
|
|
|
wms.CREATEUSER = CookieConfig.GetCookie_UserId(Request);
|
|
|
wms.CREATETIME = DateTime.Now.ToString("yyyy-MM-dd");
|
|
|
wms.MODIFIEDTIME = wms.CREATETIME;
|
|
|
wms.MODIFIEDUSER = wms.CREATEUSER;
|
|
|
wms.ASSOCIATEDNO = ctrnList[0].BSNO;
|
|
|
wms.ISCHANGE = "False";
|
|
|
wms.FREESTORAGEPERIODAP = "0";
|
|
|
wms.BLNO = headData.MBLNO;
|
|
|
wms.ASSOCIATEDNO = headData.BSNO;
|
|
|
wms.CONTRACTNO = headData.CONTRACTNO;
|
|
|
wms.STORAGENAME = headData.STORAGENAME;
|
|
|
wms.CUSTOMERNAME = headData.CUSTOMERNAME;
|
|
|
wms.ARCLIENT = headData.CUSTOMERNAME;
|
|
|
wms.GOODSNAME = headData.GOODSNAME;
|
|
|
wms.GOODSNAMEID = headData.GOODSNAMEID;
|
|
|
wms.AREANAME = ctrnList[0].AREANAME;
|
|
|
|
|
|
wms.FREESTORAGEPERIOD = "0";
|
|
|
wms.STARTBILLINGDATE = wms.WMSDATE;
|
|
|
wms.STARTBILLINGDATEAP = wms.WMSDATE;
|
|
|
wms.CHARGEUNIT = headData.UNITOFWEIGHT;
|
|
|
wms.ISLOCK = "0";
|
|
|
wms.RENTAREA = "0";
|
|
|
wms.MARKETVALUE = "0";
|
|
|
wms.BANKVALUE = "0";
|
|
|
|
|
|
int linenum = 1;
|
|
|
int pkgs = 0;
|
|
|
decimal kgs = 0;
|
|
|
|
|
|
List<WMSNewIN> wmsInList = new List<WMSNewIN>();
|
|
|
List<WMSIN_ZMYL> wmsIn_ZMYLList = new List<WMSIN_ZMYL>();
|
|
|
List<CountryModel> countryList = BasicDataRefDAL.GetCountryRefList("");
|
|
|
if (CtrnExcelList == null)
|
|
|
{
|
|
|
|
|
|
foreach (MsOpSeaiDetail item in ctrnList)
|
|
|
{
|
|
|
WMSNewIN wmsin = new WMSNewIN();
|
|
|
wmsin.GID = item.CTN_ID;
|
|
|
//wmsin.GID = Guid.NewGuid().ToString();
|
|
|
// wmsin.ASSOCIATEDNO = wms.GID;
|
|
|
wmsin.BSNO = wms.ASSOCIATEDNO;
|
|
|
wmsin.CONTRACTNO = wms.CONTRACTNO;
|
|
|
wmsin.BLNO = wms.BLNO;
|
|
|
wmsin.STORAGENAME = wms.STORAGENAME;
|
|
|
|
|
|
wmsin.GOODSNAME = wms.GOODSNAME;
|
|
|
wmsin.GOODSNAMEID = wms.GOODSNAMEID;
|
|
|
|
|
|
pkgs += item.PKGS;
|
|
|
wmsin.JIANSHU1 = Convert.ToString(item.PKGS);
|
|
|
wmsin.GOODSPACK = Convert.ToString(item.PKGS);
|
|
|
wmsin.GOODSPACKSTOCK = Convert.ToString(item.PKGS);
|
|
|
wmsin.GOODSPACKACTUAL = Convert.ToString(item.PKGS);
|
|
|
|
|
|
kgs += item.KGS / 1000;
|
|
|
wmsin.GOODSKGS = Convert.ToString(item.KGS / 1000);
|
|
|
wmsin.GOODSSTOCK = Convert.ToString(item.KGS / 1000);
|
|
|
wmsin.GOODSRKSL = Convert.ToString(item.KGS / 1000);
|
|
|
wmsin.GOODSRKSLACTUAL = Convert.ToString(item.KGS / 1000);
|
|
|
wmsin.SHIJIZHONGLIANG = Convert.ToString(item.KGS / 1000);
|
|
|
|
|
|
|
|
|
wmsin.CHARGEUNIT = wms.CHARGEUNIT;
|
|
|
|
|
|
wmsin.CNTRNO = item.CNTRNO;
|
|
|
wmsin.SEALNO = item.SEALNO;
|
|
|
wmsin.CTNALL = item.CTNALL;
|
|
|
|
|
|
wmsin.STORAGENAME = wms.STORAGENAME;
|
|
|
wmsin.CLIENTNAME = wms.CUSTOMERNAME;
|
|
|
wmsin.DODATE = wms.WMSDATE;
|
|
|
wmsin.CORPID = Convert.ToString(Session["COMPANYID"]).Trim();
|
|
|
wmsin.CREATEUSER = CookieConfig.GetCookie_UserId(Request);
|
|
|
wmsin.CREATETIME = DateTime.Now.ToString("yyyy-MM-dd");
|
|
|
wmsin.MODIFIEDTIME = wms.CREATETIME;
|
|
|
wmsin.MODIFIEDUSER = wms.CREATEUSER;
|
|
|
wmsin.ISLOCK = "0";
|
|
|
|
|
|
wmsin.LOADERFEE = "0";
|
|
|
wmsin.ZhuangXieFei = "0";
|
|
|
wmsin.CHIMA2 = "0";
|
|
|
|
|
|
wmsin.ZHONGLIANG2 = "0";
|
|
|
wmsin.SHIJICHIMA = "0";
|
|
|
|
|
|
wmsin.LUYUNFEI = "0";
|
|
|
wmsin.DIAOTOUFEI = "0";
|
|
|
wmsin.XIUXIXIANGFEI = "0";
|
|
|
wmsin.DIAOZHUANGFEI = "0";
|
|
|
|
|
|
wmsin.JIANSHU2 = "0";
|
|
|
wmsin.LinShiZhuangXieFeiDanJiaDun = "0";
|
|
|
wmsin.LinShiZhuangXieFeiDanJiaJian = "0";
|
|
|
wmsin.FREESTORAGEPERIOD = "0";
|
|
|
|
|
|
wmsin.ISDELETE = "0";
|
|
|
wmsin.APFEE = "0";
|
|
|
wmsin.ARFEE = "0";
|
|
|
|
|
|
wmsin.MARKETVALUE = "0";
|
|
|
wmsin.BANKVALUE = "0";
|
|
|
wmsin.LINENUM = Convert.ToString(linenum);
|
|
|
linenum++;
|
|
|
|
|
|
wmsin.GOODSTHICKNESS = "0";
|
|
|
wmsin.GOODSWIDTH = "0";
|
|
|
wmsin.GOODSLENGTH = "0";
|
|
|
|
|
|
wmsin.GOODSSLICE = "0";
|
|
|
wmsin.GOODSGRADE = "0";
|
|
|
wmsin.ISCHANGE = "0";
|
|
|
//wmsin.COUNTRYID = "";
|
|
|
|
|
|
|
|
|
Pattern p = Pattern.compile(".*?(?=\\()");
|
|
|
Matcher m = p.matcher(headData.COUNTRYOFORIGIN);
|
|
|
var countryname = "";
|
|
|
if (m.find())
|
|
|
{
|
|
|
countryname=m.group();
|
|
|
}
|
|
|
|
|
|
CountryModel c = countryList.FirstOrDefault(s => s.country.indexOf (countryname) >=0);
|
|
|
try
|
|
|
{
|
|
|
wmsin.COUNTRYID = c.countryid;
|
|
|
}
|
|
|
catch {
|
|
|
wmsin.COUNTRYID = "";
|
|
|
}
|
|
|
wmsInList.Add(wmsin);
|
|
|
}
|
|
|
}
|
|
|
if (CtrnExcelList != null)
|
|
|
{
|
|
|
|
|
|
foreach (MsOpSeaiDetail item in ctrnList)
|
|
|
{
|
|
|
WMSIN_ZMYL wmsin = new WMSIN_ZMYL();
|
|
|
wmsin.GID = item.CTN_ID;
|
|
|
//wmsin.GID = Guid.NewGuid().ToString();
|
|
|
// wmsin.ASSOCIATEDNO = wms.GID;
|
|
|
wmsin.BSNO = wms.ASSOCIATEDNO;
|
|
|
wmsin.CONTRACTNO = wms.CONTRACTNO;
|
|
|
wmsin.BLNO = wms.BLNO;
|
|
|
wmsin.STORAGENAME = wms.STORAGENAME;
|
|
|
|
|
|
wmsin.GOODSNAME = wms.GOODSNAME;
|
|
|
wmsin.GOODSNAMEID = wms.GOODSNAMEID;
|
|
|
|
|
|
pkgs += item.PKGS;
|
|
|
wmsin.JIANSHU1 = Convert.ToString(item.PKGS);
|
|
|
wmsin.GOODSPACK = Convert.ToString(item.PKGS);
|
|
|
wmsin.GOODSPACKSTOCK = Convert.ToString(item.PKGS);
|
|
|
wmsin.GOODSPACKACTUAL = Convert.ToString(item.PKGS);
|
|
|
|
|
|
kgs += item.KGS / 1000;
|
|
|
wmsin.GOODSKGS = Convert.ToString(item.KGS / 1000);
|
|
|
wmsin.GOODSSTOCK = Convert.ToString(item.KGS / 1000);
|
|
|
wmsin.GOODSRKSL = Convert.ToString(item.KGS / 1000);
|
|
|
wmsin.GOODSRKSLACTUAL = Convert.ToString(item.KGS / 1000);
|
|
|
wmsin.SHIJIZHONGLIANG = Convert.ToString(item.KGS / 1000);
|
|
|
|
|
|
|
|
|
wmsin.CHARGEUNIT = wms.CHARGEUNIT;
|
|
|
|
|
|
wmsin.CNTRNO = item.CNTRNO;
|
|
|
wmsin.SEALNO = item.SEALNO;
|
|
|
wmsin.CTNALL = item.CTNALL;
|
|
|
|
|
|
wmsin.STORAGENAME = wms.STORAGENAME;
|
|
|
wmsin.CLIENTNAME = wms.CUSTOMERNAME;
|
|
|
wmsin.DODATE = wms.WMSDATE;
|
|
|
wmsin.CORPID = Convert.ToString(Session["COMPANYID"]).Trim();
|
|
|
wmsin.CREATEUSER = CookieConfig.GetCookie_UserId(Request);
|
|
|
wmsin.CREATETIME = DateTime.Now.ToString("yyyy-MM-dd");
|
|
|
wmsin.MODIFIEDTIME = wms.CREATETIME;
|
|
|
wmsin.MODIFIEDUSER = wms.CREATEUSER;
|
|
|
wmsin.ISLOCK = "0";
|
|
|
|
|
|
wmsin.LOADERFEE = "0";
|
|
|
wmsin.ZhuangXieFei = "0";
|
|
|
wmsin.CHIMA2 = "0";
|
|
|
|
|
|
wmsin.ZHONGLIANG2 = "0";
|
|
|
wmsin.SHIJICHIMA = "0";
|
|
|
|
|
|
wmsin.LUYUNFEI = "0";
|
|
|
wmsin.DIAOTOUFEI = "0";
|
|
|
wmsin.XIUXIXIANGFEI = "0";
|
|
|
wmsin.DIAOZHUANGFEI = "0";
|
|
|
|
|
|
wmsin.JIANSHU2 = "0";
|
|
|
wmsin.LinShiZhuangXieFeiDanJiaDun = "0";
|
|
|
wmsin.LinShiZhuangXieFeiDanJiaJian = "0";
|
|
|
wmsin.FREESTORAGEPERIOD = "0";
|
|
|
|
|
|
wmsin.ISDELETE = "0";
|
|
|
wmsin.APFEE = "0";
|
|
|
wmsin.ARFEE = "0";
|
|
|
|
|
|
wmsin.MARKETVALUE = "0";
|
|
|
wmsin.BANKVALUE = "0";
|
|
|
wmsin.LINENUM = Convert.ToString(linenum);
|
|
|
linenum++;
|
|
|
|
|
|
wmsin.GOODSTHICKNESS = "0";
|
|
|
wmsin.GOODSWIDTH = "0";
|
|
|
wmsin.GOODSLENGTH = "0";
|
|
|
|
|
|
wmsin.GOODSSLICE = "0";
|
|
|
wmsin.GOODSGRADE = "0";
|
|
|
wmsin.ISCHANGE = "0";
|
|
|
|
|
|
////
|
|
|
var CtrnExcel = CtrnExcelList.Find(t => t.CtrnNo == wmsin.CNTRNO);
|
|
|
if (CtrnExcel != null)
|
|
|
{
|
|
|
wmsin.GOODSMODEL = CtrnExcel.GOODSMODEL;
|
|
|
wmsin.KINDPKGS = CtrnExcel.KINDPKGS;
|
|
|
wmsin.BZTCHNO = CtrnExcel.BZTCHNO;
|
|
|
wmsin.PRODUCTIONDATE = CtrnExcel.PRODUCTIONDATE;
|
|
|
wmsin.INVOICENO = CtrnExcel.INVOICENO;
|
|
|
}
|
|
|
|
|
|
wmsin.FACTORYNO = "";
|
|
|
|
|
|
Pattern p = Pattern.compile(".*?(?=\\()");
|
|
|
Matcher m = p.matcher(headData.COUNTRYOFORIGIN);
|
|
|
var countryname = "";
|
|
|
if (m.find())
|
|
|
{
|
|
|
countryname = m.group();
|
|
|
}
|
|
|
|
|
|
CountryModel c = countryList.FirstOrDefault(s => s.country.indexOf(countryname) >= 0);
|
|
|
try
|
|
|
{
|
|
|
wmsin.COUNTRYID = c.countryid;
|
|
|
}
|
|
|
catch
|
|
|
{
|
|
|
wmsin.COUNTRYID = "";
|
|
|
}
|
|
|
wmsIn_ZMYLList.Add(wmsin);
|
|
|
}
|
|
|
}
|
|
|
wms.TiDanZhongLiang = Convert.ToString(headData.KGS / 1000);
|
|
|
wms.TiDanJianShu = Convert.ToString(headData.PKGS);
|
|
|
wms.GOODSRKSL = Convert.ToString(kgs);
|
|
|
wms.GOODSRKSLACTUAL = Convert.ToString(kgs);
|
|
|
wms.GOODSKGS = Convert.ToString(kgs);
|
|
|
wms.GOODSSTOCK = Convert.ToString(kgs);
|
|
|
|
|
|
wms.GOODSPACK = Convert.ToString(pkgs);
|
|
|
wms.GOODSPACKSTOCK = Convert.ToString(pkgs);
|
|
|
wms.GOODSPACKACTUAL = Convert.ToString(pkgs);
|
|
|
|
|
|
|
|
|
var modb = new ModelObjectRepository();
|
|
|
|
|
|
if (CtrnExcelList == null)
|
|
|
{
|
|
|
result = modb.Save(wms,
|
|
|
ModelObjectConvert<WMSNewIN>.ToModelObjectList(wmsInList),
|
|
|
null
|
|
|
);
|
|
|
}
|
|
|
else {
|
|
|
result = modb.Save(wms,
|
|
|
ModelObjectConvert<WMSIN_ZMYL>.ToModelObjectList(wmsIn_ZMYLList),
|
|
|
null
|
|
|
);
|
|
|
}
|
|
|
if(result.Success)
|
|
|
result = MsOpSeaiDAL.UpdateCtrnWMSState(ctrnList);
|
|
|
return result;
|
|
|
}
|
|
|
#endregion
|
|
|
|
|
|
#region 提单箱数据入库
|
|
|
public ContentResult SaveCtrnToWMS(string CtnrData, string data, string data2, string data3)
|
|
|
{
|
|
|
var jsonRespose = new JsonResponse { Success = false, Message = "" };
|
|
|
|
|
|
try
|
|
|
{
|
|
|
|
|
|
var CtrnList = JsonConvert.Deserialize<List<MsOpSeaiDetail>>(CtnrData);
|
|
|
var HeadData = JsonConvert.Deserialize<MsOpSeai>(data.Replace("}", ",") + data2.Replace("{", "").Replace("}", ",") + data3.Replace("{", ""));
|
|
|
|
|
|
|
|
|
DBResult resultCtrn = MsOpSeaiDAL.UpdateCtrnDetail(CtrnList);
|
|
|
if (resultCtrn.Success)
|
|
|
{
|
|
|
//按照入库时间、储位分别生成入库单
|
|
|
int ctrnNum = MsOpSeaiDAL.CtrnToWMS_DATENUM(HeadData.BSNO);
|
|
|
if (ctrnNum > 0)
|
|
|
{
|
|
|
for (int i = 1; i <= ctrnNum; i++)
|
|
|
{
|
|
|
List<MsOpSeaiDetail> dateList = CtrnToWMSDateList(CtrnList);
|
|
|
if (dateList.Count != 0)
|
|
|
{
|
|
|
for (int j = 1; j <= dateList.Count(); j++)
|
|
|
{
|
|
|
List<MsOpSeaiDetail> areaList = CtrnToAreaList(dateList);
|
|
|
resultCtrn = CtrnToWMS(areaList, HeadData);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
}
|
|
|
}
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
if (!resultCtrn.Success)
|
|
|
{
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "入库失败!";
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
var json = JsonConvert.Serialize(new { Success = true, Message = "入库成功", Data = CtrnList, });
|
|
|
return new ContentResult() { Content = json };
|
|
|
|
|
|
}
|
|
|
catch (Exception execError)
|
|
|
{
|
|
|
|
|
|
jsonRespose.Success = false;
|
|
|
jsonRespose.Message = "对不起,提单箱数据入库出现异常" + execError.Message;
|
|
|
return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
|
|
|
}
|
|
|
}
|
|
|
#endregion
|
|
|
//
|
|
|
|
|
|
#region 红柿子-青银 接口发送到港日
|
|
|
|
|
|
public ContentResult Needsend(string headid) {
|
|
|
var condition = $" B.bsno='{headid}'";
|
|
|
var head = MsOpSeaiDAL.GetData(condition);
|
|
|
|
|
|
CommonDataContext cdc = new CommonDataContext();
|
|
|
|
|
|
var cansendparam = cdc.sys_param_set.Where(x => x.PARAMNAME == "QY_ETA_SEND").ToList();
|
|
|
|
|
|
var result = new DBResult();
|
|
|
|
|
|
if (cansendparam != null && cansendparam.Count > 0)
|
|
|
{
|
|
|
if (cansendparam[0].PARAMVALUE == "1")
|
|
|
{
|
|
|
result.setMessage(true, "");
|
|
|
}
|
|
|
}
|
|
|
else result.SetErrorInfo("无此项目");
|
|
|
|
|
|
|
|
|
|
|
|
var json = JsonConvert.Serialize(
|
|
|
new { Success = result.Success, Message = result.Message, data = "" });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
|
|
|
private static DBResult needsend(MsOpSeai headData) {
|
|
|
var result = new DBResult();
|
|
|
|
|
|
if (string.IsNullOrWhiteSpace(headData.CONTRACTNO) || string.IsNullOrWhiteSpace(headData.MBLNO) || string.IsNullOrWhiteSpace(headData.ETD)) {
|
|
|
result.SetErrorInfo("数据不全,不需传送");
|
|
|
return result;
|
|
|
}
|
|
|
|
|
|
CommonDataContext cdc = new CommonDataContext();
|
|
|
|
|
|
var cansendparam = cdc.sys_param_set.Where(x => x.PARAMNAME == "QY_ETA_SEND").ToList();
|
|
|
|
|
|
if (cansendparam != null && cansendparam.Count > 0)
|
|
|
{
|
|
|
if (cansendparam[0].PARAMVALUE == "1") {
|
|
|
result.setMessage(true, "");
|
|
|
}
|
|
|
}
|
|
|
else result.SetErrorInfo("无此项目");
|
|
|
|
|
|
return result;
|
|
|
}
|
|
|
|
|
|
public class saveEtaTimemb
|
|
|
{
|
|
|
public string status { get; set; }
|
|
|
public string msg { get; set; }
|
|
|
}
|
|
|
|
|
|
|
|
|
public static DBResult QY_ETA_SEND(MsOpSeai headData) {
|
|
|
var result = new DBResult();
|
|
|
|
|
|
CommonDataContext cdc = new CommonDataContext();
|
|
|
|
|
|
try
|
|
|
{
|
|
|
//如果符合条件 则进行发送
|
|
|
|
|
|
var cansend = needsend(headData);
|
|
|
if (!cansend.Success) return cansend;
|
|
|
|
|
|
var dic = new Dictionary<string, string>();
|
|
|
dic.Add("contractNo", headData.CONTRACTNO);
|
|
|
dic.Add("blNo", headData.MBLNO);
|
|
|
dic.Add("etatime", headData.ETD);
|
|
|
|
|
|
//var _IURL = "http://47.105.179.40:8080/wms-admin/api/edi/saveEtaTime";
|
|
|
var _IURL = "http://82.157.27.145:8099/wms-admin/api/edi/saveEtaTime";
|
|
|
|
|
|
string Contentjson = JsonConvert.Serialize(dic);
|
|
|
|
|
|
var rtn = WebRequestHelper.DoPost(_IURL, Contentjson);
|
|
|
//var rtn = WebRequestHelper.DoPost(_SandBoxURL, dic, 20000);
|
|
|
|
|
|
//RepCZModel CZM = Newtonsoft.Json.JsonConvert.DeserializeObject<RepCZModel>(rtn);
|
|
|
saveEtaTimemb pt = Newtonsoft.Json.JsonConvert.DeserializeObject<saveEtaTimemb>(rtn);
|
|
|
|
|
|
if (pt.status == "0")
|
|
|
{
|
|
|
result.OK();
|
|
|
return result;
|
|
|
}
|
|
|
else {
|
|
|
result.SetErrorInfo(pt.msg);
|
|
|
return result;
|
|
|
}
|
|
|
|
|
|
}
|
|
|
catch (Exception e)
|
|
|
{
|
|
|
|
|
|
result.SetErrorInfo(e.Message);
|
|
|
return result;
|
|
|
}
|
|
|
|
|
|
return result;
|
|
|
}
|
|
|
|
|
|
public class QY_WarehouseNotice_good {
|
|
|
public string goodId { get; set; }
|
|
|
public string goodCode { get; set; }
|
|
|
public string goodName { get; set; }
|
|
|
public string oneNum { get; set; }
|
|
|
public string unit { get; set; }
|
|
|
public string grossWeightSum { get; set; }
|
|
|
public string total { get; set; }
|
|
|
public QY_WarehouseNotice_good() { }
|
|
|
|
|
|
public QY_WarehouseNotice_good(MsOpApplyDetail detail) {
|
|
|
goodId = detail.BsNo + detail.SerialNo;
|
|
|
goodCode = detail.GoodsCode;
|
|
|
goodName = detail.GoodsName;
|
|
|
oneNum = Math.Round(detail.GOODSNUM,0).ToString();
|
|
|
unit = detail.KINDPKGS;
|
|
|
grossWeightSum = detail.KGS.ToString();
|
|
|
total = detail.Total.ToString();
|
|
|
}
|
|
|
}
|
|
|
public class QY_WarehouseNotice {
|
|
|
public string id { get; set; }
|
|
|
public string blNo { get; set; }
|
|
|
public string contractNo { get; set; }
|
|
|
|
|
|
/// <summary>
|
|
|
/// 委托编号
|
|
|
/// </summary>
|
|
|
public string custNo { get; set; }
|
|
|
public string customerCode { get; set; }
|
|
|
public string trade { get; set; }
|
|
|
public string caseType { get; set; }
|
|
|
public string etaDate { get; set; }
|
|
|
public string receiveDate { get; set; }
|
|
|
|
|
|
public string remark { get; set; }
|
|
|
public List<QY_WarehouseNotice_good> goodsList { get; set; }
|
|
|
|
|
|
public QY_WarehouseNotice() { }
|
|
|
public QY_WarehouseNotice(MsOpSeai headData) {
|
|
|
id = headData.BSNO;
|
|
|
blNo = headData.MBLNO;
|
|
|
contractNo = headData.CONTRACTNO;
|
|
|
custNo = headData.CUSTNO;
|
|
|
|
|
|
var custcode = BasicDataRefDAL.GetCustomerCode(headData.CUSTOMERNAME);
|
|
|
|
|
|
//customerCode = headData.CUSTOMERNAME;
|
|
|
|
|
|
customerCode = headData.APPLYNO;//20220323修改
|
|
|
trade = headData.TRADETYPE;
|
|
|
caseType = headData.CNTRTOTAL.replace("/",",");
|
|
|
etaDate = headData.ETD;
|
|
|
receiveDate = headData.BSDATE+" 00:00:00";
|
|
|
remark = headData.REMARK;
|
|
|
|
|
|
var detaillist= MsOpApplyDAL.GetBodyList(" BsNo='" + id + "' ");
|
|
|
goodsList = new List<QY_WarehouseNotice_good>();
|
|
|
|
|
|
foreach (var item in detaillist) {
|
|
|
var newdetail = new QY_WarehouseNotice_good(item);
|
|
|
goodsList.Add(newdetail);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
public DBResult cansend() {
|
|
|
var result = new DBResult();
|
|
|
result.setMessage(true, "");
|
|
|
if (goodsList==null|| goodsList.Count == 0) {
|
|
|
result.SetErrorInfo("没有商品明细");
|
|
|
}
|
|
|
if (goodsList .Exists(x=>Convert.ToInt32( x.oneNum)==0))
|
|
|
{
|
|
|
result.SetErrorInfo("存在件数为0的商品信息");
|
|
|
}
|
|
|
return result;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
public ContentResult QY_addWarehouseNotice(string headid)
|
|
|
{
|
|
|
var condition = $" B.bsno='{headid}'";
|
|
|
var head = MsOpSeaiDAL.GetData(condition);
|
|
|
|
|
|
var dbresult = QY_addWarehouseNotice(head);
|
|
|
|
|
|
var json = JsonConvert.Serialize(
|
|
|
new { Success = dbresult.Success, Message = dbresult.Message, data = "" });
|
|
|
return new ContentResult() { Content = json };
|
|
|
}
|
|
|
public static DBResult QY_addWarehouseNotice(MsOpSeai headData)
|
|
|
{
|
|
|
var result = new DBResult();
|
|
|
|
|
|
CommonDataContext cdc = new CommonDataContext();
|
|
|
|
|
|
try
|
|
|
{
|
|
|
//如果符合条件 则进行发送
|
|
|
|
|
|
//var cansend = needsend(headData);
|
|
|
//if (!cansend.Success) return cansend;
|
|
|
|
|
|
var newrecord = new QY_WarehouseNotice(headData);
|
|
|
|
|
|
//var _IURL = "http://47.105.179.40:8080/wms-admin/api/edi/addWarehouseNotice";
|
|
|
var _IURL = "http://82.157.27.145:8099/wms-admin/api/edi/addWarehouseNotice";
|
|
|
|
|
|
string Contentjson = JsonConvert.Serialize(newrecord);
|
|
|
|
|
|
var rtn = WebRequestHelper.DoPost(_IURL, Contentjson);
|
|
|
//var rtn = WebRequestHelper.DoPost(_SandBoxURL, dic, 20000);
|
|
|
|
|
|
//RepCZModel CZM = Newtonsoft.Json.JsonConvert.DeserializeObject<RepCZModel>(rtn);
|
|
|
saveEtaTimemb pt = Newtonsoft.Json.JsonConvert.DeserializeObject<saveEtaTimemb>(rtn);
|
|
|
|
|
|
if (pt.status == "0")
|
|
|
{
|
|
|
result.OK();
|
|
|
return result;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
result.SetErrorInfo(pt.msg);
|
|
|
return result;
|
|
|
}
|
|
|
|
|
|
}
|
|
|
catch (Exception e)
|
|
|
{
|
|
|
|
|
|
result.SetErrorInfo(e.Message);
|
|
|
return result;
|
|
|
}
|
|
|
|
|
|
return result;
|
|
|
}
|
|
|
|
|
|
#endregion
|
|
|
}
|
|
|
}
|
|
|
|