Adobe 0046100128056 Scripting Guide - Page 134
A More Complex Menu-scripting Example
UPC - 718659087562
View all Adobe 0046100128056 manuals
Add to My Manuals
Save this manual to your list of manuals |
Page 134 highlights
CHAPTER 9: Menus A More Complex Menu-scripting Example 134 var myScriptMenuActionNames = app.scriptMenuActions.everyItem().name; //Open a new text file. var myTextFile = File.saveDialog("Save Script Menu Action Names As", undefined); //If the user clicked the Cancel button, the result is null. if(myTextFile != null){ //Open the file with write access. myTextFile.open("w"); for(var myCounter = 0; myCounter < myScriptMenuActionNames.length; myCounter++){ myTextFile.writeln(myScriptMenuActionNames[myCounter]); } myTextFile.close(); } scriptMenuAction also can run scripts during their beforeDisplay event, in which case they are executed before an internal request for the state of the scriptMenuAction (e.g., when the menu item is about to be displayed). Among other things, the script can then change the menu names and/or set the enabled/checked status. In the following sample script, we add an eventListener to the beforeDisplay event that checks the current selection. If there is no selection, the script in the eventListener disables the menu item. If an item is selected, the menu item is enabled, and choosing the menu item displays the type of the first item in the selection. (For the complete script, see BeforeDisplay.) var mySampleScriptAction = app.scriptMenuActions.add("Display Message"); var myEventListener = mySampleScriptAction.eventListeners.add("onInvoke", function() { //JavaScript function to run when the menu item is selected. myString = app.selection[0].constructor.name; alert("The first item in the selection is a " + myString + "."); }); var mySampleScriptMenu = app.menus.item("$ID/Main").submenus.add("Script Menu Action"); var mySampleScriptMenuItem = mySampleScriptMenu.menuItems.add(mySampleScriptAction); mySampleScriptMenu.eventListeners.add("beforeDisplay", function() { //JavaScript function to run before the menu item is drawns. var mySampleScriptAction = app.scriptMenuActions.item("Display Message"); if(app.selection.length > 0){ mySampleScriptAction.enabled = true; } else{ mySampleScriptAction.enabled = false; } }); A More Complex Menu-scripting Example You have probably noticed that selecting different items in the InDesign user interface changes the contents of the context menus. The following sample script shows how to modify the context menu based on the properties of the object you select. Fragments of the script are shown below; for the complete script, see LayoutContextMenu. The following snippet shows how to create a new menu item on the Layout context menu (the context menu that appears when you have a page item selected). The following snippet adds a beforeDisplay eventListener which checks for the existence of a menuItem and removes it if it already exists. We do this to ensure the menuItem does not appear on the context menu when the selection does not contain a