TaskController.cs 7.83 KB
using Infrastructure;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using System;
using System.Collections.Generic;
using WebApp;
using WebRepository;

namespace WebMvc
{
    /// <summary>
	/// 立库任务表
	/// </summary>
    [Area("task")]
    public class TaskController : BaseController
    {
        private readonly TaskApp _app;
        
        public TaskController(IAuth authUtil, TaskApp app) : base(authUtil)
        {
            _app = app.SetLoginInfo(_loginInfo);
        }

        #region 视图功能
        /// <summary>
        /// 默认视图Action
        /// </summary>
        /// <returns></returns>
        [Authenticate]
        [ServiceFilter(typeof(OperLogFilter))]
        public ActionResult Index()
        {
            return View();
        }

        /// <summary>
        /// 出入库视图
        /// </summary>
        /// <returns></returns>
        [Authenticate]
        [ServiceFilter(typeof(OperLogFilter))]
        public ActionResult PalletInOut()
        {
            return View();
        }

        /// <summary>
        /// 线轴入库视图
        /// </summary>
        /// <returns></returns>
        [Authenticate]
        [ServiceFilter(typeof(OperLogFilter))]
        public ActionResult WireIn()
        {
            return View();
        }
        #endregion

        #region 获取数据
        /// <summary>
        /// 加载及分页查询
        /// </summary>
        /// <param name="pageRequest">表单请求信息</param>
        /// <param name="entity">请求条件实例</param>
        /// <returns></returns>
        [HttpPost]
        public string Load(PageReq pageRequest, Task entity)
        {
            return JsonHelper.Instance.Serialize(_app.Load(pageRequest, entity));
        }
        #endregion

        #region 提交数据
        /// <summary>
        /// 新增数据
        /// </summary>
        /// <param name="Table_entity">新增实例</param>
        /// <returns></returns>
        [HttpPost]
        [ServiceFilter(typeof(OperLogFilter))]
        public string Ins(Task Table_entity)
        {
            try
            {
                _app.Ins(Table_entity);
            }
            catch (Exception ex)
            {
                Result.Status = false;
                Result.Message = ex.Message;
            }
            return JsonHelper.Instance.Serialize(Result);
        }

        /// <summary>
        /// 修改数据
        /// </summary>
        /// <param name="Table_entity">修改实例</param>
        /// <returns></returns>
        [HttpPost]
        [ServiceFilter(typeof(OperLogFilter))]
        public string Upd(Task Table_entity)
        {
            try
            {
                _app.Upd(Table_entity);
            }
            catch (Exception ex)
            {
                Result.Status = false;
                Result.Message = ex.Message;
            }
            return JsonHelper.Instance.Serialize(Result);
        }

        [HttpPost]
        [ServiceFilter(typeof(OperLogFilter))]
        public string DelByIds(int[] ids)
        {
            try
            {
                _app.DelByIds(ids);
            }
            catch (Exception ex)
            {
                Result.Status = false;
                Result.Message = ex.Message;
            }
            return JsonHelper.Instance.Serialize(Result);
        }
        #endregion

        #region 导出数据
        /// <summary>
        /// 导出数据
        /// </summary>
        /// <param name="entity">请求条件实例</param>
        /// <returns></returns>
        [HttpPost]
        public string Export(Task entity)
        {
            return JsonHelper.Instance.Serialize(_app.ExportData(entity));
        }
        #endregion

        #region 导出模板
        /// <summary>
        /// 导出模板
        /// </summary>
        /// <returns></returns>
        [HttpPost]
        public string GetTemplate()
        {
            var result = new TableData();
            List<Task> listTask = new List<Task>();
            Task entity = _app.FindSingle(u => u.Id > 0);
            if (entity != null)
            {
                listTask.Add(entity);
            }
            else
            {
                listTask.Add(new Task());
            }
 
            result.data = listTask;
            result.count = listTask.Count;

            return JsonHelper.Instance.Serialize(result);
        }
        #endregion

        #region 导入数据
        /// <summary>
        /// 导入数据
        /// </summary>
        /// <param name="excelfile">表单提交的文件信息</param>
        /// <returns></returns>
        [HttpPost]
        public string Import(IFormFile excelfile)
        {
            try
            {
                Response result = _app.ImportIn(excelfile);
                if (!result.Status)
                {
                    Result.Status = false;
                    Result.Message = result.Message;
                }
            }
            catch (Exception ex)
            {
                Result.Status = false;
                Result.Message = ex.Message;
            }
            return JsonHelper.Instance.Serialize(Result);
        }
        #endregion

        #region 自定义方法
        [HttpPost]
        [ServiceFilter(typeof(OperLogFilter))]
        public string FindSourceCode(string Code)
        {
            TableData tab = new TableData();
            try
            {
                tab = _app.FindCode(Code);
            }
            catch (Exception ex)
            {
                tab.code = 300;
                tab.msg = ex.Message;
            }
            return JsonHelper.Instance.Serialize(tab);
        }

        [HttpPost]
        [ServiceFilter(typeof(OperLogFilter))]
        public string BulidContainerBack(string containerCode, string IsFull)
        {
            return JsonHelper.Instance.Serialize(_app.ContainerBack(containerCode, IsFull));
        }

        [HttpPost]
        [ServiceFilter(typeof(OperLogFilter))]
        public string BulidEmptyContainerBack(string station, string containerCode, string type)
        {
            return JsonHelper.Instance.Serialize(_app.EmptyContainerBack(station,containerCode, type));
        }

        [HttpPost]
        [ServiceFilter(typeof(OperLogFilter))]
        public string FinishPick(TaskDetail taskDel)
        {
            return JsonHelper.Instance.Serialize(_app.FinishPickApp(taskDel));
        }

        [HttpPost]
        [ServiceFilter(typeof(OperLogFilter))]
        public string FinishCheck(TaskDetail taskDel)
        {
            return JsonHelper.Instance.Serialize(_app.FinishCheckApp(taskDel));
        }

        //取消任务
        [HttpPost]
        [ServiceFilter(typeof(OperLogFilter))]
        public string TaskCancel(List<Task> tasklist)
        {
            return JsonHelper.Instance.Serialize(_app.TaskCancelApp(tasklist));
        }

        /// <summary>
        /// 线轴入库
        /// </summary>
        [HttpPost]
        [ServiceFilter(typeof(OperLogFilter))]
        public string WireIn(string barcode)
        {
            try
            {
                TableData res = new TableData();
                //解析二维码
                //201906180001|P00295976|918|16.03.19
                string[] sArray = barcode.Split('|');
                if (sArray.Length != 4)
                {
                    throw new Exception("二维码格式不正确");
                }
                
                _app.WireIn(sArray);
                res.code = 200;
                res.data = sArray;
                return JsonHelper.Instance.Serialize(res);
            }
            catch (Exception ex)
            {
                Result.Status = false;
                Result.Message = ex.Message;

                return JsonHelper.Instance.Serialize(Result);
            }
        }
        #endregion


    }
}