Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations derfloh on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

Need to Disable Navigation button

Status
Not open for further replies.

bubba100

Technical User
Nov 16, 2001
493
US
I have a Report that is giving me fits.

The report is referenced to a dynamic crosstab query. All the fields in the report are unbound. This report is modeled off of a report found in Solutions.mdb from Developers97.

The report DOES run and populate, that is not the problem. The problem occurs when the report is longer than one page. When I try to move more than just to the next page (to the end of the report) it Errors. The error is “Run Time error 3021. No Current Record”. The line where it errors is rstReport.Move Previous this is located in the SubDetail_Retreat. Moving one page at a time and no problem.

What would like to do is to disable the button. I have looked through this website, looked through my reference books and Googled but no luck.

Below is the code.

Thanks for your time.

Option Compare Database
Option Explicit

' Constant for maximum number of columns EmployeeSales query would
' create plus 1 for a Totals column.
Const conTotalColumns = 14

' Variables for Database object and Recordset.
Dim dbsReport As DATABASE
Dim rstReport As Recordset

' Variables for number of columns and row and report totals.
Dim intColumnCount As Integer
Dim lngRgColumnTotal(1 To conTotalColumns) As Long

Dim lngReportTotal As Long
Private Sub InitVars()

Dim intX As Integer

' Initialize lngReportTotal variable.
lngReportTotal = 0

' Initialize array that stores column totals.
For intX = 1 To conTotalColumns
lngRgColumnTotal(intX) = 0
Next intX

End Sub
Private Function xtabCnulls(varX As Variant)

' Test if a value is null.
If IsNull(varX) Then
' If varX is null, set varX to 0.
xtabCnulls = 0
Else
' Otherwise, return varX.
xtabCnulls = varX
End If

End Function

Private Sub Detail_Format(Cancel As Integer, FormatCount As Integer)
' Place values in text boxes and hide unused text boxes.

Dim intX As Integer
' Verify that not at end of recordset.
If Not rstReport.BOF Then
' If FormatCount is 1, place values from recordset into text boxes
' in detail section.
If Me.FormatCount = 1 Then
For intX = 1 To intColumnCount
' Convert Null values to 0.
Me("Col" + Format$(intX)) = xtabCnulls(rstReport(intX - 1))
Next intX


' Hide unused text boxes in detail section.
For intX = intColumnCount + 2 To conTotalColumns
Me("Col" + Format$(intX)).Visible = False
Next intX

' Move to next record in recordset.
rstReport.MovePrevious

End If
End If
End Sub

Private Sub Detail_Print(Cancel As Integer, PrintCount As Integer)

Dim intX As Integer
' Dim lngRowTotal As Long

' If PrintCount is 1, initialize lngRowTotal variable.
' Add to column totals.
' If Me.PrintCount = 1 Then
' lngRowTotal = 0

' For intX = 2 To intColumnCount
' Starting at column 2 (first text box with crosstab value),
' compute total for current row in detail section.
' lngRowTotal = lngRowTotal + Me("Col" + Format$(intX))

' Add crosstab value to total for current column.
' lngRgColumnTotal(intX) = lngRgColumnTotal(intX) + _
' Me("Col" + Format$(intX))
' Next intX

' Place row total in text box in detail section.
' Me("Col" + Format$(intColumnCount + 1)) = lngRowTotal
' Add row total for current row to grand total.
' lngReportTotal = lngReportTotal + lngRowTotal
' End If

End Sub

Private Sub Detail_Retreat()
' Always back up to previous record when detail section retreats.

rstReport.MovePrevious


End Sub

Private Sub PageFooter_Print(Cancel As Integer, PrintCount As Integer)

' Dim intX As Integer

' Place column totals in text boxes in report footer.
' Start at column 2 (first text box with crosstab value).
' For intX = 2 To intColumnCount
' Me("Tot" + Format$(intX)) = lngRgColumnTotal(intX)
' Next intX

' Place grand total in text box in report footer.
' Me("Tot" + Format$(intColumnCount + 1)) = lngReportTotal

' Hide unused text boxes in report footer.

'For intX = intColumnCount + 2 To conTotalColumns
' Me("Tot" + Format$(intX)).Visible = False
' Next intX

End Sub


Private Sub PageHeader_Format(Cancel As Integer, FormatCount As Integer)

Dim intX As Integer

' Put column headings into text boxes in page header.
For intX = 1 To intColumnCount
Me("Head" + Format$(intX)) = rstReport(intX - 1).Name
Next intX

' Make next available text box Totals heading.
' Me("Head" + Format$(intColumnCount + 1)) = "Totals"

' Hide unused text boxes in page header.
For intX = (intColumnCount + 2) To conTotalColumns
Me("Head" + Format$(intX)).Visible = False

Next intX

End Sub

Private Sub Report_Close()
Application.CommandBars("Print Preview").Visible = False
On Error Resume Next

' Close recordset.
rstReport.Close

End Sub



Private Sub Report_NoData(Cancel As Integer)
MsgBox "No records match the criteria you entered.", vbExclamation, "No Records Found"
rstReport.Close
Cancel = True

End Sub


Private Sub Report_Open(Cancel As Integer)
' Create underlying recordset for report by using criteria entered in
' EmployeeSalesDialogBox form.

Dim intX As Integer
Dim qdf As QueryDef
Application.CommandBars("Print Preview").Visible = True
Application.CommandBars("Print Preview").Position = msoBarTop
'.Next.Visible = False
' Don't open report if EmployeeSalesDialogBox form isn't loaded.
'If Not (IsLoaded("EmployeeSalesDialogBox")) Then
' Cancel = True
' MsgBox "To preview or print this report, you must open " _
' & "EmployeeSalesDialogBox in Form view.", vbExclamation, _
' "Must Open Dialog Box"

'Exit Sub
'End If

' Set database variable to current database.
Set dbsReport = currentDB

' Open QueryDef object.
Set qdf = dbsReport.QueryDefs("qrytblOdometersUnitJuris_CrosstabWKG")

' Set parameters for query based on values entered
' in EmployeeSalesDialogBox form.
'qdf.Parameters("Forms!EmployeeSalesDialogBox!BeginningDate") _
= Forms!EmployeeSalesDialogBox!BeginningDate
'qdf.Parameters("Forms!EmployeeSalesDialogBox!EndingDate") _
= Forms!EmployeeSalesDialogBox!EndingDate

' Open Recordset object.
Set rstReport = qdf.OpenRecordset()

' Set a variable to hold number of columns in crosstab query.
intColumnCount = rstReport.Fields.Count

End Sub

Private Sub ReportHeader_Format(Cancel As Integer, FormatCount As Integer)

' Move to first record in recordset at beginning of report
' or when report is restarted. (A report is restarted when
' you print a report from Print Preview window, or when you return
' to a previous page while previewing.)
rstReport.MoveLast

'Initialize variables.
InitVars

End Sub


 
Properties of the Report Look for control box set it to no
no more control box but are really sure

Hope this helps
Hymn
 
If you are referring to a Form where you can set the property of of the navigation button to No and this will turn then off you are correct.
But this is not an option on a report. That is why I need to turn the one off via code. Thanks anyway.
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top