337 lines
14 KiB
C#
337 lines
14 KiB
C#
|
|
using BLL;
|
|||
|
|
using MiniExcelLibs;
|
|||
|
|
using System;
|
|||
|
|
using System.Collections.Generic;
|
|||
|
|
using System.Data;
|
|||
|
|
using System.IO;
|
|||
|
|
using System.Linq;
|
|||
|
|
|
|||
|
|
namespace FineUIPro.Web.HJGL.PreDesign
|
|||
|
|
{
|
|||
|
|
public partial class PrePipelineComponentJointIn : PageBase
|
|||
|
|
{
|
|||
|
|
private string initPath = Const.ExcelUrl;
|
|||
|
|
|
|||
|
|
public static List<ComponentJointImportItem> ComponentJointList = new List<ComponentJointImportItem>();
|
|||
|
|
|
|||
|
|
public static string errorInfos = string.Empty;
|
|||
|
|
|
|||
|
|
protected void Page_Load(object sender, EventArgs e)
|
|||
|
|
{
|
|||
|
|
if (!IsPostBack)
|
|||
|
|
{
|
|||
|
|
this.hdFileName.Text = string.Empty;
|
|||
|
|
if (ComponentJointList != null)
|
|||
|
|
{
|
|||
|
|
ComponentJointList.Clear();
|
|||
|
|
}
|
|||
|
|
errorInfos = string.Empty;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
protected void btnAudit_Click(object sender, EventArgs e)
|
|||
|
|
{
|
|||
|
|
try
|
|||
|
|
{
|
|||
|
|
if (this.fuAttachUrl.HasFile == false)
|
|||
|
|
{
|
|||
|
|
ShowNotify("请您选择Excel文件!", MessageBoxIcon.Warning);
|
|||
|
|
return;
|
|||
|
|
}
|
|||
|
|
string isXls = Path.GetExtension(this.fuAttachUrl.FileName).ToString().Trim().ToLower();
|
|||
|
|
if (isXls != ".xlsx")
|
|||
|
|
{
|
|||
|
|
ShowNotify("只可以选择Excel文件!", MessageBoxIcon.Warning);
|
|||
|
|
return;
|
|||
|
|
}
|
|||
|
|
ComponentJointList.Clear();
|
|||
|
|
errorInfos = string.Empty;
|
|||
|
|
|
|||
|
|
string rootPath = Server.MapPath("~/");
|
|||
|
|
string initFullPath = rootPath + initPath;
|
|||
|
|
if (!Directory.Exists(initFullPath))
|
|||
|
|
{
|
|||
|
|
Directory.CreateDirectory(initFullPath);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
this.hdFileName.Text = BLL.Funs.GetNewFileName() + isXls;
|
|||
|
|
string filePath = initFullPath + this.hdFileName.Text;
|
|||
|
|
this.fuAttachUrl.PostedFile.SaveAs(filePath);
|
|||
|
|
ImportXlsToData(filePath);
|
|||
|
|
}
|
|||
|
|
catch (Exception ex)
|
|||
|
|
{
|
|||
|
|
Alert alert = new Alert
|
|||
|
|
{
|
|||
|
|
Message = "'" + ex.Message + "'",
|
|||
|
|
Target = Target.Self
|
|||
|
|
};
|
|||
|
|
alert.Show();
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
private void ImportXlsToData(string fileName)
|
|||
|
|
{
|
|||
|
|
var rows = MiniExcel.QueryAsDataTable(fileName, useHeaderRow: true);
|
|||
|
|
Model.ResponeData responeData = AddDatasetToSQL(rows, 3);
|
|||
|
|
if (responeData.code == 1)
|
|||
|
|
{
|
|||
|
|
ShowNotify("审核完成,请点击导入!", MessageBoxIcon.Success);
|
|||
|
|
}
|
|||
|
|
else
|
|||
|
|
{
|
|||
|
|
Alert alert = new Alert
|
|||
|
|
{
|
|||
|
|
Message = responeData.message,
|
|||
|
|
Target = Target.Self
|
|||
|
|
};
|
|||
|
|
alert.Show();
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
private Model.ResponeData AddDatasetToSQL(DataTable pds, int cols)
|
|||
|
|
{
|
|||
|
|
Model.ResponeData responeData = new Model.ResponeData();
|
|||
|
|
List<string> result = new List<string>();
|
|||
|
|
if (pds == null)
|
|||
|
|
{
|
|||
|
|
responeData.code = 0;
|
|||
|
|
responeData.message = "导入数据为空!";
|
|||
|
|
return responeData;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
int ic = pds.Columns.Count;
|
|||
|
|
int ir = pds.Rows.Count;
|
|||
|
|
if (ic < cols || !pds.Columns.Contains("管线号") || !pds.Columns.Contains("预制组件") || !pds.Columns.Contains("焊口号"))
|
|||
|
|
{
|
|||
|
|
responeData.code = 0;
|
|||
|
|
responeData.message = "导入Excel格式错误!模板列必须包含:管线号、预制组件、焊口号";
|
|||
|
|
return responeData;
|
|||
|
|
}
|
|||
|
|
if (ir == 0)
|
|||
|
|
{
|
|||
|
|
responeData.code = 0;
|
|||
|
|
responeData.message = "导入数据为空!";
|
|||
|
|
return responeData;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
var getPipeline = from x in Funs.DB.HJGL_Pipeline where x.ProjectId == this.CurrUser.LoginProjectId select x;
|
|||
|
|
List<ComponentJointImportItem> importItems = new List<ComponentJointImportItem>();
|
|||
|
|
|
|||
|
|
for (int i = 0; i < ir; i++)
|
|||
|
|
{
|
|||
|
|
string pipelineCode = GetCellValue(pds.Rows[i], "管线号");
|
|||
|
|
string pipelineComponentCode = GetCellValue(pds.Rows[i], "预制组件");
|
|||
|
|
string weldJointCode = GetCellValue(pds.Rows[i], "焊口号");
|
|||
|
|
|
|||
|
|
if (string.IsNullOrEmpty(pipelineCode) && string.IsNullOrEmpty(pipelineComponentCode) && string.IsNullOrEmpty(weldJointCode))
|
|||
|
|
{
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
if (string.IsNullOrEmpty(pipelineCode))
|
|||
|
|
{
|
|||
|
|
result.Add("第" + (i + 2).ToString() + "行,管线号,此项为必填项!");
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
if (string.IsNullOrEmpty(pipelineComponentCode))
|
|||
|
|
{
|
|||
|
|
result.Add("第" + (i + 2).ToString() + "行,预制组件,此项为必填项!");
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
if (string.IsNullOrEmpty(weldJointCode))
|
|||
|
|
{
|
|||
|
|
result.Add("第" + (i + 2).ToString() + "行,焊口号,此项为必填项!");
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
var pipeline = getPipeline.FirstOrDefault(x => x.PipelineCode == pipelineCode);
|
|||
|
|
if (pipeline == null)
|
|||
|
|
{
|
|||
|
|
result.Add("第" + (i + 2).ToString() + "行,不存在此管线号-" + pipelineCode);
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
var pipelineComponent = HJGL_PipelineComponentService.GetPipelineComponentByCodeandpipelineId(pipelineComponentCode, pipeline.PipelineId);
|
|||
|
|
if (pipelineComponent == null)
|
|||
|
|
{
|
|||
|
|
result.Add("第" + (i + 2).ToString() + "行,不存在此预制组件-" + pipelineComponentCode);
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
var weldJoint = WeldJointService.GetWeldJointsByWeldJointCode(pipeline.PipelineId, weldJointCode);
|
|||
|
|
if (weldJoint == null)
|
|||
|
|
{
|
|||
|
|
result.Add("第" + (i + 2).ToString() + "行,不存在此焊口号-" + weldJointCode);
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
importItems.Add(new ComponentJointImportItem
|
|||
|
|
{
|
|||
|
|
PipelineId = pipeline.PipelineId,
|
|||
|
|
PipelineCode = pipeline.PipelineCode,
|
|||
|
|
PipelineComponentId = pipelineComponent.PipelineComponentId,
|
|||
|
|
PipelineComponentCode = pipelineComponent.PipelineComponentCode,
|
|||
|
|
WeldJointId = weldJoint.WeldJointId,
|
|||
|
|
WeldJointCode = weldJoint.WeldJointCode
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
var conflictWeldJoints = importItems
|
|||
|
|
.GroupBy(x => x.WeldJointId)
|
|||
|
|
.Where(x => x.Select(y => y.PipelineComponentId).Distinct().Count() > 1)
|
|||
|
|
.Select(x => x.First().PipelineCode + "-" + x.First().WeldJointCode)
|
|||
|
|
.ToList();
|
|||
|
|
if (conflictWeldJoints.Count > 0)
|
|||
|
|
{
|
|||
|
|
result.Add("同一焊口不能导入到多个组件:" + string.Join("、", conflictWeldJoints));
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
if (result.Count > 0)
|
|||
|
|
{
|
|||
|
|
ComponentJointList.Clear();
|
|||
|
|
errorInfos = string.Join("|", result.Distinct());
|
|||
|
|
responeData.code = 0;
|
|||
|
|
responeData.message = errorInfos;
|
|||
|
|
return responeData;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
ComponentJointList = importItems
|
|||
|
|
.GroupBy(x => new { x.PipelineComponentId, x.WeldJointId })
|
|||
|
|
.Select(x => x.First())
|
|||
|
|
.ToList();
|
|||
|
|
errorInfos = string.Empty;
|
|||
|
|
responeData.code = ComponentJointList.Count > 0 ? 1 : 0;
|
|||
|
|
responeData.message = ComponentJointList.Count > 0 ? string.Empty : "导入数据为空!";
|
|||
|
|
return responeData;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
protected void btnImport_Click(object sender, EventArgs e)
|
|||
|
|
{
|
|||
|
|
if (string.IsNullOrEmpty(errorInfos))
|
|||
|
|
{
|
|||
|
|
if (!string.IsNullOrEmpty(this.hdFileName.Text))
|
|||
|
|
{
|
|||
|
|
if (ComponentJointList.Count > 0)
|
|||
|
|
{
|
|||
|
|
this.Grid1.Hidden = false;
|
|||
|
|
this.Grid1.DataIDField = "WeldJointId";
|
|||
|
|
this.Grid1.DataSource = ComponentJointList;
|
|||
|
|
this.Grid1.DataBind();
|
|||
|
|
Grid1.RecordCount = ComponentJointList.Count;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
else
|
|||
|
|
{
|
|||
|
|
ShowNotify("请先审核要导入的文件!", MessageBoxIcon.Warning);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
else
|
|||
|
|
{
|
|||
|
|
ShowNotify("请先将错误数据修正,再重新导入提交!", MessageBoxIcon.Warning);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
protected void btnSave_Click(object sender, EventArgs e)
|
|||
|
|
{
|
|||
|
|
if (!string.IsNullOrEmpty(errorInfos))
|
|||
|
|
{
|
|||
|
|
ShowNotify("请先将错误数据修正,再重新导入提交!", MessageBoxIcon.Warning);
|
|||
|
|
return;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
if (ComponentJointList.Count > 0)
|
|||
|
|
{
|
|||
|
|
foreach (var item in ComponentJointList)
|
|||
|
|
{
|
|||
|
|
var componentJoint = BLL.HJGL_PipelineComponentjointService.GetHJGL_Pipeline_ComponentJointByWeldJointId(item.WeldJointId);
|
|||
|
|
if (componentJoint != null)
|
|||
|
|
{
|
|||
|
|
componentJoint.PipelineComponentCode = item.PipelineComponentCode;
|
|||
|
|
componentJoint.PipelineComponentId = item.PipelineComponentId;
|
|||
|
|
componentJoint.WeldJointCode = item.WeldJointCode;
|
|||
|
|
componentJoint.WeldJointId = item.WeldJointId;
|
|||
|
|
HJGL_PipelineComponentjointService.UpdateHJGL_Pipeline_ComponentJoint(componentJoint);
|
|||
|
|
}
|
|||
|
|
else
|
|||
|
|
{
|
|||
|
|
Model.HJGL_Pipeline_ComponentJoint newComponentJoint = new Model.HJGL_Pipeline_ComponentJoint();
|
|||
|
|
newComponentJoint.Id = SQLHelper.GetNewID();
|
|||
|
|
newComponentJoint.PipelineComponentCode = item.PipelineComponentCode;
|
|||
|
|
newComponentJoint.PipelineComponentId = item.PipelineComponentId;
|
|||
|
|
newComponentJoint.WeldJointCode = item.WeldJointCode;
|
|||
|
|
newComponentJoint.WeldJointId = item.WeldJointId;
|
|||
|
|
newComponentJoint.State = 0;
|
|||
|
|
HJGL_PipelineComponentjointService.AddHJGL_Pipeline_ComponentJoint(newComponentJoint);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
string rootPath = Server.MapPath("~/");
|
|||
|
|
string filePath = rootPath + initPath + this.hdFileName.Text;
|
|||
|
|
if (filePath != string.Empty && System.IO.File.Exists(filePath))
|
|||
|
|
{
|
|||
|
|
System.IO.File.Delete(filePath);
|
|||
|
|
}
|
|||
|
|
ShowNotify("导入成功!", MessageBoxIcon.Success);
|
|||
|
|
PageContext.RegisterStartupScript(ActiveWindow.GetHidePostBackReference());
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
protected void btnDownLoad_Click(object sender, EventArgs e)
|
|||
|
|
{
|
|||
|
|
string rootPath = Server.MapPath("~/");
|
|||
|
|
string tempDirectory = rootPath + @"File\Excel\Temp\";
|
|||
|
|
if (!Directory.Exists(tempDirectory))
|
|||
|
|
{
|
|||
|
|
Directory.CreateDirectory(tempDirectory);
|
|||
|
|
}
|
|||
|
|
string tempPath = tempDirectory + "组件焊口信息导入模板" + string.Format("{0:yyyyMMddHHmmss}", DateTime.Now) + ".xlsx";
|
|||
|
|
DataTable template = new DataTable();
|
|||
|
|
template.Columns.Add("管线号");
|
|||
|
|
template.Columns.Add("预制组件");
|
|||
|
|
template.Columns.Add("焊口号");
|
|||
|
|
MiniExcel.SaveAs(tempPath, template);
|
|||
|
|
|
|||
|
|
FileInfo info = new FileInfo(tempPath);
|
|||
|
|
long fileSize = info.Length;
|
|||
|
|
Response.ClearContent();
|
|||
|
|
Response.AddHeader("Content-Disposition", "attachment;filename=" + System.Web.HttpUtility.UrlEncode("组件焊口信息导入模板.xlsx", System.Text.Encoding.UTF8));
|
|||
|
|
Response.ContentType = "excel/plain";
|
|||
|
|
Response.ContentEncoding = System.Text.Encoding.UTF8;
|
|||
|
|
Response.AddHeader("Content-Length", fileSize.ToString().Trim());
|
|||
|
|
Response.TransmitFile(tempPath, 0, fileSize);
|
|||
|
|
Response.Flush();
|
|||
|
|
Response.Close();
|
|||
|
|
File.Delete(tempPath);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
protected void ddlPageSize_SelectedIndexChanged(object sender, EventArgs e)
|
|||
|
|
{
|
|||
|
|
Grid1.PageSize = Convert.ToInt32(ddlPageSize.SelectedValue);
|
|||
|
|
this.Grid1.DataSource = ComponentJointList;
|
|||
|
|
this.Grid1.DataBind();
|
|||
|
|
Grid1.RecordCount = ComponentJointList.Count;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
private string GetCellValue(DataRow row, string columnName)
|
|||
|
|
{
|
|||
|
|
return Convert.ToString(row[columnName]).Replace("\n", "").Replace(" ", "").Replace("\t", "").Replace("\r", "").Trim();
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
public class ComponentJointImportItem
|
|||
|
|
{
|
|||
|
|
public string PipelineId { get; set; }
|
|||
|
|
|
|||
|
|
public string PipelineCode { get; set; }
|
|||
|
|
|
|||
|
|
public string PipelineComponentId { get; set; }
|
|||
|
|
|
|||
|
|
public string PipelineComponentCode { get; set; }
|
|||
|
|
|
|||
|
|
public string WeldJointId { get; set; }
|
|||
|
|
|
|||
|
|
public string WeldJointCode { get; set; }
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|