protected void grdLaterals_RowDataBound(object sender, GridViewRowEventArgs e) { if ((e.Row.RowType == DataControlRowType.DataRow) && ((e.Row.RowState == DataControlRowState.Normal) || (e.Row.RowState == (DataControlRowState.Normal | DataControlRowState.Alternate)))) { int lateral = int.Parse(((Label)e.Row.FindControl("lblLateral")).Text); if (lateral > 0) { RehabAssessmentLateralDetailsGateway gateway = new RehabAssessmentLateralDetailsGateway(rehabAssessmentTDS); ((TextBox)e.Row.FindControl("tbxMaterial")).Text = gateway.GetMaterialType(lateral); } } // Control of footer controls if (e.Row.RowType == DataControlRowType.Footer) { // For Material ((DropDownList)e.Row.FindControl("ddlNewMaterial")).SelectedIndex = 0; } // Control of edit controls if ((e.Row.RowType == DataControlRowType.DataRow) && ((e.Row.RowState == DataControlRowState.Edit) || (e.Row.RowState == (DataControlRowState.Edit | DataControlRowState.Alternate)))) { int lateral = int.Parse(((Label)e.Row.FindControl("lblLateral")).Text); if (lateral > 0) { RehabAssessmentLateralDetailsGateway gateway = new RehabAssessmentLateralDetailsGateway(rehabAssessmentTDS); int companyId = Int32.Parse(hdfCompanyId.Value); // ... Control material and connection type dropdownlists ((DropDownList)e.Row.FindControl("ddlMaterialEdit")).SelectedValue = gateway.GetMaterialType(lateral); ((DropDownList)e.Row.FindControl("ddlConnectionTypeEdit")).SelectedValue = gateway.GetConnectionType(lateral); // .... If lateral us used in junction lining if (gateway.GetInJlDatabase(lateral)) { if (!LateralsCouldBeDeletedInJl(lateral)) { ((CheckBox)e.Row.FindControl("cbxJlEdit")).Enabled = false; } } // ... Control live value int currentProjectId = Int32.Parse(hdfCurrentProjectId.Value); WorkGateway workGateway = new WorkGateway(); workGateway.LoadByProjectIdAssetIdWorkType(currentProjectId, lateral, "Junction Lining Lateral", companyId); // ... If lateral is not used in junction lining if (!workGateway.ExistsProjectIdAssetIdWorkTypeCompanyId(lateral, currentProjectId, "Junction Lining Lateral", companyId)) { ((DropDownList)e.Row.FindControl("ddlLiveEdit")).Visible = true; ((DropDownList)e.Row.FindControl("ddlLiveEdit")).SelectedValue = gateway.GetLive(lateral); ((TextBox)e.Row.FindControl("tbxJlLive")).Visible = false; } else { ((DropDownList)e.Row.FindControl("ddlLiveEdit")).Visible = false; ((TextBox)e.Row.FindControl("tbxJlLive")).Visible = true; } } } }