using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using Microsoft.EntityFrameworkCore;
using System.Runtime.Serialization;

#nullable disable

namespace AMESCoreStudio.WebApi.Models.AMES
{
    /// <summary>
    /// 工單製程對應SOP資料檔
    /// </summary>
    [Table("WIP_SOP", Schema = "JHAMES")]
    [DataContract]
    public partial class WipSop
    {
        /// <summary>
        /// 工單SOP_ID
        /// </summary>
        [Key]
        [Column("WIP_SOP_ID")]
        [DataMember]
        public int WipSOPID { get; set; }

        /// <summary>
        /// 工單號碼
        /// </summary>
        [Column("WIP_NO")]
        [DataMember]
        [StringLength(30)]
        public string WipNo { get; set; }

        /// <summary>
        /// 料號
        /// </summary>
        [Column("ITEM_NO")]
        [DataMember]
        [StringLength(20)]
        public string ItemNo { get; set; }

        /// <summary>
        /// SOP檔案名稱
        /// </summary>
        [Column("SOP_NAME")]
        [DataMember]
        [StringLength(200)]
        public string SOPName { get; set; }

        /// <summary>
        /// SOP路徑
        /// </summary>
        [Column("SOP_PATH")]
        [DataMember]
        [StringLength(100)]
        public string SOPPath { get; set; }

        /// <summary>
        /// SOP類型
        /// </summary>
        [Column("SOP_TYPE")]
        [DataMember]
        [StringLength(10)]
        public string SOPType { get; set; }

        /// <summary>
        /// 生產單位ID
        /// </summary>
        [Column("UNIT_NO")]
        [DataMember]
        [StringLength(10)]
        public string UnitNo { get; set; }

        /// <summary>
        /// SOP第一次版本
        /// </summary>
        [Column("SOP_VER")]
        [DataMember]
        public string SOPVer { get; set; }

        /// <summary>
        /// 建立UserID
        /// </summary>
        [Column("CREATE_USERID")]
        [Required]
        [DataMember]
        public int CreateUserID { get; set; } = 0;

        /// <summary>
        /// 建立日期
        /// </summary>
        [Required]
        [Column("CREATE_DATE")]
        [DataMember]
        public DateTime CreateDate { get; set; } = DateTime.Now;

        /// <summary>
        /// 更新UserID
        /// </summary>
        [Column("UPDATE_USERID")]
        [DataMember]
        public int UpdateUserID { get; set; } = 0;

        /// <summary>
        /// 更新日期
        /// </summary>
        [Column("UPDATE_DATE")]
        [DataMember]
        public DateTime? UpdateDate { get; set; } = DateTime.Now;

        ///// <summary>
        ///// Unit
        ///// </summary>
        //[ForeignKey("UnitNo")]
        //[DataMember]
        //public virtual BAS.FactoryUnit GetFactoryUnit { get; set; }
    }
}