This commit is contained in:
李云虎 2024-07-24 14:53:46 +08:00
parent b700f91cb6
commit 1e4464ca5e
8 changed files with 528 additions and 179 deletions

View File

@ -0,0 +1,68 @@
ALTER TABLE Transfer_PunchlistFrom ADD Num_NO BigInt NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD System_No NVARCHAR(50) NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Sub_Sys_No NVARCHAR(50) NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Cat NVARCHAR(50) NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Raised_By NVARCHAR(50) NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Date_Raised datetime NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Disc NVARCHAR(50) NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD IsEng bit NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD IsMatI bit NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Punch_Type NVARCHAR(50) NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Required_Date datetime NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD PIC NVARCHAR(50) NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD PIC_WUH NVARCHAR(50) NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Correction_Action NVARCHAR(500) NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Actual_Date datetime NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Cleared_By NVARCHAR(50) NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Cleared_Date datetime NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Confirmed_By NVARCHAR(50) NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Confirmed_Date datetime NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Verified_By NVARCHAR(50) NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Verified_Date datetime NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD [Status] NVARCHAR(50) NULL
GO
ALTER TABLE Transfer_PunchlistFrom ADD Remark NVARCHAR(500) NULL
GO

View File

@ -778,6 +778,13 @@ namespace FineUIPro.Web.AttachFile
} }
#endregion #endregion
#region PunchlistFrom附件保存成功后处理事件
if (MenuId == BLL.Const.PunchlistFromMenuId)
{
PageContext.RegisterStartupScript(ActiveWindow.GetHideRefreshReference());
}
#endregion
PageContext.RegisterStartupScript(ActiveWindow.GetHidePostBackReference()); PageContext.RegisterStartupScript(ActiveWindow.GetHidePostBackReference());
} }
} }

View File

