/// 
///INTERFACE CLASS FOR TABLE t_wmsGoods
///By wm with codesmith. 
///on 05/04/2017
/// 
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using DeiNiu.Utils;
namespace DeiNiu.wms.Data.Model
{
    [Serializable]
    public class WmsGoods : WmsGoods_base
    {
        
        public WmsGoods()
        {
        }
        public WmsGoods(int id): base(id)
        {
        }
         public WmsGoods(DataRow dr): base(dr)
        {
        }
         public WmsGoods(string goodsId)
         { 
             cmdParameters[0] = goodsId;
             getModel(110);
             initialExtFields();
         }
         public WmsGoods(string goodsId,string batch):this(goodsId) 
         {
             getStockInfo(goodsId,batch);
         }
         protected override void getImp()
         {
             model_imp = new WmsGoods_Imp();
         }
        /// 
        /// 更新cache
        /// 
        /// 
         public new int Update()
         {
             base.Update();           
             ObjectsFactory.putGoods(this);
             return 1;
         }
         #region fieldNames
         public enum exfields
         { goodsName, spec,unit,manufacturer,address,barcode, regeditCode, goodsTypeName,bigCount,type,pinYin ,station,repTypeName}
         #endregion
         private string _goodsName, _spec, _unit, _manufacturer, _address, _barcode, _regeditCode, _goodsTypeName,   _type,_pinyin;
        // decimal _bigCount;
         public string goodsName
         {
             get { return _goodsName; }
             
         }
         public string spec
         {
             get { return _spec; }
         }
         public string unit
         {
             get { return _unit; }
         }
         public string manufacturer
         {
             get { return _manufacturer; }
         }
         public string address
         {
             get { return _address; }
         }
         public string barcode
         {
             get { return _barcode; }
         }
         public string regeditCode
         {
             get { return _regeditCode; }
         }
         public string goodsTypeName
         {
             get { return _goodsTypeName; }
         }
         
         public string type
         {
             get { return _type; }
         }
         public string pinyin
         {
             get { return _pinyin; }
         }
         public void initialExtFields()
         {
             cmdParameters[0] = _goodsId;
             DataTable dt = CustQuery(120).Tables[0];
             foreach (DataRow dr in dt.Rows){
               if (!(dr[exfields.address.ToString()] is DBNull)) 
                 {
                     _address = dr[exfields.address.ToString()].ToString() ;
                 }
               if (!(dr[exfields.barcode.ToString()] is DBNull))
               {
                   _barcode = dr[exfields.barcode.ToString()].ToString();
               }
               if (!(dr[exfields.bigCount.ToString()] is DBNull))
               {
                   _bigCount = Convert.ToDecimal(dr[exfields.bigCount.ToString()].ToString());
               }
               if (!(dr[exfields.goodsName.ToString()] is DBNull))
               {
                   _goodsName = dr[exfields.goodsName.ToString()].ToString();
               } if (!(dr[exfields.goodsTypeName.ToString()] is DBNull))
               {
                   _goodsTypeName = dr[exfields.goodsTypeName.ToString()].ToString();
               }
               if (!(dr[exfields.manufacturer.ToString()] is DBNull))
               {
                   _manufacturer = dr[exfields.manufacturer.ToString()].ToString();
               }
               if (!(dr[exfields.regeditCode.ToString()] is DBNull))
               {
                   _regeditCode = dr[exfields.regeditCode.ToString()].ToString();
               }
               if (!(dr[exfields.spec.ToString()] is DBNull))
               {
                   _spec = dr[exfields.spec.ToString()].ToString();
               }
               if (!(dr[exfields.type.ToString()] is DBNull))
               {
                   _type = dr[exfields.type.ToString()].ToString();
               }
               if (!(dr[exfields.unit.ToString()] is DBNull))
               {
                   _unit = dr[exfields.unit.ToString()].ToString();
               }
               if (!(dr[exfields.pinYin.ToString()] is DBNull))
               {
                   _unit = dr[exfields.pinYin.ToString()].ToString();
               }
             }
         }
        //begin cust db operation, query, excute sql etc.
        public DataSet QueryByName(string name)
        {
            cmdParameters[0] = name;
            return  CustQuery(100);
        }
    
