using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.EntityFrameworkCore;
using AMESCoreStudio.WebApi;
using AMESCoreStudio.WebApi.Models.AMES;
using AMESCoreStudio.CommonTools.Result;

namespace AMESCoreStudio.WebApi.Controllers.AMES
{
    /// <summary>
    /// 各班別數量資料檔
    /// </summary>
    [Route("api/[controller]")]
    [ApiController]
    public class WipClassController : ControllerBase
    {
        private readonly AMESContext _context;

        public WipClassController(AMESContext context)
        {
            _context = context;
        }

        // GET: api/WipClass
        [HttpGet]
        public async Task<ActionResult<IEnumerable<WipClass>>> GetWipClass()
        {
            return await _context.WipClass.ToListAsync();
        }

        // GET: api/WipClass/5
        [HttpGet("{id}")]
        public async Task<ActionResult<WipClass>> GetWipClass(int id)
        {
            var wipClass = await _context.WipClass.FindAsync(id);

            if (wipClass == null)
            {
                return NotFound();
            }

            return wipClass;
        }

        [HttpGet("Query")]
        public async Task<ActionResult<IEnumerable<WipClass>>> GetWipClassByData(int wipID, int stationID ,string ruleStatus)
        {
            IQueryable<WipClass> q = _context.WipClass;


            if (wipID != 0)
                q = q.Where(w => w.WipID == wipID);


            if (stationID != 0)
                q = q.Where(w => w.StationID == stationID);

            if (!string.IsNullOrWhiteSpace(ruleStatus))
                q = q.Where(w => w.RuleStatus == ruleStatus);



            var result = await q.ToListAsync();

            return result;
        }

        /// <summary>
        /// 更新各班別數量資料檔
        /// </summary>
        /// <param name="wipClass"></param>
        /// <returns></returns>
        [HttpPut]
        public async Task<ResultModel<WipClass>> PutWipClass(WipClass wipClass)
        {
            ResultModel<WipClass> result = new ResultModel<WipClass>();
            _context.Entry(wipClass).State = EntityState.Modified;
            _context.Entry<WipClass>(wipClass).Property("CreateDate").IsModified = false;
            _context.Entry<WipClass>(wipClass).Property("CreateUserID").IsModified = false;
            wipClass.UpdateDate = DateTime.Now;

            try
            {
                await _context.SaveChangesAsync();
                result.Success = true;
                result.Msg = "OK";
            }
            catch (Exception ex)
            {
                result.Success = false;
                result.Msg = ex.InnerException.Message;

            }
            return result;
        }

        /// <summary>
        /// 新增各班別數量資料檔
        /// </summary>
        /// <param name="wipClass"></param>
        /// <returns></returns>
        [HttpPost]
        public async Task<ResultModel<WipClass>> PostWipClass(WipClass wipClass)
        {
            ResultModel<WipClass> result = new ResultModel<WipClass>();
        
            try
            {
                _context.WipClass.Add(wipClass);
                await _context.SaveChangesAsync();
                result.Success = true;
                result.Msg = "OK";
            }
            catch (Exception ex)
            {
                result.Success = false;
                result.Msg = ex.InnerException.Message;
            }
            return result;
        }

        // DELETE: api/WipClass/5
        [HttpDelete("{id}")]
        public async Task<ActionResult<WipClass>> DeleteWipClass(int id)
        {
            var wipClass = await _context.WipClass.FindAsync(id);
            if (wipClass == null)
            {
                return NotFound();
            }

            _context.WipClass.Remove(wipClass);
            await _context.SaveChangesAsync();

            return wipClass;
        }

        private bool WipClassExists(int id)
        {
            return _context.WipClass.Any(e => e.WipID == id);
        }