@ -22,15 +22,15 @@
<f:Toolbar ID="ToolSearch" Position="Top" runat="server" ToolbarAlign="Left"> <f:Toolbar ID="ToolSearch" Position="Top" runat="server" ToolbarAlign="Left">
<Items> <Items>
<f:TextBox runat="server" ID="txtPunch_No" Label="Punch_No" LabelWidth="80px" LabelAlign="Right" Width="150px"></f:TextBox> <f:TextBox runat="server" ID="txtNum_NO" Label="No." LabelWidth="80px" LabelAlign="Right" Width="150px"></f:TextBox>
<f:TextBox runat="server" ID="txtSYSTEM" Label="SYSTEM" LabelWidth="80px" LabelAlign="Right" Width="150px"></f:TextBox> <f:TextBox runat="server" ID="txtSystem_No" Label="System No" LabelWidth="100px" LabelAlign="Right" Width="150px"></f:TextBox>
<f:TextBox runat="server" ID="txtSUBSYSTEM" Label="SUBSYSTEM" LabelWidth="100px" LabelAlign="Right" Width="170px"></f:TextBox> <f:TextBox runat="server" ID="txtSub_Sys_No" Label="Sub Sys No" LabelWidth="100px" LabelAlign="Right" Width="170px"></f:TextBox>
<f:DatePicker runat="server" Label="PUNCH_ITEM_FINISH_DATE" ID="txtStarTime" LabelAlign="Right" LabelWidth="200px" <f:DatePicker runat="server" Label="Date Raised" ID="txtStartDate_Raised" LabelAlign="Right" LabelWidth="200px"
Width="320px"> Width="320px">
</f:DatePicker> </f:DatePicker>
<f:Label ID="Label1" runat="server" Text="至"> <f:Label ID="Label1" runat="server" Text="至">
</f:Label> </f:Label>
<f:DatePicker runat="server" ID="txtEndTime" LabelAlign="Right" Width="150px"> <f:DatePicker runat="server" ID="txtEndDate_Raised" LabelAlign="Right" Width="150px">
</f:DatePicker> </f:DatePicker>
<f:Button ID="btnSearch" Icon="SystemSearch" EnablePostBack="true" runat="server" OnClick="btnSearch_Click" ToolTip="查询"> <f:Button ID="btnSearch" Icon="SystemSearch" EnablePostBack="true" runat="server" OnClick="btnSearch_Click" ToolTip="查询">
@ -40,56 +40,53 @@
<%-- <f:Button ID="btnNew" Icon="Add" EnablePostBack="true" runat="server" OnClick="btnNew_Click" ToolTip="新增" Hidden="true"> <%-- <f:Button ID="btnNew" Icon="Add" EnablePostBack="true" runat="server" OnClick="btnNew_Click" ToolTip="新增" Hidden="true">
</f:Button>--%> </f:Button>--%>
<f:Button ID="btnAttach" Icon="TableCell" EnablePostBack="true" ToolTip="附件上传" runat="server" OnClick="btnAttach_Click"> <%--<f:Button ID="btnAttach" Icon="TableCell" EnablePostBack="true" ToolTip="附件上传" runat="server" OnClick="btnAttach_Click">
</f:Button> </f:Button>--%>
<f:Button ID="btnImport" ToolTip="导入" Icon="PackageIn" runat="server" OnClick="btnImport_Click" Hidden="true"> <f:Button ID="btnImport" ToolTip="导入" Icon="PackageIn" runat="server" OnClick="btnImport_Click" Hidden="true">
</f:Button> </f:Button>
</Items> </Items>
</f:Toolbar> </f:Toolbar>
<f:Toolbar ID="Toolbar1" Position="Top" runat="server" ToolbarAlign="Left"> <f:Toolbar ID="Toolbar1" Position="Top" runat="server" ToolbarAlign="Left">
<Items> <Items>
<f:TextBox runat="server" ID="txtTestPackage" Label="Test Package" LabelWidth="105px" LabelAlign="Right" Width="300px"></f:TextBox> <f:DatePicker runat="server" Label="Required Date" ID="txtStartRequired_Date" LabelAlign="Right" LabelWidth="130px"
<f:TextBox runat="server" ID="txtDiscipline" Label="Discipline" LabelWidth="80px" LabelAlign="Right" Width="150px"></f:TextBox> Width="320px">
<f:TextBox runat="server" ID="txtIdentified" Label="Identified during/by" LabelWidth="150px" LabelAlign="Right" Width="300px"></f:TextBox> </f:DatePicker>
<f:TextBox runat="server" ID="txtCategory" Label="Select Punch List Category" LabelWidth="220px" LabelAlign="Right" Width="300px"></f:TextBox> <f:Label ID="Label2" runat="server" Text="至">
</f:Label>
<f:DatePicker runat="server" ID="txtEndRequired_Date" LabelAlign="Right" Width="150px">
</f:DatePicker>
<f:DatePicker runat="server" Label="Actual_Date" ID="txtStartActual_Date" LabelAlign="Right" LabelWidth="130px"
Width="320px">
</f:DatePicker>
<f:Label ID="Label3" runat="server" Text="至">
</f:Label>
<f:DatePicker runat="server" ID="txtEndActual_Date" LabelAlign="Right" Width="150px">
</f:DatePicker>
</Items> </Items>
</f:Toolbar> </f:Toolbar>
</Toolbars> </Toolbars>
<Columns> <Columns>
<f:GroupField HeaderText="PUNCH LIST FORM" TextAlign="Center"> <%--<f:GroupField HeaderText="PUNCH LIST FORM" TextAlign="Center">
<Columns> <Columns>
<f:BoundField Width="80px" TextAlign="Center" ColumnID="Item_No" DataField="Item_No" HeaderText="Item No." /> <f:BoundField Width="80px" TextAlign="Center" ColumnID="Item_No" DataField="Item_No" HeaderText="Item No." />
<f:BoundField Width="90px" TextAlign="Center" ColumnID="Punch_No" DataField="Punch_No" HeaderText="Punch No" /> <f:BoundField Width="90px" TextAlign="Center" ColumnID="Punch_No" DataField="Punch_No" HeaderText="Punch No" />
<f:BoundField Width="80px" TextAlign="Center" ColumnID="SystemName" DataField="SystemName" HeaderText="SYSTEM" /> <f:BoundField Width="80px" TextAlign="Center" ColumnID="SystemName" DataField="SystemName" HeaderText="SYSTEM" />
<f:BoundField Width="108px" ColumnID="Subsystem" DataField="Subsystem" HeaderText="SUBSYSTEM" TextAlign="Center"/> <f:BoundField Width="108px" ColumnID="Subsystem" DataField="Subsystem" HeaderText="SUBSYSTEM" TextAlign="Center"/>
<f:BoundField Width="140px" ColumnID="Test_Package" DataField="Test_Package" HeaderText="Test Package" TextAlign="Center"/> <f:BoundField Width="140px" ColumnID="Test_Package" DataField="Test_Package" HeaderText="Test Package" TextAlign="Center"/>
<f:BoundField Width="85px" ColumnID="Discipline" DataField="Discipline" HeaderText="Discipline" TextAlign="Center"/> <f:BoundField Width="85px" ColumnID="Discipline" DataField="Discipline" HeaderText="Discipline" TextAlign="Center"/>
<f:BoundField Width="250px" ColumnID="DESCRIPTION" DataField="DESCRIPTION" HeaderText="PUNCH LIST ITEM DESCRIPTION" TextAlign="Center"/> <f:BoundField Width="250px" ColumnID="DESCRIPTION" DataField="DESCRIPTION" HeaderText="PUNCH LIST ITEM DESCRIPTION" TextAlign="Center"/>
<f:BoundField Width="145px" ColumnID="Identified" DataField="Identified" HeaderText="Identified during/by" TextAlign="Center"/> <f:BoundField Width="145px" ColumnID="Identified" DataField="Identified" HeaderText="Identified during/by" TextAlign="Center"/>
<f:BoundField Width="110px" ColumnID="Category" DataField="Category" HeaderText="Select Punch<br/>List Category" TextAlign="Center"/> <f:BoundField Width="110px" ColumnID="Category" DataField="Category" HeaderText="Select Punch<br/>List Category" TextAlign="Center"/>
<f:RenderField Width="110px" ColumnID="PUNCH_ITEM_FINISH_DATE" DataField="PUNCH_ITEM_FINISH_DATE" <f:RenderField Width="110px" ColumnID="PUNCH_ITEM_FINISH_DATE" DataField="PUNCH_ITEM_FINISH_DATE"
HeaderText="PUNCH ITEM<br/>FINISH DATE" TextAlign="Center" HeaderText="PUNCH ITEM<br/>FINISH DATE" TextAlign="Center"
FieldType="Date" Renderer="Date" RendererArgument="yyyy-MM-dd"/> FieldType="Date" Renderer="Date" RendererArgument="yyyy-MM-dd"/>
<f:BoundField Width="100px" ColumnID="Action_By" DataField="Action_By" HeaderText="Action By" TextAlign="Center"/> <f:BoundField Width="100px" ColumnID="Action_By" DataField="Action_By" HeaderText="Action By" TextAlign="Center"/>
<f:BoundField Width="100px" ColumnID="Required_By" DataField="Required_By" HeaderText="Required By" TextAlign="Center"/> <f:BoundField Width="100px" ColumnID="Required_By" DataField="Required_By" HeaderText="Required By" TextAlign="Center"/>
<f:BoundField Width="110px" ColumnID="PUNCH_ITEM_STATUS" DataField="PUNCH_ITEM_STATUS" HeaderText="PUNCH ITEM<br/>STATUS" TextAlign="Center"/> <f:BoundField Width="110px" ColumnID="PUNCH_ITEM_STATUS" DataField="PUNCH_ITEM_STATUS" HeaderText="PUNCH ITEM<br/>STATUS" TextAlign="Center"/>
<f:BoundField Width="150px" ColumnID="Comments" DataField="Comments" HeaderText="Comments" TextAlign="Center"/> <f:BoundField Width="150px" ColumnID="Comments" DataField="Comments" HeaderText="Comments" TextAlign="Center"/>
</Columns> </Columns>
</f:GroupField> </f:GroupField>--%>
<%--<f:GroupField HeaderText="SYSTEM AND TEST PACKAGE SELECTION" TextAlign="Center" MinWidth="450"> <%--<f:GroupField HeaderText="SYSTEM AND TEST PACKAGE SELECTION" TextAlign="Center" MinWidth="450">
<Columns> <Columns>
@ -110,6 +107,84 @@
<f:BoundField MinWidth="200px" ColumnID="FINAL_Status" DataField="FINAL_Status" HeaderText="FINAL Status" TextAlign="Center"/>--%> <f:BoundField MinWidth="200px" ColumnID="FINAL_Status" DataField="FINAL_Status" HeaderText="FINAL Status" TextAlign="Center"/>--%>
<f:BoundField Width="100px" TextAlign="Center" ColumnID="Num_NO" DataField="Num_NO" HeaderText="No." />
<f:BoundField Width="150px" TextAlign="Center" ColumnID="System_No" DataField="System_No" HeaderText="System No." />
<f:BoundField Width="150px" TextAlign="Center" ColumnID="Sub_Sys_No" DataField="Sub_Sys_No" HeaderText="Sub-sys. No." />
<f:BoundField Width="150px" TextAlign="Center" ColumnID="DESCRIPTION" DataField="DESCRIPTION" HeaderText="Description" />
<f:TemplateField ColumnID="ImagePhotoes" Width="120px" HeaderText="Photoes" HeaderTextAlign="Center"
TextAlign="Left">
<ItemTemplate>
<asp:Label ID="lbPhotoesImageUrl" runat="server" Text='<%# ConvertImageUrlByImage(Eval("Id")+"_A") %>'></asp:Label>
</ItemTemplate>
</f:TemplateField>
<%--<f:BoundField Width="150px" TextAlign="Center" ColumnID="Photoes" DataField="Photoes" HeaderText="Photoes" />--%>
<f:BoundField Width="100px" TextAlign="Center" ColumnID="Cat" DataField="Cat" HeaderText="Cat." />
<f:BoundField Width="100px" TextAlign="Center" ColumnID="Raised_By" DataField="Raised_By" HeaderText="Raised By" />
<f:RenderField Width="100px" TextAlign="Center" ColumnID="Date_Raised" DataField="Date_Raised" HeaderText="Date Raised" FieldType="Date" Renderer="Date" RendererArgument="yyyy-MM-dd" />
<f:BoundField Width="100px" TextAlign="Center" ColumnID="Disc" DataField="Disc" HeaderText="Disc." />
<f:BoundField Width="100px" TextAlign="Center" ColumnID="IsEng" DataField="IsEngStr" HeaderText="Eng(Y/N)" />
<f:BoundField Width="100px" TextAlign="Center" ColumnID="IsMatI" DataField="IsMatIStr" HeaderText="Matl(Y/N)" />
<f:BoundField Width="100px" TextAlign="Center" ColumnID="Punch_Type" DataField="Punch_Type" HeaderText="Punch Type" />
<f:RenderField Width="150px" TextAlign="Center" ColumnID="Required_Date" DataField="Required_Date" HeaderText="Required Date" FieldType="Date" Renderer="Date" RendererArgument="yyyy-MM-dd" />
<f:BoundField Width="100px" TextAlign="Center" ColumnID="Action_By" DataField="Action_By" HeaderText="Action By" />
<f:BoundField Width="100px" TextAlign="Center" ColumnID="PIC" DataField="PIC" HeaderText="PIC" />
<f:BoundField Width="100px" TextAlign="Center" ColumnID="PIC_WUH" DataField="PIC_WUH" HeaderText="PIC-WUH" />
<f:BoundField Width="150px" TextAlign="Center" ColumnID="Correction_Action" DataField="Correction_Action" HeaderText="Correction Action" />
<f:TemplateField ColumnID="ImageCorrected_Photos" Width="150px" HeaderText="Corrected Photos" HeaderTextAlign="Center"
TextAlign="Left">
<ItemTemplate>
<asp:Label ID="labCorrected_Photos" runat="server" Text='<%# ConvertImageUrlByImage(Eval("Id")+"_B") %>'></asp:Label>
</ItemTemplate>
</f:TemplateField>
<%--<f:BoundField Width="150px" TextAlign="Center" ColumnID="Corrected_Photos" DataField="Corrected_Photos" HeaderText="Corrected Photos" />--%>
<f:RenderField Width="150px" TextAlign="Center" ColumnID="Actual_Date" DataField="Actual_Date" HeaderText="Actual Date" FieldType="Date" Renderer="Date" RendererArgument="yyyy-MM-dd" />
<f:GroupField HeaderText="Cleared(PIC" TextAlign="Center" MinWidth="200px">
<Columns>
<f:RenderField Width="100px" ColumnID="Cleared_By" DataField="Cleared_By" HeaderText="By" TextAlign="Center" />
<f:RenderField Width="100px" ColumnID="Cleared_Date" DataField="Cleared_Date" HeaderText="Date" TextAlign="Center"
FieldType="Date" Renderer="Date" RendererArgument="yyyy-MM-dd" />
</Columns>
</f:GroupField>
<f:GroupField HeaderText="Confirmed(WUH)" TextAlign="Center" MinWidth="200px">
<Columns>
<f:RenderField Width="100px" ColumnID="Confirmed_By" DataField="Confirmed_By" HeaderText="By" TextAlign="Center" />
<f:RenderField Width="100px" ColumnID="Confirmed_Date" DataField="Confirmed_Date" HeaderText="Date" TextAlign="Center"
FieldType="Date" Renderer="Date" RendererArgument="yyyy-MM-dd" />
</Columns>
</f:GroupField>
<f:GroupField HeaderText="Verified(BASF)" TextAlign="Center" MinWidth="200px">
<Columns>
<f:RenderField Width="100px" ColumnID="Verified_By" DataField="Verified_By" HeaderText="By" TextAlign="Center" />
<f:RenderField Width="100px" ColumnID="Verified_Date" DataField="Verified_Date" HeaderText="Date" TextAlign="Center"
FieldType="Date" Renderer="Date" RendererArgument="yyyy-MM-dd" />
</Columns>
</f:GroupField>
<f:BoundField Width="80px" TextAlign="Center" ColumnID="Status" DataField="Status" HeaderText="Status" />
<f:BoundField Width="80px" TextAlign="Center" ColumnID="Remark" DataField="Remark" HeaderText="Remark" />
</Columns> </Columns>
<Listeners> <Listeners>
<f:Listener Event="beforerowcontextmenu" Handler="onRowContextMenu" /> <f:Listener Event="beforerowcontextmenu" Handler="onRowContextMenu" />
@ -143,6 +218,10 @@
<f:MenuButton ID="btnMenuDel" EnablePostBack="true" runat="server" Icon="Delete" Text="删除" ConfirmText="确定删除当前数据?" <f:MenuButton ID="btnMenuDel" EnablePostBack="true" runat="server" Icon="Delete" Text="删除" ConfirmText="确定删除当前数据?"
OnClick="btnMenuDel_Click" Hidden="true"> OnClick="btnMenuDel_Click" Hidden="true">
</f:MenuButton> </f:MenuButton>
<f:MenuButton ID="btnMenuAttachA" runat="server" Icon="FolderUp" Text="Photoes附件" OnClick="btnMenuAttachA_Click" Hidden="true">
</f:MenuButton>
<f:MenuButton ID="btnMenuAttachB" runat="server" Icon="FolderUp" Text="Corrected_Photos附件" OnClick="btnMenuAttachB_Click" Hidden="true">
</f:MenuButton>
</Items> </Items>
</f:Menu> </f:Menu>
</form> </form>

