Setting the Ribbon Name in Code
You don't need to use the options dialog to set a custom ribbon for your Microsoft Access application.
data:image/s3,"s3://crabby-images/70cd5/70cd53a0cfbecedbf481a51290b358895f98d871" alt="Setting the Ribbon Name in Code"
The typical way to choose a custom ribbon in an Access application is via File > Options > Current Database > Ribbon Name.
data:image/s3,"s3://crabby-images/94d18/94d18b8d72f3fee7891088135f14660d06a710fe" alt=""
But what if you want to assign that ribbon name in code? It's quite easy once you know where the information is stored: in a database property named CustomRibbonID:
data:image/s3,"s3://crabby-images/7d348/7d348a951370c1c9ad4ecb95cb8a25bf7daf8f73" alt=""
So, if we wanted to set the application-level ribbon to our Print Preview ribbon, we could use the following code:
CurrentDB.Properties("CustomRibbonID").Value = "gbRibbonPrintPreview"
Handling the "Property not found" Error
Now, let's say you haven't set a custom Ribbon Name through the Options dialog yet–or you set it at one time but then cleared it out:
data:image/s3,"s3://crabby-images/2e8da/2e8da86ab4e76ae4b8037acf575c396a3204c995" alt=""
If your "Ribbon and Toolbar Options" look like the above screenshot, then you won't be able to assign a value to the CustomRibbonID database property because it doesn't exist:
data:image/s3,"s3://crabby-images/ca66f/ca66fd0c9c26abb29f0120831d0510c9fa77b0b9" alt=""
In this situation, you would need to create the property itself and then append it to the database properties collection. You can do this in a single line of code if you wanted to:
CurrentDB.Properties.Append CurrentDB.CreateProperty("CustomRibbonID", dbText, "gbRibbonTaxColl2k")
The problem is that if you run the above code and the property already exists, then you'll get a different error message:
data:image/s3,"s3://crabby-images/ccf94/ccf94e4d84fefd1f9cad211e72725985bdc83deb" alt=""
The SetProp()
Routine
Rather than worrying about whether the property exists or not, you can just use my SetProp()
routine which will handle either scenario gracefully:
SetProp "CustomRibbonID", "gbRibbonTaxColl2k"
Referenced articles
data:image/s3,"s3://crabby-images/fcf21/fcf2140a8fb0d04152044096deab84257ad30eaa" alt=""
External references
data:image/s3,"s3://crabby-images/fd138/fd1383978565e5ed41be1d7da786baeaa07bbf76" alt=""
Image by Bruno /Germany from Pixabay