        /// <summary>
        /// 良率查詢
        /// </summary>
        /// <param name="unitNo"></param>
        /// <param name="lineID"></param>
        /// <param name="stationID"></param>
        /// <param name="mfgTypeNo"></param>
        /// <param name="wipNo"></param>
        /// <param name="itemNo"></param>
        /// <param name="dateStart"></param>
        /// <param name="dateEnd"></param>
        /// <param name="page"></param>
        /// <param name="limit"></param>
        /// <returns></returns>
        [Route("[action]")]
        [HttpGet]
        public async Task<ResultModel<dynamic>> GetYieldData4QRS010(string unitNo, string lineID, string stationID, string mfgTypeNo, string wipNo, string itemNo, string dateStart, string dateEnd, int page = 0, int limit = 10)
        {
            ResultModel<dynamic> result = new ResultModel<dynamic>();
            var q = from a in _context.WipStations
                    join b in _context.Stationses on a.StationID equals b.StationID
                    join c in _context.WipInfos on a.WipID equals c.WipID
                    join d in _context.WipAtts on c.WipNO equals d.WipNO
                    join e in _context.LineInfoes on c.LineID equals e.LineID
                    select new
                    {
                        a.WipID,
                        c.WipNO,
                        d.ItemNO,
                        c.PlanQTY,
                        d.ModelNO,
                        e.LineDesc,
                        b.StationID,
                        b.StationName,
                        a.RuleStatus,
                        a.FirstCnt,
                        a.PassCnt,
                        c.UnitNO,
                        c.LineID,
                        a.CreateDate
                    };

            if (unitNo != null)
            {
                if (unitNo != "*")
                {
                    q = q.Where(w => w.UnitNO == unitNo);
                }
            }

            if (lineID != null)
            {
                if (lineID != "0")
                {
                    q = q.Where(w => w.LineID == int.Parse(lineID));
                }
            }

            if (stationID != null)
            {
                if (stationID != "0")
                {
                    q = q.Where(w => w.StationID == int.Parse(stationID));
                }
            }

            if (wipNo != null)
            {
                if (wipNo != "")
                {
                    q = q.Where(w => w.WipNO == wipNo);
                }
            }

            if (itemNo != null)
            {
                if (itemNo != "")
                {
                    q = q.Where(w => w.ItemNO == itemNo);
                }
            }

            if (dateStart != null && dateEnd != null)
            {
                if (dateStart != "" && dateEnd != "")
                {
                    q = q.Where(w => w.CreateDate >= DateTime.Parse(dateStart) && w.CreateDate <= DateTime.Parse(dateEnd));
                }
            }

            q = q.OrderBy(w => w.WipID + w.StationID);

            var g = q.GroupBy(x => new { x.WipID, x.WipNO, x.PlanQTY, x.StationID, x.StationName, x.RuleStatus, x.ItemNO, x.LineDesc, x.ModelNO }).Select(y => new
            {
                WipID = y.Key.WipID,
                WipNO = y.Key.WipNO,
                PlanQTY = y.Key.PlanQTY,
                StationID = y.Key.StationID,
                StationName = y.Key.StationName,
                RuleStatus = y.Key.RuleStatus,
                ItemNO = y.Key.ItemNO,
                LineDesc = y.Key.LineDesc,
                ModelNO = y.Key.ModelNO,
                FirstCnt = y.Sum(x => x.FirstCnt),
                PassCnt = y.Sum(x => x.PassCnt),
                Yield = (y.Sum(x => x.FirstCnt) / y.Sum(x => x.PassCnt) * 100)
            });

            var g1 = g.GroupBy(x => new { x.WipID, x.WipNO, x.PlanQTY, x.StationID, x.StationName, x.ItemNO, x.LineDesc, x.ModelNO }).Select(y => new
            {
                WipID = y.Key.WipID,
                WipNO = y.Key.WipNO,
                PlanQTY = y.Key.PlanQTY,
                StationID = y.Key.StationID,
                StationName = y.Key.StationName,
                ItemNO = y.Key.ItemNO,
                LineDesc = y.Key.LineDesc,
                ModelNO = y.Key.ModelNO,
                FirstCnt = 0,
                PassCnt = y.Sum(x => x.FirstCnt),
                Yield = (y.Sum(x => x.FirstCnt) / y.Sum(x => x.PassCnt) * 100)
            }) ;

            //紀錄筆數
            result.DataTotal = g1.Count();

            //Table 頁數
            if (page > 0)
            {
                g1 = g1.Skip((page - 1) * limit).Take(limit);
            }

            result.Data = await g1.ToListAsync();

            if (result == null)
            {
                result.Msg = "查無資料";
                result.Success = false;
                return result;
            }

            result.Success = true;
            result.Msg = "OK";
            return result;
        }

        /// <summary>
        /// 良率查詢
        /// </summary>
        /// <param name="lineDesc"></param>
        /// <param name="stationID"></param>
        /// <param name="wipNo"></param>
        /// <returns></returns>
        [Route("[action]")]
        [HttpGet]
        public async Task<ResultModel<dynamic>> GetPassData4QRS010(string lineDesc, string stationID, string wipNo)
        {
            ResultModel<dynamic> result = new ResultModel<dynamic>();
            var q = from a in _context.WipStations
                    join b in _context.Stationses on a.StationID equals b.StationID
                    join c in _context.WipInfos on a.WipID equals c.WipID
                    join d in _context.WipAtts on c.WipNO equals d.WipNO
                    join e in _context.LineInfoes on c.LineID equals e.LineID
                    select new
                    {
                        a.WipID,
                        c.WipNO,
                        d.ItemNO,
                        c.PlanQTY,
                        d.ModelNO,
                        e.LineDesc,
                        b.StationID,
                        b.StationName,
                        a.RuleStatus,
                        a.FirstCnt,
                        a.PassCnt,
                        c.UnitNO,
                        c.LineID,
                        a.CreateDate
                    };

            q = q.Where(w => w.RuleStatus.Equals("P"));

            if (lineDesc != null)
            {
                if (lineDesc != "*")
                {
                    q = q.Where(w => w.LineDesc == lineDesc);
                }
            }

            if (stationID != null)
            {
                if (stationID != "0")
                {
                    q = q.Where(w => w.StationID == int.Parse(stationID));
                }
            }

            if (wipNo != null)
            {
                if (wipNo != "")
                {
                    q = q.Where(w => w.WipNO == wipNo);
                }
            }

            q = q.OrderBy(w => w.WipID + w.StationID);

            var g = q.GroupBy(x => new { x.WipID, x.WipNO, x.PlanQTY, x.StationID, x.StationName, x.RuleStatus, x.ItemNO, x.LineDesc, x.ModelNO }).Select(y => new
            {
                WipID = y.Key.WipID,
                WipNO = y.Key.WipNO,
                PlanQTY = y.Key.PlanQTY,
                StationID = y.Key.StationID,
                StationName = y.Key.StationName,
                RuleStatus = y.Key.RuleStatus,
                ItemNO = y.Key.ItemNO,
                LineDesc = y.Key.LineDesc,
                ModelNO = y.Key.ModelNO,
                FirstCnt = y.Sum(x => x.FirstCnt),
                PassCnt = y.Sum(x => x.PassCnt),
                Yield = (y.Sum(x => x.FirstCnt) / y.Sum(x => x.PassCnt) * 100)
            });

            //紀錄筆數
            result.DataTotal = g.Count();

            result.Data = await g.ToListAsync();

            if (result == null)
            {
                result.Msg = "查無資料";
                result.Success = false;
                return result;
            }

            result.Success = true;
            result.Msg = "OK";
            return result;
        }
    }
}