using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using QMFrameWork.WebUI.Attribute;
using QMAPP.Common.Web.Controllers;
using QMAPP.FJC.Web.Models.FIS;
using QMFrameWork.Data;
using QMAPP.ServicesAgent;
using QMAPP.Entity;
using QMAPP.FJC.Entity.FIS;
using QMFrameWork.WebUI.DataSource;
using QMFrameWork.Common.Serialization;
using System.Data;
using QMAPP.Common.Web.Models;
using QMAPP.FJC.Entity.Basic;
using QMAPP.MD.Entity;
using QMAPP.FJC.BLL.FIS;

namespace QMAPP.FJC.Web.Controllers
{
    /// <summary>
    /// 模块名称:仪表板计划
    /// 作    者:郭兆福
    /// 创建时间:2017年09月15日
    /// </summary>
    public class DashBoardPlanController : QController
    {
        #region 获取信息
        /// <summary>
        /// 加载列表
        /// </summary>
        /// <returns>结果</returns>
        [HandleException]
        public ActionResult List(bool? callback)
        {
            DashBoardPlanModel seachModel = new DashBoardPlanModel();
            string order_type = Request["ORDER_TYPE"];

            seachModel.PLANTIMESTART = DateTime.Now.Date.AddDays(-10).ToString("yyyy-MM-dd HH:mm:ss");
            seachModel.PLANTIMEEND = DateTime.Now.Date.AddDays(1).ToString("yyyy-MM-dd HH:mm:ss");
            seachModel.ImmediateSearch = false;
            seachModel.ORDER_TYPE = order_type;
            if (callback == true)
                TryGetSelectBuffer<DashBoardPlanModel>(out seachModel);
            seachModel.rownumbers = false;
            seachModel.url = "/DashBoardPlan/GetList";
            return View("DashBoardPlanList", seachModel);
        }
        #endregion