View File

@ -30,57 +30,60 @@ namespace FineUIPro.Web.Transfer
/// </summary> /// </summary>
public void BindGrid() public void BindGrid()
{ {
string strSql = @"select*from Transfer_PunchlistFrom string strSql = @"select *
,(CASE isnull(IsEng,0) WHEN 1 THEN 'Y' ELSE 'N' END) IsEngStr
,(CASE isnull(IsMatI,0) WHEN 1 THEN 'Y' ELSE 'N' END) IsMatIStr
from Transfer_PunchlistFrom
where ProjectId = @ProjectId"; where ProjectId = @ProjectId";
List<SqlParameter> listStr = new List<SqlParameter>(); List<SqlParameter> listStr = new List<SqlParameter>();
listStr.Add(new SqlParameter("@ProjectId", this.CurrUser.LoginProjectId)); listStr.Add(new SqlParameter("@ProjectId", this.CurrUser.LoginProjectId));
if (!string.IsNullOrEmpty(this.txtPunch_No.Text.Trim())) if (!string.IsNullOrEmpty(this.txtNum_NO.Text.Trim()))
{ {
strSql += " AND Punch_No like @Punch_No"; strSql += " AND Num_NO like @Num_NO";
listStr.Add(new SqlParameter("@Punch_No", "%" + this.txtPunch_No.Text.Trim() + "%")); listStr.Add(new SqlParameter("@Num_NO", "%" + this.txtNum_NO.Text.Trim() + "%"));
} }
if (!string.IsNullOrEmpty(this.txtSYSTEM.Text.Trim())) if (!string.IsNullOrEmpty(this.txtSystem_No.Text.Trim()))
{ {
strSql += " AND SystemName like @SystemName"; strSql += " AND System_No like @System_No";
listStr.Add(new SqlParameter("@SystemName", "%" + this.txtSYSTEM.Text.Trim() + "%")); listStr.Add(new SqlParameter("@System_No", "%" + this.txtSystem_No.Text.Trim() + "%"));
} }
if (!string.IsNullOrEmpty(this.txtSUBSYSTEM.Text.Trim())) if (!string.IsNullOrEmpty(this.txtSub_Sys_No.Text.Trim()))
{ {
strSql += " AND Subsystem like @Subsystem"; strSql += " AND Sub_Sys_No like @Sub_Sys_No";
listStr.Add(new SqlParameter("@Subsystem", "%" + this.txtSUBSYSTEM.Text.Trim() + "%")); listStr.Add(new SqlParameter("@Sub_Sys_No", "%" + this.txtSub_Sys_No.Text.Trim() + "%"));
} }
if (!string.IsNullOrEmpty(txtStarTime.Text.Trim())) if (!string.IsNullOrEmpty(txtStartDate_Raised.Text.Trim()))
{ {
strSql += " AND PUNCH_ITEM_FINISH_DATE >= @InspectionDateA"; strSql += " AND Date_Raised >= @StartDate_Raised";
listStr.Add(new SqlParameter("@InspectionDateA", Funs.GetNewDateTime(txtStarTime.Text.Trim()))); listStr.Add(new SqlParameter("@StartDate_Raised", Funs.GetNewDateTime(txtStartDate_Raised.Text.Trim())));
} }
if (!string.IsNullOrEmpty(txtEndTime.Text.Trim())) if (!string.IsNullOrEmpty(txtEndDate_Raised.Text.Trim()))
{ {
strSql += " AND PUNCH_ITEM_FINISH_DATE <= @InspectionDateZ"; strSql += " AND Date_Raised <= @EndDate_Raised";
listStr.Add(new SqlParameter("@InspectionDateZ", Funs.GetNewDateTime(txtEndTime.Text.Trim()))); listStr.Add(new SqlParameter("@EndDate_Raised", Funs.GetNewDateTime(txtEndDate_Raised.Text.Trim())));
} }
if (!string.IsNullOrEmpty(this.txtTestPackage.Text.Trim())) if (!string.IsNullOrEmpty(txtStartRequired_Date.Text.Trim()))
{ {
strSql += " AND Test_Package like @Test_Package"; strSql += " AND Required_Date >= @Required_Date";
listStr.Add(new SqlParameter("@Test_Package", "%" + this.txtTestPackage.Text.Trim() + "%")); listStr.Add(new SqlParameter("@Required_Date", Funs.GetNewDateTime(txtStartRequired_Date.Text.Trim())));
} }
if (!string.IsNullOrEmpty(this.txtDiscipline.Text.Trim())) if (!string.IsNullOrEmpty(txtEndRequired_Date.Text.Trim()))
{ {
strSql += " AND Discipline like @Discipline"; strSql += " AND Required_Date <= @Required_Date";
listStr.Add(new SqlParameter("@Discipline", "%" + this.txtDiscipline.Text.Trim() + "%")); listStr.Add(new SqlParameter("@Required_Date", Funs.GetNewDateTime(txtEndRequired_Date.Text.Trim())));
} }
if (!string.IsNullOrEmpty(this.txtIdentified.Text.Trim())) if (!string.IsNullOrEmpty(txtStartActual_Date.Text.Trim()))
{ {
strSql += " AND Identified like @Identified"; strSql += " AND Actual_Date >= @Actual_Date";
listStr.Add(new SqlParameter("@Identified", "%" + this.txtIdentified.Text.Trim() + "%")); listStr.Add(new SqlParameter("@Actual_Date", Funs.GetNewDateTime(txtStartActual_Date.Text.Trim())));
} }
if (!string.IsNullOrEmpty(this.txtCategory.Text.Trim())) if (!string.IsNullOrEmpty(txtEndActual_Date.Text.Trim()))
{ {
strSql += " AND Category like @Category"; strSql += " AND Actual_Date <= @Actual_Date";
listStr.Add(new SqlParameter("@Category", "%" + this.txtCategory.Text.Trim() + "%")); listStr.Add(new SqlParameter("@Actual_Date", Funs.GetNewDateTime(txtEndActual_Date.Text.Trim())));
} }
strSql += " order by Punch_No "; strSql += " order by Num_No ";
SqlParameter[] parameter = listStr.ToArray(); SqlParameter[] parameter = listStr.ToArray();
DataTable tb = SQLHelper.GetDataTableRunText(strSql, parameter); DataTable tb = SQLHelper.GetDataTableRunText(strSql, parameter);
Grid1.RecordCount = tb.Rows.Count; Grid1.RecordCount = tb.Rows.Count;
@ -175,6 +178,56 @@ namespace FineUIPro.Web.Transfer
} }
#endregion #endregion
#region Photoes附件
/// <summary>
/// 右键附件上传功能
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnMenuAttachA_Click(object sender, EventArgs e)
{
if (Grid1.SelectedRowIndexArray.Length > 0)
{
PageContext.RegisterStartupScript(WindowAtt.GetShowReference(String.Format("../AttachFile/webuploader.aspx?type=0&toKeyId={0}_A&path=FileUpload/Transfer/PunchlistFrom&menuId={1}", Grid1.SelectedRowID, BLL.Const.PunchlistFromMenuId)));
}
}
#endregion
#region Corrected_Photos附件
/// <summary>
/// 右键附件上传功能
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnMenuAttachB_Click(object sender, EventArgs e)
{
if (Grid1.SelectedRowIndexArray.Length > 0)
{
PageContext.RegisterStartupScript(WindowAtt.GetShowReference(String.Format("../AttachFile/webuploader.aspx?type=0&toKeyId={0}_B&path=FileUpload/Transfer/PunchlistFrom&menuId={1}", Grid1.SelectedRowID, BLL.Const.PunchlistFromMenuId)));
}
}
#endregion
/// <summary>
/// 获取附件(放于Img中)
/// </summary>
/// <param name="Id_type"></param>
/// <returns></returns>
protected string ConvertImageUrlByImage(object Id_type)
{
string url = string.Empty;
if (Id_type != null)
{
var registration = BLL.AttachFileService.GetAttachFile(Id_type.ToString(), BLL.Const.PunchlistFromMenuId);
if (registration != null)
{
url = BLL.UploadAttachmentService.ShowImage("../../", registration.AttachUrl);
}
}
return url;
}
#region #region
/// <summary> /// <summary>
/// 导入按钮 /// 导入按钮
@ -205,11 +258,15 @@ namespace FineUIPro.Web.Transfer
if (buttonList.Contains(BLL.Const.BtnAdd)) if (buttonList.Contains(BLL.Const.BtnAdd))
{ {
//this.btnNew.Hidden = false; //this.btnNew.Hidden = false;
btnMenuAttachA.Hidden=false;
btnMenuAttachB.Hidden = false;
} }
if (buttonList.Contains(BLL.Const.BtnModify)) if (buttonList.Contains(BLL.Const.BtnModify))
{ {
//this.btnMenuModify.Hidden = false; //this.btnMenuModify.Hidden = false;
this.Grid1.EnableRowDoubleClickEvent = true; this.Grid1.EnableRowDoubleClickEvent = true;
btnMenuAttachA.Hidden = false;
btnMenuAttachB.Hidden = false;
} }
else else
{ {

View File

@ -7,10 +7,12 @@
// </自动生成> // </自动生成>
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
namespace FineUIPro.Web.Transfer { namespace FineUIPro.Web.Transfer
{
public partial class PunchlistFrom { public partial class PunchlistFrom
{
/// <summary> /// <summary>
/// form1 控件。 /// form1 控件。
@ -58,40 +60,40 @@ namespace FineUIPro.Web.Transfer {
protected global::FineUIPro.Toolbar ToolSearch; protected global::FineUIPro.Toolbar ToolSearch;
/// <summary> /// <summary>
/// txtPunch_No 控件。 /// txtNum_NO 控件。
/// </summary> /// </summary>
/// <remarks> /// <remarks>
/// 自动生成的字段。 /// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。 /// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks> /// </remarks>
protected global::FineUIPro.TextBox txtPunch_No; protected global::FineUIPro.TextBox txtNum_NO;
/// <summary> /// <summary>
/// txtSYSTEM 控件。 /// txtSystem_No 控件。
/// </summary> /// </summary>
/// <remarks> /// <remarks>
/// 自动生成的字段。 /// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。 /// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks> /// </remarks>
protected global::FineUIPro.TextBox txtSYSTEM; protected global::FineUIPro.TextBox txtSystem_No;
/// <summary> /// <summary>
/// txtSUBSYSTEM 控件。 /// txtSub_Sys_No 控件。
/// </summary> /// </summary>
/// <remarks> /// <remarks>
/// 自动生成的字段。 /// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。 /// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks> /// </remarks>
protected global::FineUIPro.TextBox txtSUBSYSTEM; protected global::FineUIPro.TextBox txtSub_Sys_No;
/// <summary> /// <summary>
/// txtStarTime 控件。 /// txtStartDate_Raised 控件。
/// </summary> /// </summary>
/// <remarks> /// <remarks>
/// 自动生成的字段。 /// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。 /// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks> /// </remarks>
protected global::FineUIPro.DatePicker txtStarTime; protected global::FineUIPro.DatePicker txtStartDate_Raised;
/// <summary> /// <summary>
/// Label1 控件。 /// Label1 控件。
@ -103,13 +105,13 @@ namespace FineUIPro.Web.Transfer {
protected global::FineUIPro.Label Label1; protected global::FineUIPro.Label Label1;
/// <summary> /// <summary>
/// txtEndTime 控件。 /// txtEndDate_Raised 控件。
/// </summary> /// </summary>
/// <remarks> /// <remarks>
/// 自动生成的字段。 /// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。 /// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks> /// </remarks>
protected global::FineUIPro.DatePicker txtEndTime; protected global::FineUIPro.DatePicker txtEndDate_Raised;
/// <summary> /// <summary>
/// btnSearch 控件。 /// btnSearch 控件。
@ -120,15 +122,6 @@ namespace FineUIPro.Web.Transfer {
/// </remarks> /// </remarks>
protected global::FineUIPro.Button btnSearch; protected global::FineUIPro.Button btnSearch;
/// <summary>
/// btnAttach 控件。
/// </summary>
/// <remarks>
/// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks>
protected global::FineUIPro.Button btnAttach;
/// <summary> /// <summary>
/// btnImport 控件。 /// btnImport 控件。
/// </summary> /// </summary>
@ -148,40 +141,76 @@ namespace FineUIPro.Web.Transfer {
protected global::FineUIPro.Toolbar Toolbar1; protected global::FineUIPro.Toolbar Toolbar1;
/// <summary> /// <summary>
/// txtTestPackage 控件。 /// txtStartRequired_Date 控件。
/// </summary> /// </summary>
/// <remarks> /// <remarks>
/// 自动生成的字段。 /// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。 /// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks> /// </remarks>
protected global::FineUIPro.TextBox txtTestPackage; protected global::FineUIPro.DatePicker txtStartRequired_Date;
/// <summary> /// <summary>
/// txtDiscipline 控件。 /// Label2 控件。
/// </summary> /// </summary>
/// <remarks> /// <remarks>
/// 自动生成的字段。 /// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。 /// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks> /// </remarks>
protected global::FineUIPro.TextBox txtDiscipline; protected global::FineUIPro.Label Label2;
/// <summary> /// <summary>
/// txtIdentified 控件。 /// txtEndRequired_Date 控件。
/// </summary> /// </summary>
/// <remarks> /// <remarks>
/// 自动生成的字段。 /// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。 /// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks> /// </remarks>
protected global::FineUIPro.TextBox txtIdentified; protected global::FineUIPro.DatePicker txtEndRequired_Date;
/// <summary> /// <summary>
/// txtCategory 控件。 /// txtStartActual_Date 控件。
/// </summary> /// </summary>
/// <remarks> /// <remarks>
/// 自动生成的字段。 /// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。 /// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks> /// </remarks>
protected global::FineUIPro.TextBox txtCategory; protected global::FineUIPro.DatePicker txtStartActual_Date;
/// <summary>
/// Label3 控件。
/// </summary>
/// <remarks>
/// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks>
protected global::FineUIPro.Label Label3;
/// <summary>
/// txtEndActual_Date 控件。
/// </summary>
/// <remarks>
/// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks>
protected global::FineUIPro.DatePicker txtEndActual_Date;
/// <summary>
/// lbPhotoesImageUrl 控件。
/// </summary>
/// <remarks>
/// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks>
protected global::System.Web.UI.WebControls.Label lbPhotoesImageUrl;
/// <summary>
/// labCorrected_Photos 控件。
/// </summary>
/// <remarks>
/// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks>
protected global::System.Web.UI.WebControls.Label labCorrected_Photos;
/// <summary> /// <summary>
/// ToolbarText1 控件。 /// ToolbarText1 控件。
@ -236,5 +265,23 @@ namespace FineUIPro.Web.Transfer {
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。 /// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks> /// </remarks>
protected global::FineUIPro.MenuButton btnMenuDel; protected global::FineUIPro.MenuButton btnMenuDel;
/// <summary>
/// btnMenuAttachA 控件。
/// </summary>
/// <remarks>
/// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks>
protected global::FineUIPro.MenuButton btnMenuAttachA;
/// <summary>
/// btnMenuAttachB 控件。
/// </summary>
/// <remarks>
/// 自动生成的字段。
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
/// </remarks>
protected global::FineUIPro.MenuButton btnMenuAttachB;
} }
} }

View File

@ -130,7 +130,7 @@ namespace FineUIPro.Web.Transfer
oleDBConn.Close(); oleDBConn.Close();
oleDBConn.Dispose(); oleDBConn.Dispose();
AddDatasetToSQL(ds.Tables[0], 14); AddDatasetToSQL(ds.Tables[0], 24);
hdCheckResult.Text = "1"; hdCheckResult.Text = "1";
} }
catch (Exception exc) catch (Exception exc)
@ -168,18 +168,99 @@ namespace FineUIPro.Web.Transfer
{ {
for (int i = 1; i < ir; i++) for (int i = 1; i < ir; i++)
{ {
string row4 = pds.Rows[i][9].ToString(); string allRowData = string.Empty;
if (!string.IsNullOrEmpty(row4)) for (int j = 0; j < 24; j++)
{
allRowData += pds.Rows[i][j].ToString();
}
if (string.IsNullOrWhiteSpace(allRowData))
continue;
string row3 = pds.Rows[i][3].ToString();
if (row3 != "" && row3 != "A" && row3 != "B" && row3 != "C" && row3 != "D")
{
result += (i + 2).ToString() + "," + " Cat. " + "," + "[" + row3 + "]错误不是ABCD" + "|";
}
string row5 = pds.Rows[i][5].ToString();
if (!string.IsNullOrEmpty(row5))
{ {
try try
{ {
DateTime date = Convert.ToDateTime(row4.Trim()); DateTime date = Convert.ToDateTime(row5.Trim());
} }
catch (Exception) catch (Exception)
{ {
result += (i + 2).ToString() + "," + "PUNCH ITEM FINISH DATE" + "," + "[" + row4 + "]错误!不是日期格式!" + "|"; result += (i + 2).ToString() + "," + " Date Raised " + "," + "[" + row5 + "]错误!不是日期格式!" + "|";
} }
} }
string row10 = pds.Rows[i][10].ToString();
if (!string.IsNullOrEmpty(row10))
{
try
{
DateTime date = Convert.ToDateTime(row10.Trim());
}
catch (Exception)
{
result += (i + 2).ToString() + "," + " Required Date " + "," + "[" + row10 + "]错误!不是日期格式!" + "|";
}
}
string row15 = pds.Rows[i][15].ToString();
if (!string.IsNullOrEmpty(row15))
{
try
{
DateTime date = Convert.ToDateTime(row15.Trim());
}
catch (Exception)
{
result += (i + 2).ToString() + "," + " Actual Date " + "," + "[" + row15 + "]错误!不是日期格式!" + "|";
}
}
string row17 = pds.Rows[i][17].ToString();
if (!string.IsNullOrEmpty(row17))
{
try
{
DateTime date = Convert.ToDateTime(row17.Trim());
}
catch (Exception)
{
result += (i + 2).ToString() + "," + " Cleared(PIC Date " + "," + "[" + row17 + "]错误!不是日期格式!" + "|";
}
}
string row19 = pds.Rows[i][19].ToString();
if (!string.IsNullOrEmpty(row19))
{
try
{
DateTime date = Convert.ToDateTime(row19.Trim());
}
catch (Exception)
{
result += (i + 2).ToString() + "," + " Confirmed(WUH) Date " + "," + "[" + row19 + "]错误!不是日期格式!" + "|";
}
}
string row21 = pds.Rows[i][21].ToString();
if (!string.IsNullOrEmpty(row21))
{
try
{
DateTime date = Convert.ToDateTime(row21.Trim());
}
catch (Exception)
{
result += (i + 2).ToString() + "," + " Verified(BASF) Date " + "," + "[" + row21 + "]错误!不是日期格式!" + "|";
}
}
} }
if (!string.IsNullOrEmpty(result)) if (!string.IsNullOrEmpty(result))
{ {
@ -286,7 +367,7 @@ namespace FineUIPro.Web.Transfer
oleDBConn.Close(); oleDBConn.Close();
oleDBConn.Dispose(); oleDBConn.Dispose();
AddDatasetToSQL2(ds.Tables[0], 14); AddDatasetToSQL2(ds.Tables[0], 24);
} }
catch (Exception ex) catch (Exception ex)
{ {
@ -312,6 +393,7 @@ namespace FineUIPro.Web.Transfer
} }
string result = string.Empty; string result = string.Empty;
ir = pds.Rows.Count; ir = pds.Rows.Count;
long? maxNumNO = -1;
if (pds != null && ir > 0) if (pds != null && ir > 0)
{ {
List<Model.Transfer_PunchlistFrom> list = new List<Model.Transfer_PunchlistFrom>(); List<Model.Transfer_PunchlistFrom> list = new List<Model.Transfer_PunchlistFrom>();
@ -320,57 +402,66 @@ namespace FineUIPro.Web.Transfer
if (!string.IsNullOrEmpty(pds.Rows[i][1].ToString().Trim())) if (!string.IsNullOrEmpty(pds.Rows[i][1].ToString().Trim()))
{ {
//查询第一列,没查到的情况下作导入处理 //查询第一列,没查到的情况下作导入处理
var modelOnly = Funs.DB.Transfer_PunchlistFrom.FirstOrDefault(x => x.Punch_No == pds.Rows[i][1].ToString().Trim() if (maxNumNO == -1) {
&& x.ProjectId == CurrUser.LoginProjectId); maxNumNO = Funs.DB.Transfer_PunchlistFrom.Where(x => x.ProjectId == CurrUser.LoginProjectId).Max(p => p.Num_NO);
if (modelOnly == null) if (maxNumNO == null)
{ maxNumNO = 1001;
}
Model.Transfer_PunchlistFrom model = new Model.Transfer_PunchlistFrom(); Model.Transfer_PunchlistFrom model = new Model.Transfer_PunchlistFrom();
model.Id = Guid.NewGuid().ToString(); model.Id = Guid.NewGuid().ToString();
model.ProjectId = CurrUser.LoginProjectId; model.ProjectId = CurrUser.LoginProjectId;
model.Item_No = pds.Rows[i][0].ToString().Trim(); model.Num_NO = maxNumNO;
model.Punch_No = pds.Rows[i][1].ToString().Trim(); model.System_No = pds.Rows[i][0].ToString().Trim();
model.SystemName = pds.Rows[i][2].ToString().Trim(); model.Sub_Sys_No = pds.Rows[i][1].ToString().Trim();
model.Subsystem = pds.Rows[i][3].ToString().Trim(); model.DESCRIPTION = pds.Rows[i][2].ToString().Trim();
model.Test_Package = pds.Rows[i][4].ToString().Trim(); model.Cat = pds.Rows[i][3].ToString().Trim();
model.Discipline = pds.Rows[i][5].ToString().Trim(); model.Raised_By = pds.Rows[i][4].ToString().Trim();
model.DESCRIPTION = pds.Rows[i][6].ToString().Trim(); DateTime t5;
model.Identified = pds.Rows[i][7].ToString().Trim(); if (DateTime.TryParse(pds.Rows[i][5].ToString(), out t5) && !string.IsNullOrEmpty(pds.Rows[i][5].ToString()))
model.Category = pds.Rows[i][8].ToString().Trim(); model.Date_Raised = t5;
DateTime t1;
if (DateTime.TryParse(pds.Rows[i][9].ToString(), out t1) && !string.IsNullOrEmpty(pds.Rows[i][9].ToString()))
model.PUNCH_ITEM_FINISH_DATE = t1;
model.Disc = pds.Rows[i][6].ToString().Trim();
model.Action_By = pds.Rows[i][10].ToString().Trim(); if (pds.Rows[i][7].ToString().Trim().Contains("Y"))
model.Required_By = pds.Rows[i][11].ToString().Trim(); model.IsEng = true;
model.PUNCH_ITEM_STATUS = pds.Rows[i][12].ToString().Trim();
model.Comments = pds.Rows[i][13].ToString().Trim();
list.Add(model);
}
else else
{ model.IsEng = false;
//修改
modelOnly.Item_No = pds.Rows[i][0].ToString().Trim(); if (pds.Rows[i][8].ToString().Trim().Contains("Y"))
modelOnly.Punch_No = pds.Rows[i][1].ToString().Trim(); model.IsMatI = true;
modelOnly.SystemName = pds.Rows[i][2].ToString().Trim(); else
modelOnly.Subsystem = pds.Rows[i][3].ToString().Trim(); model.IsMatI = false;
modelOnly.Test_Package = pds.Rows[i][4].ToString().Trim(); model.Punch_Type = pds.Rows[i][9].ToString().Trim();
modelOnly.Discipline = pds.Rows[i][5].ToString().Trim(); DateTime t10;
modelOnly.DESCRIPTION = pds.Rows[i][6].ToString().Trim(); if (DateTime.TryParse(pds.Rows[i][10].ToString(), out t10) && !string.IsNullOrEmpty(pds.Rows[i][10].ToString()))
modelOnly.Identified = pds.Rows[i][7].ToString().Trim(); model.Required_Date = t10;
modelOnly.Category = pds.Rows[i][8].ToString().Trim(); model.Action_By = pds.Rows[i][11].ToString().Trim();
DateTime t1; model.PIC = pds.Rows[i][12].ToString().Trim();
if (DateTime.TryParse(pds.Rows[i][9].ToString(), out t1) && !string.IsNullOrEmpty(pds.Rows[i][9].ToString())) model.PIC_WUH = pds.Rows[i][13].ToString().Trim();
modelOnly.PUNCH_ITEM_FINISH_DATE = t1; model.Correction_Action = pds.Rows[i][14].ToString().Trim();
modelOnly.Action_By = pds.Rows[i][10].ToString().Trim(); DateTime t15;
modelOnly.Required_By = pds.Rows[i][11].ToString().Trim(); if (DateTime.TryParse(pds.Rows[i][15].ToString(), out t15) && !string.IsNullOrEmpty(pds.Rows[i][15].ToString()))
modelOnly.PUNCH_ITEM_STATUS = pds.Rows[i][12].ToString().Trim(); model.PUNCH_ITEM_FINISH_DATE = t15;
modelOnly.Comments = pds.Rows[i][13].ToString().Trim(); model.Cleared_By = pds.Rows[i][16].ToString().Trim();
Funs.DB.SubmitChanges(); DateTime t17;
} if (DateTime.TryParse(pds.Rows[i][17].ToString(), out t17) && !string.IsNullOrEmpty(pds.Rows[i][17].ToString()))
model.Cleared_Date = t17;
model.Confirmed_By = pds.Rows[i][18].ToString().Trim();
DateTime t19;
if (DateTime.TryParse(pds.Rows[i][19].ToString(), out t19) && !string.IsNullOrEmpty(pds.Rows[i][19].ToString()))
model.Confirmed_Date = t19;
model.Verified_By = pds.Rows[i][20].ToString().Trim();
DateTime t21;
if (DateTime.TryParse(pds.Rows[i][21].ToString(), out t21) && !string.IsNullOrEmpty(pds.Rows[i][21].ToString()))
model.Verified_Date = t21;
model.Status = pds.Rows[i][22].ToString().Trim();
model.Remark = pds.Rows[i][23].ToString().Trim();
list.Add(model);
maxNumNO++;
} }
} }
if (list.Count > 0) if (list.Count > 0)