using System;
using System.ComponentModel;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using CK.SCP.Models.Attributes;
using CK.SCP.Models.Base;

using CK.SCP.Models.ExchangeCenterTables;namespace CK.SCP.Models.DataCenterTables
{
    [Description("采购价格表")]
    public class TS_PURCHASE_PRICE : IUpdatableTable, ISoftDelete, IDomain
    {
        [Required(ErrorMessage = "代码不能为空")]
        [Index("IndexPurchasePrice", Order = 0, IsUnique = true, IsClustered = false)]
        [IsDataGridColum(true, 1)]
        [Description("价目表代码")]
        [StringLength(50)]
        public string PriceList { get; set; }
        [IsDataGridColum(true, 2)]
        [Description("说明")]
        [StringLength(50)]
        public string Desc { get; set; }
        [IsDataGridColum(true, 3)]
        [Description("产品类")]
        [StringLength(50)]
        public string ProductLine { get; set; }
        [IsDataGridColum(true, 4)]
        [Description("货币")]
        [StringLength(50)]
        public string Currency { get; set; }
        [IsDataGridColum(true, 5)]
        [Description("物料号")]
        [StringLength(50)]
        public string PartCode { get; set; }
        [IsDataGridColum(true, 6)]
        [Description("计量单位")]
        [StringLength(50)]
        public string Um { get; set; }
        [IsDataGridColum(true, 7)]
        [Description("开始")]
        public DateTime Start { get; set; }
        [IsDataGridColum(true, 8)]
        [Description("到期日期")]
        public DateTime ExpireDate { get; set; }
        [IsDataGridColum(true, 9)]
        [Description("金额类型")]
        [StringLength(50)]
        public string AmountType { get; set; }
        [IsDataGridColum(true, 10)]
        [Description("金额")]
        public decimal Amount { get; set; }


        [Key]
        public Guid GUID { get; set; } = Guid.NewGuid();

        [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
        public int UID { get; set; }
        [IsDataGridColum(true, 11)]
        [Description("创建人")]
        [StringLength(50)]
        public string CreateUser { get; set; }
        [IsDataGridColum(true, 12)]
        [Description("创建时间")]
        public DateTime CreateTime { get; set; }

        [IsDataGridColum(true, 13)]
        [Description("备注")]
        public string Remark { get; set; }

        [Description("修改人")]
        [StringLength(50)]
        public string UpdateUser { get; set; }

        [Description("修改时间")]
        public DateTime? UpdateTime { get; set; }

        [Description("已删除")]
        public bool IsDeleted { get; set; }
        [Description("域")]
        [StringLength(50)]
        public string Domain { get; set; }
    }
}