protected void tbxVideoLength_TextChanged(object sender, EventArgs e) { int workId = Int32.Parse(hdfWorkId.Value); int assetId = Int32.Parse(hdfAssetId.Value); string videoLength = tbxVideoLength.Text.Trim(); // Update distance from dsmh and reverse setup FullLengthLiningLateralDetails fullLengthLiningLateralDetails = new FullLengthLiningLateralDetails(fullLengthLiningTDS); fullLengthLiningLateralDetails.UpdateLengthReverseSetup(workId, assetId, videoLength); // Store dataset Session["fullLengthLiningTDS"] = fullLengthLiningTDS; for (int i = 0; i < grdLaterals.Rows.Count; i++) { if ((grdLaterals.Rows[i].RowType == DataControlRowType.DataRow) && ((grdLaterals.Rows[i].RowState == DataControlRowState.Normal) || (grdLaterals.Rows[i].RowState == (DataControlRowState.Normal | DataControlRowState.Alternate)))) { // Reverse Setup calculation string videoDistance = ((TextBox)grdLaterals.Rows[i].Cells[2].FindControl("tbxVideoDistance")).Text.Trim(); string reverseSetup = ""; if (videoDistance != "") { Distance videoLengthD = new Distance(tbxVideoLength.Text.Trim()); Distance videoDistanceD = new Distance(videoDistance); Distance reverseSetupD = videoLengthD - videoDistanceD; switch (videoDistanceD.DistanceType) { case 1: reverseSetup = reverseSetupD.ToStringInEng1(); break; case 2: reverseSetup = reverseSetupD.ToStringInEng2(); break; case 3: reverseSetup = reverseSetupD.ToStringInEng3(); break; case 4: reverseSetup = reverseSetupD.ToStringInMet1(); break; case 5: reverseSetup = reverseSetupD.ToStringInMil1(); break; } } reverseSetup = GetDistance(reverseSetup); ((TextBox)grdLaterals.Rows[i].Cells[2].FindControl("tbxReverseSetup")).Text = reverseSetup; } } }