using System ;
using System.Collections.Generic ;
using System.Linq ;
using System.Web.Mvc ;
using DSWeb.Areas.Import.Models.Comm ;
using DSWeb.Areas.CommMng.DAL ;
using DSWeb.Areas.Import.DAL.ImportTrade ;
using DSWeb.Areas.Import.DAL.ImportSales ;
using DSWeb.Areas.Import.Models.ImportTrade ;
using DSWeb.Areas.Import.DAL.XXH ;
using DSWeb.Areas.Import.Models.XXH ;
using DSWeb.TruckMng.Comm.Cookie ;
using DSWeb.TruckMng.Helper ;
using DSWeb.TruckMng.Helper.Repository ;
using DSWeb.Areas.Import.DAL.Comm ;
using HcUtility.Comm ;
using HcUtility.Core ;
using DSWeb.Areas.CommMng.Models ;
////应对新的单据管理模块
using DSWeb.MvcShipping.Controllers ;
using DSWeb.MvcShipping.DAL.MsOpReceiptDAL ;
using DSWeb.MvcShipping.Models.MsOpReceipt ;
using DSWeb.MvcShipping.Models.MsOpAmend ;
using System.Text ;
using DSWeb.MvcShipping.DAL.MsOpSeaeDAL ;
using DSWeb.MvcShipping.DAL.MsOpSeaeEdiPortDAL ;
using DSWeb.MvcShipping.Models.MsOpSeae ;
using DSWeb.MvcShipping.Models.MsOpSeaeBill ;
using DSWeb.MvcShipping.DAL.MsCodeFtpSet ;
using DSWeb.MvcShipping.DAL.MsBaseInfoDAL ;
using DSWeb.Areas.RptMng.Comm ;
using Microsoft.Office.Interop.Excel ;
using DSWeb.MvcShipping.Models.MsOpApply ;
using DSWeb.MvcShipping.DAL.MsOpApplyDAL ;
using DSWeb.MvcShipping.DAL.MsSysBillNoSet ;
using DSWeb.MvcShipping.Models.MsSysBillNoSet ;
using DSWeb.MvcShipping.Models.WMS ;
using DSWeb.MvcShipping.Controllers ;
using System.IO ;
using DSWeb.Areas.CommMng.DAL ;
using DSWeb.MvcShipping.DAL.WMS ;
using Microsoft.Practices.EnterpriseLibrary.Data ;
using System.Data ;
using DSWeb.SoftMng.Filter ;
namespace DSWeb.Areas.Import.Controllers
{
[JsonRequestBehavior]
public class ImportTradeController : Controller
{
/ /
// GET: /Import/XXH
public ActionResult Index ( )
{
return View ( ) ;
}
/ /
// GET: /Import/XXH/Edit
public ActionResult Edit ( )
{
return View ( ) ;
}
public ActionResult FeeEdit ( )
{
return View ( ) ;
}
public ActionResult WMSIN ( )
{
return View ( ) ;
}
public ActionResult WMSINEdit ( )
{
return View ( ) ;
}
public ActionResult WMSOUT ( )
{
return View ( ) ;
}
public ActionResult WMSOUTEdit ( )
{
return View ( ) ;
}
[ValidateInput(false)]
[SqlKeyWordsFilter(Type = "Action")] //sql 防注入过滤器
public ContentResult GetDataList_ALL ( int start , int limit , string sort , string condition )
{
var dataList = ImportTradeDAL . GetDataList_ALL ( condition , CookieConfig . GetCookie_UserCode ( Request ) , CookieConfig . GetCookie_UserName ( Request ) , CookieConfig . GetCookie_CompanyId ( Request ) , 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 } ;
}
[SqlKeyWordsFilter(Type = "Action")] //sql 防注入过滤器
public ContentResult GetEditList_ALL ( int start , int limit , string sort , string condition )
{
var dataList = XXHDAL . GetEditList_ALL ( condition , CookieConfig . GetCookie_UserCode ( Request ) , CookieConfig . GetCookie_UserName ( Request ) , CookieConfig . GetCookie_CompanyId ( Request ) , 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 } ;
}
[SqlKeyWordsFilter(Type = "Action")] //sql 防注入过滤器
public ContentResult GetDataList_ALL_single ( int start , int limit , string sort , string condition )
{
var dataList = XXHDAL . GetDataList_ALL_single ( condition , CookieConfig . GetCookie_UserCode ( Request ) , CookieConfig . GetCookie_UserName ( Request ) , CookieConfig . GetCookie_CompanyId ( Request ) ) ;
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 } ;
}
[SqlKeyWordsFilter(Type = "Action")] //sql 防注入过滤器
//获取指定合同号的合同数量,用于防止合同号重复
public ContentResult GetData_HT ( string handle , string condition )
{
HTmb head = null ;
var list = XXHDAL . GetDataList_HT ( condition ) ;
if ( list . Count > 0 )
head = list [ 0 ] ;
if ( head = = null )
{ head = new HTmb ( ) ; }
var json = JsonConvert . Serialize (
new { Success = true , Message = "查询成功" , data = head } ) ;
return new ContentResult ( ) { Content = json } ;
}
//获取毛利(通过存储过程)
public ContentResult GetML ( string contractno )
{
MLmb head = null ;
var corpid = Convert . ToString ( Session [ "COMPANYID" ] ) ;
var USERID = Convert . ToString ( Session [ "USERID" ] ) ;
var DEPTGID = Convert . ToString ( Session [ "DEPTGID" ] ) ;
//var OPERATERANGE="";
var VISIBLERANGE = "" ;
var modName = "modImport_Fee" ;
var evList = BasicDataRefDAL . GetAR ( modName , USERID ) ;
AuthorityRangemb AR = null ;
if ( evList . Count > 0 )
AR = evList [ 0 ] ;
if ( AR = = null )
{
AR = new AuthorityRangemb ( ) ;
//OPERATERANGE = "3";
VISIBLERANGE = "3" ;
}
else
{
//OPERATERANGE = head.OPERATERANGE;
VISIBLERANGE = AR . VISIBLERANGE ;
}
var condition = "BsNo='" + contractno + "' " ;
if ( VISIBLERANGE = = "1" )
{
condition = condition + " and enteroperator in(select userid from user_company where companyid='" + corpid + "')" ;
}
if ( VISIBLERANGE = = "2" )
{
condition = condition + " and enteroperator in(select userid from user_baseinfo where companyname=(select name from company where gid='" + corpid + "') " ;
condition = condition + " and deptname=(select deptname from sys_dept where gid='" + DEPTGID + "')) " ;
}
if ( VISIBLERANGE = = "3" )
{
condition = condition + " and enteroperator ='" + USERID + "'" ;
}
var list = XXHDAL . GetML ( condition , contractno ) ;
if ( list . Count > 0 )
head = list [ 0 ] ;
if ( head = = null )
{ head = new MLmb ( ) ; }
var json = JsonConvert . Serialize (
new { Success = true , Message = "查询成功" , data = head } ) ;
return new ContentResult ( ) { Content = json } ;
}
/ /
// GET: /Import/XXH/GetData/
[SqlKeyWordsFilter(Type = "Action")] //sql 防注入过滤器
public ContentResult GetData ( string handle , string condition )
{
ImportTrademb head = null ;
if ( handle = = "edit" )
{
var _t = "" ;
var list = ImportTradeDAL . GetDataList_ALL ( condition , CookieConfig . GetCookie_UserCode ( Request ) , CookieConfig . GetCookie_UserName ( Request ) , CookieConfig . GetCookie_CompanyId ( Request ) , _t ) ;
if ( list . Count > 0 )
head = list [ 0 ] ;
}
if ( head = = null )
{
head = new ImportTrademb ( ) ;
}
if ( handle = = "add" )
{
head . OP = CookieConfig . GetCookie_UserName ( Request ) ;
//head.OPRef = Convert.ToString(Session["SHOWNAME"]);
head . creator = CookieConfig . GetCookie_UserCode ( Request ) ;
head . EXCHANGERATE = "1" ;
head . CORPID = Convert . ToString ( Session [ "COMPANYID" ] ) ;
}
if ( head = = null )
{
head = new ImportTrademb ( ) ;
}
var json = JsonConvert . Serialize (
new { Success = true , Message = "查询成功" , data = head } ) ;
return new ContentResult ( ) { Content = json } ;
}
/ /
// GET: /Import/ImportTrade/Save
public ContentResult Save ( string opstatus , string data , string CargoBody , string CargoDelBody )
{
//var headData = JsonConvert.Deserialize<MsOpSeae>(data.Replace("}", ",") + data2.Replace("{", "").Replace("}", ",") + data3.Replace("{", ""));
var head = JsonConvert . Deserialize < ImportTrademb > ( data ) ;
var CargobodyList = JsonConvert . Deserialize < List < Cargomb2 > > ( CargoBody ) ;
var CargodelbodyList = JsonConvert . Deserialize < List < Cargomb2 > > ( CargoDelBody ) ;
if ( opstatus = = "add" )
{
head . DbOperationType = DbOperationType . DbotIns ;
head . ModelUIStatus = "I" ;
head . CORPID = Convert . ToString ( Session [ "COMPANYID" ] ) ;
head . ContractNo = PubSysDAL . GetBillNo ( "0201" ) ; //获取合同号
//headData.LrDate = DateTime.Now;
}
else if ( opstatus = = "edit" )
{
head . DbOperationType = DbOperationType . DbotUpd ;
head . ModelUIStatus = "E" ;
}
else
{
head . DbOperationType = DbOperationType . DbotDel ;
}
var modb = new ModelObjectRepository ( ) ;
DBResult result = modb . Save ( head ,
ModelObjectConvert < Cargomb2 > . ToModelObjectList ( CargobodyList ) ,
ModelObjectConvert < Cargomb2 > . ToModelObjectList ( CargodelbodyList )
) ;
//刷新父窗口上的父节点
var jsonRespose = new JsonResponse
{
Success = result . Success ,
Message = result . Message ,
Data = ImportTradeDAL . GetData_ALL ( "M.ContractNo='" + head . ContractNo + "'" , CookieConfig . GetCookie_UserCode ( Request ) , CookieConfig . GetCookie_UserName ( Request ) , CookieConfig . GetCookie_CompanyId ( Request ) )
} ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
}
public ContentResult Delete ( string data )
{
var head = JsonConvert . Deserialize < ImportTrademb > ( data ) ;
var modb = new ModelObjectDB ( ) ;
DBResult result = modb . Delete ( head , Session [ "USERID" ] . ToString ( ) , true ) ;
var ContractNo = head . ContractNo ;
var jsonRespose = new JsonResponse { Success = result . Success , Message = result . Message } ;
var _count = XXHDAL . ClearHTH ( ContractNo ) ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
//return new ContentResult() { Content = JsonConvert.Serialize(jsonRespose) };
}
// Get:/Import/XXH/GetCargoList
[SqlKeyWordsFilter(Type = "Action")] //sql 防注入过滤器
public ContentResult GetCargoList ( string condition )
{
var _condition = " c.ContractNo = '" + condition + "' " ;
List < Cargomb > list = XXHDAL . GetCargoList ( _condition ) ;
var json = JsonConvert . Serialize ( new { Success = true , Message = "查询成功" , totalCount = list . Count , data = list . ToList ( ) } ) ;
return new ContentResult ( ) { Content = json } ;
}
[SqlKeyWordsFilter(Type = "Action")] //sql 防注入过滤器
public ContentResult GetCargoList2 ( string condition ) //增加三个字段
{
var _condition = " c.ContractNo = '" + condition + "' " ;
List < Cargomb2 > list = ImportTradeDAL . GetCargoList2 ( _condition ) ;
var json = JsonConvert . Serialize ( new { Success = true , Message = "查询成功" , totalCount = list . Count , data = list . ToList ( ) } ) ;
return new ContentResult ( ) { Content = json } ;
}
[SqlKeyWordsFilter(Type = "Action")] //sql 防注入过滤器
public ContentResult GetCargoList3 ( string condition ) //接受条件
{
var _condition = condition ;
List < Cargomb3 > list = ImportTradeDAL . GetCargoList3 ( _condition ) ;
var json = JsonConvert . Serialize ( new { Success = true , Message = "查询成功" , totalCount = list . Count , data = list . ToList ( ) } ) ;
return new ContentResult ( ) { Content = json } ;
}
#region 获取指定合同号的费用数量,防止有费用的合同被删
[SqlKeyWordsFilter(Type = "Action")] //sql 防注入过滤器
public ContentResult GetChfee ( string handle , string condition )
{
HTmb head = null ;
var list = XXHDAL . GetChfee ( condition ) ;
if ( list . Count > 0 )
head = list [ 0 ] ;
if ( head = = null )
{ head = new HTmb ( ) ; }
var json = JsonConvert . Serialize (
new { Success = true , Message = "查询成功" , data = head } ) ;
return new ContentResult ( ) { Content = json } ;
}
# endregion
#region 锁定商品信息,生成库存
//20160707 修改
//如无对应销售信息,货主为操作者的“本公司”
//如有对应销售信息,则首先判断销售重量是否大于等于实际入库重量。
//如剩余重量小于等于1kg, 则全部按销售重量和销售客户, 按比例生成。
//如剩余重量大于1kg, 则剩余部分按货主为操作者的“本公司”处理。
public ContentResult LockCargo ( string CUSTOMERNAME , string STORAGENAME , string WMSDATE , string CargoBody )
{
//首先通过商品信息生成和保存wms和wms_in
var CargobodyList = JsonConvert . Deserialize < List < Cargomb3 > > ( CargoBody ) ;
var WMSNOList = MakeWMS ( CUSTOMERNAME , STORAGENAME , WMSDATE , CargobodyList ) ;
/ *
var WMSC = new WMSController ( ) ;
var USERID = CookieConfig . GetCookie_UserId ( Request ) ;
var _k = WMSC . LockWMS ( WMSNOList , USERID , "1" ) ;
* /
var json = JsonConvert . Serialize ( new { Success = true , Message = "查询成功" , data = WMSNOList } ) ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( json ) } ;
}
public ContentResult LockCargo2 ( string STORAGENAME , string WMSDATE , string CargoBody )
{
//首先通过商品信息生成和保存wms和wms_in
var CargobodyList = JsonConvert . Deserialize < List < Cargomb3 > > ( CargoBody ) ;
var WMSNOList = MakeWMS2 ( STORAGENAME , WMSDATE , CargobodyList ) ;
/ *
var WMSC = new WMSController ( ) ;
var USERID = CookieConfig . GetCookie_UserId ( Request ) ;
var _k = WMSC . LockWMS ( WMSNOList , USERID , "1" ) ;
* /
var json = JsonConvert . Serialize ( new { Success = true , Message = "查询成功" , data = WMSNOList } ) ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( json ) } ;
}
public string MakeWMS ( string CUSTOMERNAME , string STORAGENAME , string WMSDATE , List < Cargomb3 > CargobodyList )
{
//首先通过商品信息生成和保存wms和wms_in
//返回值是所有生成的WMS信息的GID, 用于费用入账的参数
/ /
var WMSNOList = "" ;
foreach ( var cargo in CargobodyList )
{
var SaleDetailList = ImportSalesDAL . GetDetailList ( " s.CARGO_GID='" + cargo . GID + "'" ) ;
//如无对应销售信息,货主为操作者的“本公司”
//如有对应销售信息,则首先判断销售重量是否大于等于实际入库重量。
//如剩余重量小于等于3000kg, 则全部按销售重量和销售客户, 按比例生成。
//如剩余重量大于3000kg, 则剩余部分按货主为操作者的“本公司”处理。
/ *
if ( SaleDetailList . Count ( ) = = 0 )
{ * / // 20160910 改为全部按照北京二商入库。
//CUSTOMERNAME = Session["COMPANYNAME"].ToString();
//如无对应销售信息,货主为操作者的“本公司”
var REMARK = "" ;
if ( SaleDetailList . Count ( ) > 0 ) {
REMARK = "销售对象:" ;
foreach ( var _SD in SaleDetailList )
{
if ( REMARK = = "销售对象:" )
REMARK = REMARK + _SD . CUSTOMERNAME ;
else
REMARK = REMARK + "," + _SD . CUSTOMERNAME ;
}
}
var WMSGID = DoMakeWMS ( Session [ "COMPANYNAME" ] . ToString ( ) , STORAGENAME , WMSDATE , cargo , REMARK ) ;
if ( WMSNOList = = "" )
{
WMSNOList = "" + WMSGID + "" ;
}
else
WMSNOList = WMSNOList + "," + WMSGID + "" ;
/ *
}
else
{
decimal salesweight = 0 ;
decimal cargoweight_ACT = decimal . Parse ( cargo . WEIGHT_ACT ) ;
decimal cargoweight = decimal . Parse ( cargo . WEIGHT_ACT ) ;
decimal cargoboxcount = decimal . Parse ( cargo . BOXCOUNT_ACT ) ;
foreach ( var _sd in SaleDetailList )
{
salesweight = salesweight + decimal . Parse ( _sd . WEIGHT ) ;
}
//如有对应销售信息,则首先判断销售重量是否大于等于实际入库重量。
if ( cargoweight_ACT - salesweight > 3000 )
{
//如剩余重量大于3000kg, 则剩余部分按货主为操作者的“本公司”处理。
cargo . WEIGHT_ACT = ( cargoweight_ACT - salesweight ) . ToString ( ) ;
cargo . BOXCOUNT_ACT = ( cargoboxcount * ( cargoweight_ACT - salesweight ) / cargoweight_ACT ) . ToString ( ) ;
var WMSGID = DoMakeWMS ( Session [ "COMPANYNAME" ] . ToString ( ) , STORAGENAME , WMSDATE , cargo ) ;
if ( WMSNOList = = "" )
{
WMSNOList = "" + WMSGID + "" ;
}
else
WMSNOList = WMSNOList + "," + WMSGID + "" ;
cargoweight = salesweight ;
foreach ( var _sd in SaleDetailList )
{
cargo . WEIGHT_ACT = _sd . WEIGHT ;
cargo . BOXCOUNT_ACT = ( cargoboxcount * decimal . Parse ( _sd . WEIGHT ) / cargoweight_ACT ) . ToString ( ) ;
WMSGID = DoMakeWMS ( _sd . CUSTOMERNAME , STORAGENAME , WMSDATE , cargo ) ;
if ( WMSNOList = = "" )
{
WMSNOList = "" + WMSGID + "" ;
}
else
WMSNOList = WMSNOList + "," + WMSGID + "" ;
}
}
else
{
//如剩余重量小于等于1kg, 则全部按销售重量和销售客户, 按比例生成。
foreach ( var _sd in SaleDetailList )
{
var wmsinweight = cargoweight_ACT * decimal . Parse ( _sd . WEIGHT ) / salesweight ;
cargo . WEIGHT_ACT = wmsinweight . ToString ( ) ;
cargo . BOXCOUNT_ACT = ( cargoboxcount * decimal . Parse ( _sd . WEIGHT ) / salesweight ) . ToString ( ) ;
var WMSGID = DoMakeWMS ( _sd . CUSTOMERNAME , STORAGENAME , WMSDATE , cargo ) ;
if ( WMSNOList = = "" )
{
WMSNOList = "" + WMSGID + "" ;
}
else
WMSNOList = WMSNOList + "," + WMSGID + "" ;
}
}
}
* /
}
return WMSNOList ;
}
public string MakeWMS2 ( string STORAGENAME , string WMSDATE , List < Cargomb3 > CargobodyList )
{
//首先通过商品信息生成和保存wms和wms_in
//返回值是所有生成的WMS信息的GID, 用于费用入账的参数
/ /
var WMSNOList = "" ;
foreach ( var cargo in CargobodyList )
{
var SaleDetailList = ImportSalesDAL . GetDetailList ( " s.CARGO_GID='" + cargo . GID + "'" ) ;
//如无对应销售信息,货主为操作者的“本公司”
//如有对应销售信息,则首先判断销售重量是否大于等于实际入库重量。
//如剩余重量小于等于3000kg, 则全部按销售重量和销售客户, 按比例生成。
//如剩余重量大于3000kg, 则剩余部分按货主为操作者的“本公司”处理。
/ *
if ( SaleDetailList . Count ( ) = = 0 )
{ * /
// 20160910 改为全部按照北京二商入库。
//CUSTOMERNAME = Session["COMPANYNAME"].ToString();
//如无对应销售信息,货主为操作者的“本公司”
var REMARK = "" ;
/ *
if ( SaleDetailList . Count ( ) > 0 )
{
REMARK = "销售对象:" ;
foreach ( var _SD in SaleDetailList )
{
if ( REMARK = = "销售对象:" )
REMARK = REMARK + cargo . buyer ;
else
REMARK = REMARK + "," + cargo . buyer ;
}
} * /
var WMSGID = DoMakeWMS ( cargo . buyer , STORAGENAME , WMSDATE , cargo , REMARK ) ;
if ( WMSNOList = = "" )
{
WMSNOList = "" + WMSGID + "" ;
}
else
WMSNOList = WMSNOList + "," + WMSGID + "" ;
/ *
}
else
{
decimal salesweight = 0 ;
decimal cargoweight_ACT = decimal . Parse ( cargo . WEIGHT_ACT ) ;
decimal cargoweight = decimal . Parse ( cargo . WEIGHT_ACT ) ;
decimal cargoboxcount = decimal . Parse ( cargo . BOXCOUNT_ACT ) ;
foreach ( var _sd in SaleDetailList )
{
salesweight = salesweight + decimal . Parse ( _sd . WEIGHT ) ;
}
//如有对应销售信息,则首先判断销售重量是否大于等于实际入库重量。
if ( cargoweight_ACT - salesweight > 3000 )
{
//如剩余重量大于3000kg, 则剩余部分按货主为操作者的“本公司”处理。
cargo . WEIGHT_ACT = ( cargoweight_ACT - salesweight ) . ToString ( ) ;
cargo . BOXCOUNT_ACT = ( cargoboxcount * ( cargoweight_ACT - salesweight ) / cargoweight_ACT ) . ToString ( ) ;
var WMSGID = DoMakeWMS ( Session [ "COMPANYNAME" ] . ToString ( ) , STORAGENAME , WMSDATE , cargo ) ;
if ( WMSNOList = = "" )
{
WMSNOList = "" + WMSGID + "" ;
}
else
WMSNOList = WMSNOList + "," + WMSGID + "" ;
cargoweight = salesweight ;
foreach ( var _sd in SaleDetailList )
{
cargo . WEIGHT_ACT = _sd . WEIGHT ;
cargo . BOXCOUNT_ACT = ( cargoboxcount * decimal . Parse ( _sd . WEIGHT ) / cargoweight_ACT ) . ToString ( ) ;
WMSGID = DoMakeWMS ( _sd . CUSTOMERNAME , STORAGENAME , WMSDATE , cargo ) ;
if ( WMSNOList = = "" )
{
WMSNOList = "" + WMSGID + "" ;
}
else
WMSNOList = WMSNOList + "," + WMSGID + "" ;
}
}
else
{
//如剩余重量小于等于1kg, 则全部按销售重量和销售客户, 按比例生成。
foreach ( var _sd in SaleDetailList )
{
var wmsinweight = cargoweight_ACT * decimal . Parse ( _sd . WEIGHT ) / salesweight ;
cargo . WEIGHT_ACT = wmsinweight . ToString ( ) ;
cargo . BOXCOUNT_ACT = ( cargoboxcount * decimal . Parse ( _sd . WEIGHT ) / salesweight ) . ToString ( ) ;
var WMSGID = DoMakeWMS ( _sd . CUSTOMERNAME , STORAGENAME , WMSDATE , cargo ) ;
if ( WMSNOList = = "" )
{
WMSNOList = "" + WMSGID + "" ;
}
else
WMSNOList = WMSNOList + "," + WMSGID + "" ;
}
}
}
* /
}
return WMSNOList ;
}
private string DoMakeWMS ( string CUSTOMERNAME , string STORAGENAME , string WMSDATE , Cargomb3 cargo , string REMARK )
{
var CargoInfo = ImportTradeDAL . GetData_ALL ( " c.gid = '" + cargo . GID + "' " , CookieConfig . GetCookie_UserCode ( Request ) , CookieConfig . GetCookie_UserName ( Request ) , CookieConfig . GetCookie_CompanyId ( Request ) ) ;
var head = new WMSmb_ImportTrade ( ) ;
head . DbOperationType = DbOperationType . DbotIns ;
head . ModelUIStatus = "I" ;
head . GID = "Wms" + Guid . NewGuid ( ) . ToString ( ) . Replace ( "-" , "" ) ; ;
head . WMSOP = CookieConfig . GetCookie_UserName ( Request ) ;
head . CUSTOMERNAME = CUSTOMERNAME ;
head . STORAGENAME = STORAGENAME ;
head . WMSDATE = WMSDATE ;
var USERID = CookieConfig . GetCookie_UserId ( Request ) ;
var ORGCODE = CookieConfig . GetCookie_OrgCode ( Request ) ;
var WMSC = new WMSController ( ) ;
head . WMSNO = WMSC . getCodeRule ( USERID , ORGCODE , "入库单号" , "WMSNO" , "WMS" , head . WMSDATE ) ; //调用编码规则
head . WMSDATE = WMSDATE ;
head . STARTBILLINGDATE = WMSDATE ;
head . GOODSPACK = cargo . BOXCOUNT_ACT ;
head . GOODSPACKACTUAL = cargo . BOXCOUNT_ACT ;
head . GOODSPACKSTOCK = cargo . BOXCOUNT_ACT ;
head . GOODSRKSL = ( float . Parse ( cargo . WEIGHT_ACT ) / 1000 ) . ToString ( ) ;
head . GOODSRKSLACTUAL = ( float . Parse ( cargo . WEIGHT_ACT ) / 1000 ) . ToString ( ) ;
head . GOODSSTOCK = ( float . Parse ( cargo . WEIGHT_ACT ) / 1000 ) . ToString ( ) ;
head . ASSOCIATEDNO = cargo . ContractNo ;
head . ARFEE = "0" ;
head . APFEE = "0" ;
head . ISCHANGE = "0" ;
head . BANKVALUE = "0" ;
head . MARKETVALUE = "0" ;
head . CARGO_GID = cargo . GID ;
head . GOODSNAME = cargo . name ;
head . CHARGEUNIT = "吨" ;
head . BLNO = CargoInfo . BillNo ;
head . CONTRACTNO = CargoInfo . HTH ;
head . GOODSMODEL = CargoInfo . factoryno ; //牌号
head . CORPID = Session [ "COMPANYID" ] . ToString ( ) ;
head . CREATEUSER = Session [ "USERID" ] . ToString ( ) ;
head . MODIFIEDUSER = Session [ "USERID" ] . ToString ( ) ;
head . MODIFIEDTIME = DateTime . Now . ToString ( ) ;
head . CUSTOMNO = "" ;
head . ARCLIENT = CUSTOMERNAME ;
head . REMARK = REMARK ;
head . GOODSSTANDARD = cargo . SPECIFICATIONS ;
var WMSIN = new WMSINmb ( ) ;
WMSIN . GID = Guid . NewGuid ( ) . ToString ( ) ;
WMSIN . BSNO = head . WMSNO ;
WMSIN . GOODSPACK = cargo . BOXCOUNT_ACT ;
WMSIN . GOODSPACKACTUAL = cargo . BOXCOUNT_ACT ;
WMSIN . GOODSPACKSTOCK = cargo . BOXCOUNT_ACT ;
WMSIN . GOODSRKSL = ( float . Parse ( cargo . WEIGHT_ACT ) / 1000 ) . ToString ( ) ;
WMSIN . GOODSRKSLACTUAL = ( float . Parse ( cargo . WEIGHT_ACT ) / 1000 ) . ToString ( ) ;
WMSIN . GOODSSTOCK = ( float . Parse ( cargo . WEIGHT_ACT ) / 1000 ) . ToString ( ) ;
WMSIN . CNTRNO = CargoInfo . ContainerNo ;
WMSIN . SEALNO = CargoInfo . SealNo ;
WMSIN . GOODSKGS = "0" ;
WMSIN . ARFEE = "0" ;
WMSIN . APFEE = "0" ;
WMSIN . GOODSTHICKNESS = "0" ;
WMSIN . GOODSWIDTH = "0" ;
WMSIN . GOODSLENGTH = "0" ;
WMSIN . GOODSSLICE = cargo . BOXCOUNT_ACT ;
WMSIN . MARKETVALUE = "0" ;
WMSIN . BANKVALUE = "0" ;
WMSIN . CHARGEUNIT = "吨" ;
WMSIN . GOODSCODE = CargoInfo . productiondate_min + "-" + CargoInfo . productiondate_max ;
var wmsinlist = new List < WMSINmb > ( ) ;
wmsinlist . Add ( WMSIN ) ;
var wmsinlistdel = new List < WMSINmb > ( ) ;
var modb = new ModelObjectRepository ( ) ;
DBResult result = modb . Save ( head ,
ModelObjectConvert < WMSINmb > . ToModelObjectList ( wmsinlist ) ,
ModelObjectConvert < WMSINmb > . ToModelObjectList ( wmsinlistdel )
) ;
if ( result . Success )
{
//将cargo表的islocked设为1
var _i = ImportTradeDAL . SetCargoLock ( cargo . GID , WMSDATE ) ;
var _j = ImportTradeDAL . SetWMSRATE ( STORAGENAME , USERID , head . GID , CUSTOMERNAME , WMSDATE ) ;
return head . GID ;
}
else
{
return "" ;
}
}
/ *
private string DoChangeSales ( Cargomb2 cargo )
{
//根据实际入库件数 修改相应销售单的销售件数
} * /
# endregion
public ContentResult SaveWMSCargo ( string Cargobody )
{
var CargobodyList = JsonConvert . Deserialize < List < Cargomb3 > > ( Cargobody ) ;
var WMSImportMain = JsonConvert . Deserialize < List < WMSmb_ImportTradeMain > > ( Cargobody ) ;
var modb = new ModelObjectRepository ( ) ;
DBResult result = modb . Save (
ModelObjectConvert < Cargomb3 > . ToModelObjectList ( CargobodyList )
) ;
result = modb . Save (
ModelObjectConvert < WMSmb_ImportTradeMain > . ToModelObjectList ( WMSImportMain )
) ;
//刷新父窗口上的父节点
var jsonRespose = new JsonResponse
{
Success = result . Success ,
Message = result . Message ,
//Data = XXHDAL.GetData("M.ContractNo='" + head.ContractNo + "'")
} ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
}
#region 删除库存
public ContentResult DeleteWMS ( string CARGO_GID )
{
var _i = ImportTradeDAL . SetCargoUnLock ( CARGO_GID ) ;
var GIDList = WMSDAL . GetDataList ( " CARGO_GID='" + CARGO_GID + "' " , "" ) ;
if ( GIDList . Count > 0 )
{
//var head = new WMSmb();
var USERID = CookieConfig . GetCookie_UserId ( Request ) ;
//var _GIDList = "";
var result = new DBResult ( ) ;
foreach ( var _w in GIDList )
{
var WMSC = new WMSController ( ) ;
var _k = WMSC . LockWMS ( _w . GID , USERID , "0" ) ;
var modb = new ModelObjectDB ( ) ;
result = modb . Delete ( _w , "delete from wms_in where ASSOCIATEDNO ='" + _w . GID + "' delete from WMS_RATE where BSNO ='" + _w . GID + "'" ) ;
}
var jsonRespose = new JsonResponse { Success = result . Success , Message = result . Message } ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
}
else
{
var jsonRespose = new JsonResponse { Success = true , Message = "无所属入库信息" } ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
}
}
# endregion
#region 查询库存,看是否有取用记录
public ContentResult GetCargoOut ( string CARGO_GID )
{
var _count = ImportTradeDAL . GetCargoOut ( CARGO_GID ) ;
var json = JsonConvert . Serialize (
new { Success = true , Message = "查询成功" , data = _count } ) ;
return new ContentResult ( ) { Content = json } ;
}
public ContentResult GetLocked ( string CARGO_GID )
{
var _count = ImportTradeDAL . GetLocked ( CARGO_GID ) ;
var json = JsonConvert . Serialize (
new { Success = true , Message = "查询成功" , data = _count } ) ;
return new ContentResult ( ) { Content = json } ;
}
# endregion
#region 参照部分
// Get:/Import/XXH/GetApp
public ContentResult GetApp ( string condition )
{
var _condition = " ap.cargoinfo_id in(select cargoinfo_id from import_cargo where contractno='" + condition + "') " ;
_condition = _condition + " and ap.cargociq_id in(select cargociq_id from import_cargo where contractno='" + condition + "') " ;
_condition = _condition + " and ap.countryid in(select countryid from import_main where contractno='" + condition + "')" ;
_condition = _condition + " and ap.sljg in(select port sljg from import_main where contractno='" + condition + "')" ;
// _condition = _condition + " and ap.company in(select company from import_main where contractno='" + condition + "')";
_condition = _condition + " and ap.isdeleted=0 and (validdate>(select creattime from import_main where contractno='" + condition + "') or validdate='')" ;
List < Appstatemb > list = XXHDAL . GetApp ( _condition ) ;
var json = JsonConvert . Serialize ( new { Success = true , Message = "查询成功" , totalCount = list . Count , data = list . ToList ( ) } ) ;
return new ContentResult ( ) { Content = json } ;
}
public ContentResult GetCountry ( string condition )
{
var list = XXHDAL . GetCountry ( ) ;
var json = JsonConvert . Serialize ( new { Success = true , Message = "查询成功" , totalCount = list . Count , data = list . ToList ( ) } ) ;
return new ContentResult ( ) { Content = json } ;
}
public string KCEnterDate ( string contractno , string OutDate )
{
var KCEnterDate = "" ;
//KCEnterDate = XXHDAL.GetKCEnterDate(contractno);
return KCEnterDate ;
}
# endregion
#region AMS
public ContentResult GetAmsData ( string condition )
{
MsOpSeaeAms head = null ;
head = MsOpSeaeEdiPortDAL . GetAmsData ( condition ) ;
var json = JsonConvert . Serialize (
new { Success = true , Message = "查询成功" , data = head } ) ;
return new ContentResult ( ) { Content = json } ;
}
public ContentResult SaveAms ( string data , string bsno )
{
var headData = JsonConvert . Deserialize < MsOpSeaeAms > ( data ) ;
headData . BSNO = bsno ;
if ( headData . AMSNO = = "*" )
{
headData . DbOperationType = DbOperationType . DbotIns ;
headData . AMSNO = Guid . NewGuid ( ) . ToString ( ) ;
}
else
{
headData . DbOperationType = DbOperationType . DbotUpd ;
headData . ModelUIStatus = "E" ;
}
var BSNO = headData . AMSNO ;
var modb = new ModelObjectDB ( ) ;
DBResult result = modb . Save ( headData ) ;
var jsonRespose = new JsonResponse
{
Success = result . Success ,
Message = result . Message ,
Data = MsOpSeaeEdiPortDAL . GetAmsData ( "AMSNO='" + BSNO + "'" )
} ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
}
# endregion
[HttpPost]
public ContentResult UploadFile ( )
{
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 [ "LoadImage" ] ;
var fileGID = Request . Form [ "fileGid" ] ;
var HTH = Request . Form [ "HTH" ] ;
var RECEIPTTYPE = Request . Form [ "RECEIPTTYPE" ] ;
var fileName_EX = Request . Form [ "fileName_EX" ] + "_" + System . Guid . NewGuid ( ) . ToString ( ) ;
if ( file = = null )
{
jsonRespose . Success = false ;
jsonRespose . Message = "上传文件发生未知错误,请重新上传" ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
}
String fileExt = Path . GetExtension ( file . FileName ) . ToLower ( ) ;
if ( fileExt = = ".asp" | | fileExt = = ".aspx" )
{
jsonRespose . Success = false ;
jsonRespose . Message = "不允许上传ASP或ASPX文件" ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
}
var path = "" ;
var FTPPATH = "" ;
var COMPANYID = Convert . ToString ( Session [ "COMPANYID" ] ) ;
var _ftpurlList = BasicDataRefDAL . GeneralSelect ( "select ftpurl GVALUE,gid GID from company where GID='" + COMPANYID + "'" ) ;
var _ftpurl = _ftpurlList [ 0 ] . GVALUE ;
if ( RECEIPTTYPE = = "单据" )
{
path = "D:/Doc/BJES/单据/" + HTH ;
FTPPATH = "ftp://bjes:@" + _ftpurl + "/单据/" + HTH ; //101.201.50.235//
}
else
{
path = "D:/Doc/BJES/" + RECEIPTTYPE ;
FTPPATH = "ftp://bjes:@" + _ftpurl + "/" + RECEIPTTYPE ; //120.27.53.37
}
if ( ! Directory . Exists ( path ) )
{
Directory . CreateDirectory ( path ) ;
}
var size = file . ContentLength ;
var name = HTH + fileName_EX ;
string ext = Path . GetExtension ( file . FileName ) . ToLower ( ) ;
if ( ext = = ".asp" | | ext = = ".aspx" | | ext = = ".html" )
{
jsonRespose . Success = false ;
jsonRespose . Message = "不允许上传ASP或ASPX文件" ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
}
var usercode = CookieConfig . GetCookie_UserCode ( Request ) ;
var realname = Path . GetFileName ( file . FileName ) ;
var _name = realname . Substring ( realname . IndexOf ( "." ) , realname . Length - realname . IndexOf ( "." ) ) ;
//string filename = path + "\\" + name + _name;
string filename = path + "/" + name + _name ;
FTPPATH = FTPPATH + "/" + name + _name ;
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 = "上传文件发生未知错误,请重新上传" ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
}
try
{
var message = string . Empty ;
var isSucess = ImportTradeDAL . UpdateFileData ( Request , filename , name , FTPPATH , fileGID , out message ) ;
if ( ! isSucess )
{
jsonRespose . Success = false ;
jsonRespose . Message = message ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
}
var json = JsonConvert . Serialize ( new { success = true , Message = "上传成功!" , data = filename } ) ;
return new ContentResult ( ) { Content = json } ;
}
catch ( Exception e )
{
jsonRespose . Success = false ;
jsonRespose . Message = "上传文件出错 " + e . Message ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
}
}
public ContentResult DeleteUploadFile ( string data )
{
int iResult = 0 ;
var bodyList = data ;
var result = new DBResult ( ) ;
if ( bodyList ! = "" | | bodyList ! = null )
{
iResult = ImportTradeDAL . DeleteUploadFile ( bodyList ) ;
}
if ( iResult = = 1 )
{
result . Success = true ;
result . Message = "删除成功!" ;
}
else if ( iResult = = 0 )
{
result . Success = false ;
result . Message = "出现错误,未删除!" ;
}
else if ( iResult = = - 1 )
{
result . Success = false ;
result . Message = "有异常,删除失败!" ;
}
else if ( iResult = = - 2 )
{
result . Success = false ;
result . Message = "删除异常,事务已回滚成功!" ;
}
var jsonRespose = new JsonResponse
{
Success = result . Success ,
Message = result . Message ,
// Data = MsChFeeDAL.GetDataList(headData.BillNo, Convert.ToString(Session["USERID"]), CookieConfig.GetCookie_UserCode(Request), CookieConfig.GetCookie_OrgCode(Request))
} ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
}
#region 生成补税/退税
public ContentResult MakeTax ( string ContractNo , string tax , string tax_zz )
{
var head = ImportTradeDAL . GetData_ALL ( "M.Contractno='" + ContractNo + "'" , CookieConfig . GetCookie_UserCode ( Request ) , CookieConfig . GetCookie_UserName ( Request ) , CookieConfig . GetCookie_CompanyId ( Request ) ) ;
Database db = DatabaseFactory . CreateDatabase ( ) ;
var 关 税 补 税 = 0 M ;
var 增 值 税 补 税 = 0 M ;
var 当 前 计 算 关 税 = 0 M ;
var 当 前 计 算 增 值 税 = 0 M ;
var 关 税 备 注 = "" ;
var 增 值 税 备 注 = "" ;
var chfeelist = new List < MsChFee2 > ( ) ;
var _ 关 税 = db . ExecuteScalar ( CommandType . Text , "select sum(amount) from ch_fee where BSNO='" + ContractNo + "' and feetype=2 and (feename='关税' or (feename='补税' and remark like '%关税%') ) " ) ;
if ( string . IsNullOrEmpty ( _ 关 税 . ToString ( ) ) ) {
_ 关 税 = "0" ;
}
var 关 税 = Convert . ToDecimal ( _ 关 税 ) ;
var 原 有 退 关 税 = db . ExecuteScalar ( CommandType . Text , "select sum(amount) from ch_fee where BSNO='" + ContractNo + "' and feetype=1 and feename='退税' and remark like '%关税%'" ) ;
var 原 有 补 关 税 = db . ExecuteScalar ( CommandType . Text , "select sum(amount) from ch_fee where BSNO='" + ContractNo + "' and feetype=1 and feename='补税' and remark like '%关税%'" ) ;
if ( string . IsNullOrEmpty ( 原 有 退 关 税 . ToString ( ) ) )
{
原 有 退 关 税 = "0" ;
}
关 税 = 关 税 - Convert . ToDecimal ( 原 有 退 关 税 ) ;
if ( string . IsNullOrEmpty ( 原 有 补 关 税 . ToString ( ) ) )
{
原 有 补 关 税 = "0" ;
}
关 税 = 关 税 + Convert . ToDecimal ( 原 有 补 关 税 ) ;
var _ 增 值 税 = db . ExecuteScalar ( CommandType . Text , "select sum(amount) from ch_fee where BSNO='" + ContractNo + "' and feetype=2 and (feename='增值税' or (feename='补税' and remark like '%增值税%') ) " ) ;
if ( string . IsNullOrEmpty ( _ 增 值 税 . ToString ( ) ) )
{
_ 增 值 税 = "0" ;
}
var 增 值 税 = Convert . ToDecimal ( _ 增 值 税 ) ;
var 原 有 退 增 值 税 = db . ExecuteScalar ( CommandType . Text , "select sum(amount) from ch_fee where BSNO='" + ContractNo + "' and feetype=1 and feename='退税' and remark like '%增值税%'" ) ;
var 原 有 补 增 值 税 = db . ExecuteScalar ( CommandType . Text , "select sum(amount) from ch_fee where BSNO='" + ContractNo + "' and feetype=1 and feename='补税' and remark like '%增值税%'" ) ;
if ( string . IsNullOrEmpty ( 原 有 退 增 值 税 . ToString ( ) ) )
{
原 有 退 增 值 税 = "0" ;
}
增 值 税 = 增 值 税 - Convert . ToDecimal ( 原 有 退 增 值 税 ) ;
if ( string . IsNullOrEmpty ( 原 有 补 增 值 税 . ToString ( ) ) )
{
原 有 补 增 值 税 = "0" ;
}
增 值 税 = 增 值 税 + Convert . ToDecimal ( 原 有 补 增 值 税 ) ;
if ( Convert . ToDecimal ( tax_zz ) = = 增 值 税 )
{
//如果与当前应付税金相同,不做处理
} else
if ( Convert . ToDecimal ( tax_zz ) > 增 值 税 )
{
/ * 计 算 该 业 务 的 所 有 商 品 的 应 付 税 金 ,
* 如 果 与 当 前 应 付 税 金 相 同 , 不 做 处 理
不 相 同 : 看 有 没 有 限 价 大 于 采 购 单 价 的 , 如 果 有 , 计 算 出 该 种 商 品 的 补 税 , 写 一 条 费 用 ( 备 注 写 < 货 名 > 限 价 )
如 果 所 有 补 税 加 起 来 加 上 当 前 应 付 税 金 = 该 业 务 的 所 有 商 品 的 应 付 税 金 , 结 束 。
如 果 还 不 对 剩 余 部 分 写 入 一 条 费 用 ( 备 注 写 “ 汇 率 变 动 ” ) * /
/ *
var _chfee = getChfee ( "关税" , head . Agent , 2 , 关 税 补 税 ) ;
chfeelist . Add ( _chfee ) ;
* * /
var CargoList = ImportTradeDAL . GetCargoList2 ( " c.ContractNo='" + ContractNo + "' " ) ;
foreach ( var _C in CargoList ) {
var _old_amount = 0 M ;
var old_tax = 0 M ;
var old_tax_zz = 0 M ;
if ( Convert . ToDecimal ( _C . price_limit ) > Convert . ToDecimal ( _C . price ) )
{
_old_amount = Convert . ToDecimal ( _C . price_limit ) * Convert . ToDecimal ( _C . weight ) * Convert . ToDecimal ( _C . Exchangerate_Customs ) * Convert . ToDecimal ( _C . baolv ) ;
old_tax = _old_amount * Convert . ToDecimal ( _C . tax ) ;
old_tax_zz = _old_amount * ( 1 + Convert . ToDecimal ( _C . tax ) ) * Convert . ToDecimal ( _C . tax_zz ) ;
当 前 计 算 关 税 = 当 前 计 算 关 税 + old_tax ;
当 前 计 算 增 值 税 = 当 前 计 算 增 值 税 + old_tax_zz ;
}
else {
_old_amount = Convert . ToDecimal ( _C . price ) * Convert . ToDecimal ( _C . weight ) * Convert . ToDecimal ( _C . Exchangerate_Customs ) * Convert . ToDecimal ( _C . baolv ) ;
old_tax = _old_amount * Convert . ToDecimal ( _C . tax ) ;
old_tax_zz = _old_amount * ( 1 + Convert . ToDecimal ( _C . tax ) ) * Convert . ToDecimal ( _C . tax_zz ) ;
当 前 计 算 关 税 = 当 前 计 算 关 税 + old_tax ;
当 前 计 算 增 值 税 = 当 前 计 算 增 值 税 + old_tax_zz ;
}
var 该 商 品 当 前 补 税 = Convert . ToDecimal ( db . ExecuteScalar ( CommandType . Text , "select isnull((select sum(isnull(amount,0)) from ch_fee where BSNO='" + ContractNo + "' and feename='补税' and BXGID='" + _C . GID + "'),0)" ) ) ;
if ( Convert . ToDecimal ( _C . price_limit ) > Convert . ToDecimal ( _C . price ) & & 该 商 品 当 前 补 税 = = 0 ) {
//而且该商品没有生成过补税
_old_amount = Convert . ToDecimal ( _C . price ) * Convert . ToDecimal ( _C . weight ) * Convert . ToDecimal ( _C . Exchangerate_Customs ) * Convert . ToDecimal ( _C . baolv ) ;
old_tax = _old_amount * Convert . ToDecimal ( _C . tax ) ;
old_tax_zz = _old_amount * ( 1 + Convert . ToDecimal ( _C . tax ) ) * Convert . ToDecimal ( _C . tax_zz ) ;
var _new_amount = Convert . ToDecimal ( _C . price_limit ) * Convert . ToDecimal ( _C . weight ) * Convert . ToDecimal ( _C . Exchangerate_Customs ) * Convert . ToDecimal ( _C . baolv ) ;
var new_tax = _new_amount * Convert . ToDecimal ( _C . tax ) ;
var new_tax_zz = _new_amount * ( 1 + Convert . ToDecimal ( _C . tax ) ) * Convert . ToDecimal ( _C . tax_zz ) ;
var _ 补 关 税 = new_tax - old_tax ;
var _ 补 增 值 税 = new_tax_zz - old_tax_zz ;
var _chfee = getChfee ( "补税" , head . Agent , 2 , _ 补 关 税 , _C , "关税补税" ) ;
var _chfee2 = getChfee ( "补税" , head . Agent , 2 , _ 补 增 值 税 , _C , "增值税补税" ) ;
chfeelist . Add ( _chfee ) ;
chfeelist . Add ( _chfee2 ) ;
关 税 补 税 = 关 税 补 税 + _ 补 关 税 ;
增 值 税 补 税 = 增 值 税 补 税 + _ 补 增 值 税 ;
}
}
if ( 增 值 税 + 增 值 税 补 税 = = 当 前 计 算 增 值 税 )
{
//只有限价产生补税
}
else
{
var 汇 率 差 补 退 税 = 当 前 计 算 关 税 - ( 关 税 + 关 税 补 税 ) + 当 前 计 算 增 值 税 - ( 增 值 税 + 增 值 税 补 税 ) ;
if ( 汇 率 差 补 退 税 > 0 )
{
var _chfee = getChfee ( "补税" , head . Agent , 2 , 汇 率 差 补 退 税 , "汇率差补税" ) ;
chfeelist . Add ( _chfee ) ;
} else
{
var _chfee = getChfee ( "退税" , head . Agent , 1 , 0 - 汇 率 差 补 退 税 , "汇率差退税" ) ;
chfeelist . Add ( _chfee ) ;
}
}
} else
if ( Convert . ToDecimal ( tax ) < 关 税 )
{
var 退 税 = 关 税 - Convert . ToDecimal ( tax ) ;
var _chfee = getChfee ( "退税" , head . Agent , 1 , 退 税 , "" ) ;
chfeelist . Add ( _chfee ) ;
}
var modb = new ModelObjectRepository ( ) ;
DBResult result = modb . SaveComm ( "BsNo" , ContractNo ,
ModelObjectConvert < MsChFee2 > . ToModelObjectList ( chfeelist ) ,
null
) ;
//刷新父窗口上的父节点
var jsonRespose = new JsonResponse
{
Success = result . Success ,
Message = result . Message ,
//Data = XXHDAL.GetData("M.ContractNo='" + head.ContractNo + "'")
} ;
return new ContentResult ( ) { Content = JsonConvert . Serialize ( jsonRespose ) } ;
}
private MsChFee2 getChfee ( string FeeName , string CustomerName , decimal FeeType , decimal Amount , string remark )
{
var _chfee = new MsChFee2 ( ) ;
_chfee . GId = System . Guid . NewGuid ( ) . ToString ( ) ;
_chfee . BsNo = "" ;
_chfee . FeeStatus = 1 ;
_chfee . FeeType = FeeType ;
if ( FeeType = = 2 )
{
_chfee . FeeName = "补税" ;
}
else {
_chfee . FeeName = "退税" ;
}
_chfee . CustomerName = CustomerName ;
_chfee . UnitPrice = Amount ;
//_chfee.Tax=关税补税;
_chfee . Quantity = 1 ;
_chfee . Amount = Amount ;
//_chfee.NoTaxAmount
_chfee . Currency = "RMB" ;
_chfee . ExChangerate = 1 ;
_chfee . Remark = FeeName ;
_chfee . Commissionrate = 0 ;
_chfee . Settlement = 0 ;
_chfee . Invoice = 0 ;
_chfee . OrderAmount = 0 ;
_chfee . OrderInvoice = 0 ;
_chfee . EnteroPerator = Session [ "USERID" ] . ToString ( ) ;
_chfee . EnterDate = DateTime . Now ;
_chfee . IsDebit = "0" ;
_chfee . IsOpen = "0" ;
_chfee . IsAdvancedpay = "0" ;
_chfee . IsInvoice = "0" ;
_chfee . FeeFrt = "PP" ;
_chfee . IsCrmOrderFee = "0" ;
_chfee . AuditStatus = 0 ;
_chfee . MODIFIEDTIME = DateTime . Now . ToString ( ) ;
_chfee . MODIFIEDUSER = Session [ "USERID" ] . ToString ( ) ;
return _chfee ;
}
private MsChFee2 getChfee ( string FeeName , string CustomerName , decimal FeeType , decimal Amount , Cargomb2 _C , string remark )
{
var _chfee = new MsChFee2 ( ) ;
_chfee . GId = System . Guid . NewGuid ( ) . ToString ( ) ;
_chfee . BsNo = "" ;
_chfee . FeeStatus = 1 ;
_chfee . FeeType = FeeType ;
if ( FeeType = = 2 )
{
_chfee . FeeName = "补税" ;
}
else
{
_chfee . FeeName = "退税" ;
}
_chfee . CustomerName = CustomerName ;
_chfee . UnitPrice = Amount ;
//_chfee.Tax=关税补税;
_chfee . Quantity = 1 ;
_chfee . Amount = Amount ;
//_chfee.NoTaxAmount
_chfee . Currency = "RMB" ;
_chfee . ExChangerate = 1 ;
_chfee . Remark = _C . name + ' ' + FeeName + ' ' + remark ;
_chfee . Commissionrate = 0 ;
_chfee . Settlement = 0 ;
_chfee . Invoice = 0 ;
_chfee . OrderAmount = 0 ;
_chfee . OrderInvoice = 0 ;
_chfee . EnteroPerator = Session [ "USERID" ] . ToString ( ) ;
_chfee . EnterDate = DateTime . Now ;
_chfee . IsDebit = "0" ;
_chfee . IsOpen = "0" ;
_chfee . IsAdvancedpay = "0" ;
_chfee . IsInvoice = "0" ;
_chfee . FeeFrt = "PP" ;
_chfee . IsCrmOrderFee = "0" ;
_chfee . AuditStatus = 0 ;
_chfee . MODIFIEDTIME = DateTime . Now . ToString ( ) ;
_chfee . MODIFIEDUSER = Session [ "USERID" ] . ToString ( ) ;
_chfee . BXGID = _C . GID ;
return _chfee ;
}
# endregion
}
}