        /// 
        /// 同步erp 商品信息
        /// 
        /// 
        public int syncGoods()
        {
            
            return CustOper(300);  
        }
        /// 
        /// 根据货位类型返回货物的库容量
        /// 
        /// 
        /// 
        public decimal getMaxCount(int locVolType)
        {
            decimal goodsMaxcnt = 0m;
            switch (locVolType)
            {
                case (int)enumWhLocVol.零库:
                    goodsMaxcnt = this.bulkMax;
                    break;
                case (int)enumWhLocVol.小整:
                    goodsMaxcnt = this.batchMax1;
                    break;
                case (int)enumWhLocVol.大整:
                    goodsMaxcnt = this.batchMax2;
                    break;
                case (int)enumWhLocVol.超大整:
                    goodsMaxcnt = this.batchMax3;
                    break;
            }
            return goodsMaxcnt;
        }
        private decimal _stockSumCount, _stockBulkCount, _stockBatch1Count, _stockBatch2Count;
        private decimal _stockSumCountIn, _stockBulkCountIn, _stockBatch1CountIn, _stockBatch2CountIn;
        private decimal _stockSumCountOuting, _stockBulkCountOuting, _stockBatch1CountOuting, _stockBatch2CountOuting;
        public decimal stockSumCountIn
        {
            get { return _stockSumCountIn; }
        }
        public decimal stockBulkCountIn
        {
            get { return _stockBulkCountIn; }
        }
        public decimal stockBatch1CountIn
        {
            get { return _stockBatch1CountIn; }
        }
        public decimal stockBatch2CountIn
        {
            get { return _stockBatch2CountIn; }
        }
        public decimal stockSumCountOuting
        {
            get { return _stockSumCountOuting; }
        }
        public decimal stockBulkCountOuting
        {
            get { return _stockBulkCountOuting; }
        }
        public decimal stockBatch1CountOuting
        {
            get { return _stockBatch1CountOuting; }
        }
        public decimal stockBatch2CountOuting
        {
            get { return _stockBatch2CountOuting; }
        }
        public decimal  stockSumCount
        {
            get { return _stockSumCount; }
            
        }
        public decimal  stockBulkCount
        {
            get { return _stockBulkCount; }
        }
        public decimal  stockBatch1Count
        {
            get { return _stockBatch1Count; }
        }
        public decimal stockBatch2Count
        {
            get { return _stockBatch2Count; }
        }
        private List _stocks;
        public List stocks
        {
            get {
                if (_stocks == null)
                {  
                     _stocks = new List();
                    
                }
                 
                return _stocks; 
            }
             
        }
        /// 
        /// 取得商品的即时库存
        /// 
        /// 
        /// 
        public void getStockInfo(string goodsId,string batch, enumWhType whType = enumWhType.合格库)
        {
            cmdParameters[0] = goodsId;
            cmdParameters[1] = batch;
            cmdParameters[2] = (int)whType;
            DataTable dt = CustQuery(400).Tables[0];
            _stocks = new List(); 
            _stockSumCount = 0m; _stockBulkCount = 0m; _stockBatch1Count = 0m; _stockBatch2Count = 0m;
            _stockSumCountIn = 0m; _stockBulkCountIn = 0m; _stockBatch1CountIn = 0m; _stockBatch2CountIn = 0m;
            _stockSumCountOuting = 0m; _stockBulkCountOuting = 0m; _stockBatch1CountOuting = 0m; _stockBatch2CountOuting = 0m;
            foreach (DataRow dr in dt.Rows){
                WmsStock st = new WmsStock(dr);
               
                _stocks.Add(st);
                decimal cnt = st.count - st.countOut;
                _stockSumCount += cnt;
                _stockSumCountIn +=st.countIn;
                _stockSumCountOuting += st.countOuting; 
                switch (st.location.whVolType)
                {
                    case (int) enumWhLocVol.零库:
                        _stockBulkCount += cnt;
                        _stockBulkCountIn += st.countIn;
                        _stockBulkCountOuting += st.countOuting; 
                        break;
                    case (int)enumWhLocVol.小整:
                        _stockBatch1Count += cnt;
                        _stockBatch1CountIn += st.countIn;
                        _stockBatch1CountOuting += st.countOuting; 
                        break;
                    case (int)enumWhLocVol.大整:
                        _stockBatch2Count += cnt;
                        _stockBatch2CountIn += st.countIn;
                        _stockBatch2CountOuting += st.countOuting; 
                        break;
                } 
            } 
        }
    }
}