using FineUIPro; using System.Collections; using System.Collections.Generic; using System.Linq; namespace BLL { public static class TwOutputdetailService { #region 获取列表 /// /// 记录数 /// public static int Count { get; set; } public static IQueryable GetByModle(Model.Tw_InOutDetailOutput table) { var q = from x in Funs.DB.Tw_OutputDetail join y in Funs.DB.HJGL_Pipeline_Component on x.PipelineComponentId equals y.PipelineComponentId into yy from y in yy.DefaultIfEmpty() join mat in Funs.DB.HJGL_MaterialCodeLib on x.MaterialCode equals mat.MaterialCode into mm from mat in mm.DefaultIfEmpty() join master in Funs.DB.Tw_OutputMaster on x.OutputMasterId equals master.Id into masters from master in masters.DefaultIfEmpty() join stock in Funs.DB.Tw_MaterialStock on new { x.MaterialCode, master.WarehouseCode, master.ProjectId } equals new { MaterialCode = stock.PipeLineMatCode, stock.WarehouseCode, stock.ProjectId } into st from stock in st.DefaultIfEmpty() where (string.IsNullOrEmpty(table.Id) || x.Id.Contains(table.Id)) && (string.IsNullOrEmpty(table.OutputMasterId) || x.OutputMasterId.Contains(table.OutputMasterId)) && (string.IsNullOrEmpty(table.PipelineComponentId) || x.PipelineComponentId.Contains(table.PipelineComponentId)) && (string.IsNullOrEmpty(table.MaterialCode) || x.MaterialCode.Contains(table.MaterialCode)) && (table.TypeInt == null || master.TypeInt == table.TypeInt) select new Model.Tw_InOutDetailOutput { Id = x.Id, OutputMasterId = x.OutputMasterId, CusBillCode = master.CusBillCode, TypeInt = master.TypeInt, PipelineComponentId = x.PipelineComponentId, MaterialCode = x.MaterialCode, PlanNum = x.PlanNum, ActNum = x.ActNum, PipelineComponentCode = y.PipelineComponentCode, MaterialName = mat.MaterialName, StockNum = stock.StockNum ?? 0, DiffNum = (x.ActNum ?? 0) - (x.PlanNum ?? 0), MaterialDef = mat.MaterialDef } ; return q; } /// /// 获取分页列表 /// /// /// /// public static IEnumerable GetListData(Model.Tw_InOutDetailOutput table, Grid grid1) { var q = GetByModle(table); Count = q.Count(); if (Count == 0) { return null; } q = q.Skip(grid1.PageSize * grid1.PageIndex).Take(grid1.PageSize); // q = SortConditionHelper.SortingAndPaging(q, Grid1.SortField, Grid1.SortDirection, Grid1.PageIndex, Grid1.PageSize); return from x in q select x; } #endregion public static Model.Tw_OutputDetail GetById(string Id) { return Funs.DB.Tw_OutputDetail.FirstOrDefault(x => x.Id == Id); } /// /// 根据明细Id获取对应的出库主表信息 /// /// /// public static Model.Tw_InOutMasterOutput GetInOutMasterById(string Id) { var detail = Funs.DB.Tw_OutputDetail.FirstOrDefault(x => x.Id == Id); if (detail == null) return null; Model.Tw_InOutMasterOutput fliter = new Model.Tw_InOutMasterOutput { Id = detail.OutputMasterId }; var result= TwOutputmasterService.GetListData(fliter).FirstOrDefault(); return result; } public static void Add(Model.Tw_OutputDetail newtable) { Model.Tw_OutputDetail table = new Model.Tw_OutputDetail { Id = newtable.Id, OutputMasterId = newtable.OutputMasterId, PipelineComponentId = newtable.PipelineComponentId, MaterialCode = newtable.MaterialCode, PlanNum = newtable.PlanNum, ActNum = newtable.ActNum, }; Funs.DB.Tw_OutputDetail.InsertOnSubmit(table); Funs.DB.SubmitChanges(); } public static void Update(Model.Tw_OutputDetail newtable) { Model.Tw_OutputDetail table = Funs.DB.Tw_OutputDetail.FirstOrDefault(x => x.Id == newtable.Id); if (table != null) { table.Id = newtable.Id; table.OutputMasterId = newtable.OutputMasterId; table.PipelineComponentId = newtable.PipelineComponentId; table.MaterialCode = newtable.MaterialCode; table.PlanNum = newtable.PlanNum; table.ActNum = newtable.ActNum; Funs.DB.SubmitChanges(); } } public static void DeleteById(string Id) { Model.Tw_OutputDetail table = Funs.DB.Tw_OutputDetail.FirstOrDefault(x => x.Id == Id); if (table != null) { Funs.DB.Tw_OutputDetail.DeleteOnSubmit(table); Funs.DB.SubmitChanges(); } } public static IEnumerable GetPrintListByOutputMasterIds(List outputMasterIds) { var q = from x in Funs.DB.Tw_OutputDetail join y in Funs.DB.HJGL_MaterialCodeLib on x.MaterialCode equals y.MaterialCode join master in Funs.DB.Tw_OutputMaster on x.OutputMasterId equals master.Id where outputMasterIds.Contains(x.OutputMasterId) orderby master.CusBillCode select new { 出库单编号 = master.CusBillCode, 材料编码 = x.MaterialCode, 材料名称 = y.MaterialName, 材料描述 = y.MaterialDef, 计划数量 = x.PlanNum, 实际数量 = x.ActNum, }; return q; } } }