?
Solved

Open Form from vba module

Posted on 2004-03-21
3
Medium Priority
?
846 Views
Last Modified: 2008-02-01
Hi

I have a switchboard (form) with a project name and number that is stored in a table (project_info).

The switchboard is the first form that opens (set in the startup options menu).

I have a form for users to enter the project name and number (called Project_details). This only needs to be entered once for the life of the database (until it is used for a new project).

If there is no project name or number in the table then the code that fetches the number onto the form comes up with an error because there is no recordset in the empty project_info table.

I want to either:-

a) open the project_details form on the first time to get the users to fill in the form, before the switchboard comes up. But I can't see how to programatically change startup options without having opened the database once already.

b) get the vb function I have written to get the name and number on the switchboard to open the form if there are no records in the table. I have tried using the
DoCmd.OpenForm ("Project_details") in my vb function.

This works if the procedure is run from the vb module but when I try to run it by opening the switchboard (which calls the getProjNumber function via a text box) I get the message "You can't carry out this action at the present time" and the debugger highlights the DoCmd line.

Does anyone have any ideas or do I have to just resign myself to the fact that I'm trying the impossible?!

Here is my function (in the modules section)
Function GetProjectName()

    Dim rstName As ADODB.Recordset
           
    Set rstName = New ADODB.Recordset
        rstName.Open "Project_details", CurrentProject.Connection, adOpenKeyset, adLockOptimistic
       

    If (rstName.BOF = True) Or (rstName.EOF = True) Then
        rstName.Close
   
        DoCmd.OpenForm "Project_details"
   
   Else
    GetProjectName = rstName!Project_name
    rstName.Close
   End If
     
End Function
0
Comment
Question by:willmottj
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
3 Comments
 
LVL 14

Accepted Solution

by:
bluelizard earned 1000 total points
ID: 10646971
i'd do the following:

in the original database (i.e., in the version that the users initially opens), make the project_details form the startup form.  in that form, when the users clicks OK, programmatically modify the startup form...:

  Dim wdb As Database
  Set wdb = CurrentDb
  wdb.Properties("StartupForm") = “MySwitchboardForm”
  Set wdb = Nothing

...and go to the switchboard:

  DoCmd.OpenForm “MySwitchboardForm”
  DoCmd.Close acForm, “project_details”, acSaveNo


(note: the above code to change the properties requires the DAO object library; if necessary, install it with "Tools > References" from a VB window)


--bluelizard
0
 
LVL 1

Expert Comment

by:ajysen
ID: 10649085
you can do the following, insert the below code in the Vb module and set the Project properties --> Startup Object to Sub Main.

Public Sub main()
     Open your connection here
    call GetProjectName
End Sub

by doing so u have set the startup object to Sub main, where u are opening ur connection, once ur connection is open u can manipulate ur code depending upon ur needs.This will work.
0
 

Author Comment

by:willmottj
ID: 10653333
Thanks bluelizard. This solution actually dawned on me whilst discussing this problem with a friend after work yesterday. But it's good to see what the code will look like.

Thanks
willmottj
0

Featured Post

Veeam Task Manager for Hyper-V

Task Manager for Hyper-V provides critical information that allows you to monitor Hyper-V performance by displaying real-time views of CPU and memory at the individual VM-level, so you can quickly identify which VMs are using host resources.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Access developers frequently have requirements to interact with Excel (import from or output to) in their applications.  You might be able to accomplish this with the TransferSpreadsheet and OutputTo methods, but in this series of articles I will di…
This article describes a method of delivering Word templates for use in merging Access data to Word documents, that requires no computer knowledge on the part of the recipient -- the templates are saved in table fields, and are extracted and install…
Get people started with the utilization of class modules. Class modules can be a powerful tool in Microsoft Access. They allow you to create self-contained objects that encapsulate functionality. They can easily hide the complexity of a process from…
Polish reports in Access so they look terrific. Take yourself to another level. Equations, Back Color, Alternate Back Color. Write easy VBA Code. Tighten space to use less pages. Launch report from a menu, considering criteria only when it is filled…
Suggested Courses

800 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question