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>
    /// 工單治具資料檔
    /// </summary>
    [Table("WIP_OUTFIT", Schema = "JHAMES")]
    public partial class WipOutfit
    {
        /// <summary>
        /// 工單治具ID
        /// </summary>
        [Key]
        [Column("WIP_OUTFIT_ID")]
        [DataMember]
        public int WipOutfitID { get; set; }

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

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

        /// <summary>
        /// 設備編碼
        /// </summary>
        [Column("OUTFIT_NO")]
        [StringLength(15)]
        [DataMember]
        public string OutfitNo { get; set; } = ".";

        /// <summary>
        /// 設備名稱
        /// </summary>
        [Required]
        [Column("PART_NO")]
        [StringLength(50)]
        [DataMember]
        public string PartNo { get; set; }

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

        /// <summary>
        /// 作業站ID
        /// </summary>
        [Column("STATION_ID")]
        [DataMember]
        public int? StationID { 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; }
    }
}