        #region 获取列表
        /// <summary>
        /// 获取列表
        /// </summary>
        /// <param name="callBack">是否回调</param>
        /// <returns>列表</returns>
        [HandleException]
        public ActionResult GetList(bool? callBack)
        {
            DashBoardPlanModel seachModel = null;
            DataPage page = null;
            ServiceAgent wcfAgent = this.GetServiceAgent();
            OrderPlan condition = null;
            DataResult<DataPage> pageResult = new DataResult<DataPage>();
            try
            {
                //获取查询对象
                seachModel = GetModel<DashBoardPlanModel>();
                #region 获取缓存值
                if (callBack != null)
                {
                    TryGetSelectBuffer<DashBoardPlanModel>(out seachModel);
                }
                else
                {
                    //保存搜索条件
                    SetSelectBuffer<DashBoardPlanModel>(seachModel);
                }
                #endregion

                //获取前台分页设置信息
                page = this.GetDataPage(seachModel);
                condition = CopyToModel<OrderPlan, DashBoardPlanModel>(seachModel);

                pageResult = wcfAgent.InvokeServiceFunction<DataResult<DataPage>>("DashBoardPlanBLL_GetList", condition, page);

                if (pageResult.IsSuccess == false)
                {
                    SetMessage(pageResult.Msg);
                    return List(true);
                }

                DateGridResult<OrderPlan> result = new DateGridResult<OrderPlan>();
                result.Total = pageResult.Result.RecordCount;
                result.Rows = JsonConvertHelper.GetDeserialize<List<OrderPlan>>(pageResult.Result.Result.ToString());

                return Content(result.GetJsonSource());
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
        #endregion

        #region 编辑
        /// <summary>
        /// 编辑载入
        /// </summary>
        /// <returns>处理结果</returns>
        [HandleException]
        public ActionResult Edit()
        {
            DashBoardPlanModel model = new DashBoardPlanModel();
            string ID = Request.QueryString["PID"];
            string TYPE = Request.Params["ORDER_TYPE"];
            OrderPlan Entity = new OrderPlan();
            ServiceAgent wcfAgent = this.GetServiceAgent();
            DataResult<OrderPlan> result = new DataResult<OrderPlan>();
            try
            {
                if (string.IsNullOrEmpty(ID) == false)
                {
                    //修改获取原数据
                    Entity.PID = ID;
                    result = wcfAgent.InvokeServiceFunction<DataResult<OrderPlan>>("DashBoardPlanBLL_Get", Entity);
                    if (result.IsSuccess == false)
                    {
                        SetMessage(result.Msg);
                        return View("DashBoardPlanEdit", model);
                    }
                    model = CopyToModel<DashBoardPlanModel, OrderPlan>(result.Result);
                }
                else
                {
                    model.PLAN_DATE = DateTime.Now;
                }
                model.ORDER_TYPE = TYPE;
                return View("DashBoardPlanEdit", model);
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
        /// <summary>
        /// 保存
        /// </summary>
        /// <param name="model"></param>
        /// <returns>处理结果</returns>
        [HttpPost]
        [HandleException]
        [ValidateInput(false)]
        public ActionResult Save(DashBoardPlanModel saveModel)
        {
            OrderPlan Entity = null;
            string TYPE = Request.Form["ORDER_TYPE"];
            ServiceAgent wcfAgent = this.GetServiceAgent();
            DataResult<int> result = new DataResult<int>();
            try
            {
                Entity = CopyToModel<OrderPlan, DashBoardPlanModel>(saveModel);
                if (string.IsNullOrEmpty(Entity.PID) == true)
                {
                    //新增
                    result = wcfAgent.InvokeServiceFunction<DataResult<int>>("DashBoardPlanBLL_Insert", Entity);
                    if (result.IsSuccess == false)
                    {
                        SetMessage("计划单号已存在!");
                        return View("DashBoardPlanEdit", saveModel);
                    }
                }
                else
                {
                    //修改
                    result = wcfAgent.InvokeServiceFunction<DataResult<int>>("DashBoardPlanBLL_Update", Entity);
                    if (result.IsSuccess == false)
                    {
                        SetMessage(result.Msg
                            );
                        return View("DashBoardPlanEdit", saveModel);
                    }
                }
                return this.GetJsViewResult(string.Format("parent.List(1);parent.showTitle('{0}');parent.closeAppWindow1();", AppResource.SaveMessge));
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
        #endregion

        #region 删除
        /// <summary>
        /// 删除
        /// </summary>
        /// <returns>结果</returns>
        [HttpPost]
        [HandleException]
        public ActionResult Delete(OrderPlan model)
        {
            string selectKey = Request.Form["selectKey"];
            ServiceAgent wcfAgent = this.GetServiceAgent();
            DataResult<int> result = new DataResult<int>();
            try
            {
                result = wcfAgent.InvokeServiceFunction<DataResult<int>>("DashBoardPlanBLL_Delete", selectKey);
                if (result.IsSuccess == false)
                {
                    SetMessage("存在完成数量数据,删除失败!");
                    return List(true);
                }
                SetMessage(AppResource.DeleteMessage);
                return List(true);
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
        #endregion

        #region 发布
        /// <summary>
        /// 发布
        /// </summary>
        /// <returns></returns>
        [HttpPost]
        [HandleException]
        public ActionResult PutOut(OrderPlan model)
        {
            string selectKey = Request.Form["selectKey"];
            ServiceAgent wcfAgent = this.GetServiceAgent();
            DataResult<int> result = new DataResult<int>();
            result = wcfAgent.InvokeServiceFunction<DataResult<int>>("DashBoardPlanBLL_PutOut", selectKey);
            if (result.IsSuccess == false)
            {
                SetMessage(result.Msg);
                return List(true);
            }
            SetMessage(AppResource.PutOutMessage);
            return List(true);
        }
        #endregion

        #region 导出excel
        /// <summary>
        /// 导出excel
        /// </summary>
        /// <returns>结果</returns>
        [HttpPost]
        public ActionResult ExportExcel()
        {
            DashBoardPlanModel seachModel = null;
            OrderPlan condition = null;
            DataTable exportDt = new DataTable();
            ServiceAgent wcfAgent = this.GetServiceAgent();
            try
            {
                //获取查询对象
                seachModel = GetModel<DashBoardPlanModel>();
                condition = CopyToModel<OrderPlan, DashBoardPlanModel>(seachModel);
                condition.PIDList = Request.Form["selectKey"];

                DashBoardPlanBLL db = new DashBoardPlanBLL();

                exportDt = db.GetExportData(condition);
                //exportDt = wcfAgent.InvokeServiceFunction<DataTable>("DashBoardPlanBLL_GetExportData", condition);

                //导出
                QMFrameWork.WebUI.Util.IEFileTool efTool = new QMFrameWork.WebUI.Util.IEFileTool();
                return efTool.GetExcelFileResult("DashBoardPlanExp", "仪表板计划信息.xlsx", exportDt);
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
        #endregion

        #region 导入excel
        /// <summary>
        /// 导入excel
        /// </summary>
        /// <returns>结果</returns>
        [HttpPost]
        public ActionResult ImportExcel()
        {
            DataTable dt = null;
            List<OrderPlan> list = new List<OrderPlan>();
            DataResult<ImportMessage> serviceResult = null;
            string fileName = Request.Form["fileName"];
            string orderby = Request.Form["ORDER_TYPE"];
            ServiceAgent wcfAgent = this.GetServiceAgent();

            Materiel materialmodel = new Materiel();
            ProduceShift produceshiftmodel = new ProduceShift();

            //初始工作中心编号条件
            QMAPP.MD.Entity.WorkCell workcell=new QMAPP.MD.Entity.WorkCell();
            workcell.WORKCELL_CODE = orderby;
            MachineInfo machine = new MachineInfo();
            try
            {
                dt = this.GetTableByExcel("DashBoardPlanImp", fileName, dt);
                //格式转换
                list = QMFrameWork.Common.Util.BindHelper.ConvertToList<OrderPlan>(dt).ToList();
                serviceResult = wcfAgent.InvokeServiceFunction<DataResult<ImportMessage>>("DashBoardPlanBLL_GetImportData", list, materialmodel,machine, produceshiftmodel, workcell);
                if (serviceResult.Ex != null)
                {
                    throw serviceResult.Ex;
                }
                if (serviceResult.Result.failureNum != 0)
                {
                    foreach (RowError error in serviceResult.Result.Errors)
                    {
                        dt.Rows[error.Key - 1]["InfoError"] = error.Value;
                    }
                    ImportMessageModel model = new ImportMessageModel();
                    model.InfoName = "DashBoardPlanImp";
                    model.ReturnUrl = "/DashBoardPlan/List?callBack=true";
                    model.Message = serviceResult.Result;
                    model.ErrorDt = dt;
                    return new MessageOutputController().OutputImportMessage(model);
                }
                else
                {
                    SetMessage(serviceResult.Msg + ",如下:<br/>"
                    + "插入" + serviceResult.Result.insertNum + "条,"
                    + "更新" + serviceResult.Result.updateNum + "条"
                    );
                    return List(true);
                }
            }
            catch (Exception ex)
            {
                throw ex;
            }
            finally
            {
                System.IO.File.Delete(MvcApplication.TempPath + fileName);
            }
        }
        #endregion

        #region 下载模板
        /// <summary>
        /// 下载导入模板
        /// </summary>
        /// <returns>结果</returns>
        [HttpPost]
        public ActionResult GetTemplate()
        {
            try
            {
                string path = AppDomain.CurrentDomain.BaseDirectory + "App_Data/Excel/";
                string fileName = "DashBoardPlanImp.xlsx";
                return File(path + fileName, "application/vnd.ms-excel", Url.Encode("仪表板信息导入模板.xlsx"));
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
        #endregion

        #region 仪表板顺序号编辑
        /// <summary>
        /// 仪表板顺序号编辑
        /// </summary>
        /// <returns></returns>
        public ActionResult DashBoardEditSeq()
        {
            DashBoardPlanModel model = new DashBoardPlanModel();
            OrderPlan Entity = new OrderPlan();
            ServiceAgent wcfAgent = this.GetServiceAgent();
            DataResult<OrderPlan> result = new DataResult<OrderPlan>();
            try
            {
                model = GetModel<DashBoardPlanModel>();
                return View("DashBoardEditSeq", model);
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }
        #endregion


        #region 获取编辑系列号列表
        /// <summary>
        /// 获取编辑系列号列表
        /// </summary>
        /// <param name="callBack"></param>
        /// <returns></returns>
        [HandleException]
        public ActionResult GetDashBoardPlanList(bool? callBack)
        {
            DashBoardPlanModel seachModel = null;
            DataResult<DataPage> pageResult = new DataResult<DataPage>();
            DataPage page = new DataPage();
            ServiceAgent wcfAgent = this.GetServiceAgent();
            OrderPlan condition = new OrderPlan();
            try
            {
                //获取查询对象
                seachModel = GetModel<DashBoardPlanModel>();

                condition.PIDList = seachModel.PIDList;
                condition.ORDER_TYPE = seachModel.ORDER_TYPE;

                #region 获取缓存值
                if (callBack != null)
                {
                    TryGetSelectBuffer<DashBoardPlanModel>(out seachModel);
                }
                else
                {
                    //保存搜索条件
                    SetSelectBuffer<DashBoardPlanModel>(seachModel);
                }
                #endregion
                //获取前台分页设置信息
                page = this.GetDataPage(seachModel);
                condition = CopyToModel<OrderPlan, DashBoardPlanModel>(seachModel);

                #region wcf服务统一接口
                pageResult = wcfAgent.InvokeServiceFunction<DataResult<DataPage>>("DashBoardPlanBLL_GetDashBoardPlanList", condition, page);
                if (pageResult.IsSuccess == false)
                {
                    SetMessage(pageResult.Msg);
                    return List(true);
                }
                DateGridResult<OrderPlan> result = new DateGridResult<OrderPlan>();
                result.Total = pageResult.Result.RecordCount;
                result.Rows = JsonConvertHelper.GetDeserialize<List<OrderPlan>>(pageResult.Result.Result.ToString());
                #endregion
                return Content(result.GetJsonSource());
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }

        #endregion

        #region 保存顺序号修改
        /// <summary>
        ///  
        /// </summary>
        /// <param name="model"></param>
        /// <returns>处理结果</returns>
        [HttpPost]
        [HandleException]
        [ValidateInput(false)]
        public ActionResult DashBoardPlanSeqSave(DashBoardPlanModel saveModel)
        {
            OrderPlan entity = new OrderPlan();
            ServiceAgent wcfAgent = this.GetServiceAgent();
            DataResult<int> result = new DataResult<int>();

            entity.PLAN_SEQ = saveModel.PLAN_SEQ;
            entity.PIDList = saveModel.PIDList;

            entity = CopyToModel<OrderPlan, DashBoardPlanModel>(saveModel);

            //修改
            result = wcfAgent.InvokeServiceFunction<DataResult<int>>("DoorPlankPlanBLL_UpdateDoorPlankPlanSeq", entity);

            return this.GetJsViewResult(string.Format("parent.List(1);parent.showTitle('{0}');parent.closeAppWindow1();", AppResource.SaveMessge));
        }
        #endregion

    }
}