using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using WIDESEA_Core.Attributes;
using WIDESEA_Core.CodeConfigEnum;
using WIDESEA_Core.DB.Models;
namespace WIDESEA_Model.Models
{
    /// 
    /// 成品调拨出库单
    /// 
    [SugarTable(nameof(Dt_ErpProTransferOrder), "成品调拨出库单")]
    public class Dt_ErpProTransferOrder : BaseEntity
    {
        /// 
        /// 主键
        /// 
        [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "主键")]
        public int Id { get; set; }
        /// 
        /// 仓库主键
        /// 
        [SugarColumn(IsNullable = false, ColumnDescription = "仓库主键")]
        public int WarehouseId { get; set; }
        /// 
        /// 单据编号
        /// 
        [CodeRule(RuleCodeEnum.ProOutCOdeRule)]
        [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "单据编号")]
        public string OrderNo { get; set; }
        /// 
        /// 上游单据编号
        /// 
        [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "上游单据编号")]
        public string UpperOrderNo { get; set; }
        /// 
        /// 订单类型
        /// 
        [SugarColumn(IsNullable = false, ColumnDescription = "订单类型")]
        public int OrderType { get; set; }
        /// 
        /// 库存属性
        /// 1:成品
        /// 2:尾数
        /// 3:研发
        /// 
        [SugarColumn(IsNullable = true, ColumnDescription = "库存属性")]
        public int ProStockAttribute { get; set; }
        /// 
        /// 产品编码
        /// 
        [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "产品编码")]
        public string PCode { get; set; }
        /// 
        /// 产品版本
        /// 
        [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "产品版本")]
        public string PVer { get; set; }
        /// 
        /// 产品批次
        /// 
        [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "产品批次")]
        public string PLot { get; set; }
        /// 
        /// 产品周期
        /// 
        [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "产品周期")]
        public string DateCode { get; set; }
        /// 
        /// 合格PCS数
        /// 
        [SugarColumn(IsNullable = false, ColumnDescription = "合格PCS数")]
        public float QtyPcs { get; set; }
        /// 
        /// 包装Set数
        /// 
        [SugarColumn(IsNullable = false, ColumnDescription = "包装Set数")]
        public float QtySet { get; set; }
        /// 
        /// X板数
        /// 
        [SugarColumn(IsNullable = false, ColumnDescription = "X板数")]
        public float XQty { get; set; }
        /// 
        /// X板位
        /// 
        [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "X板位")]
        public string XSite { get; set; }
        /// 
        /// 单位
        /// 
        [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "单位")]
        public string Unit { get; set; }
        /// 
        /// 上游建单日期
        /// 
        [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "上游建单日期")]
        public string OrderDate { get; set; }
        /// 
        /// 销售订单号
        /// 
        [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "销售订单号")]
        public string ProSaleOrderNo { get; set; }
        /// 
        /// 客户
        /// 
        [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "客户")]
        public string Customer { get; set; }
        /// 
        /// 工厂
        /// 
        [SugarColumn(IsNullable = false, Length = 50, ColumnDescription = "工厂")]
        public string FactoryCode { get; set; }
        /// 
        /// 备注
        /// 
        [SugarColumn(IsNullable = true, Length = 200, ColumnDescription = "备注")]
        public string Remark { get; set; }
    }
}