Automating the User Interface
Unfortunately, not every Mac app has scripting support, and those that do may not always have scripting support for every task you want to automate. You can often work around such limitations, however, by writing a user interface script, commonly called a UI or GUI script. A user interface script simulates user interaction, such as mouse clicks and keystrokes, allowing the script to select menu items, push buttons, enter text into text fields, and more.
Enabling User Interface Scripting
User interface scripting relies upon the OS X accessibility frameworks that provide alternative methods of querying and controlling the interfaces of apps and the system. By default, accessibility control of apps is disabled. For security and privacy reasons, the user must manually enable it on an app-by-app (including script apps) basis.
Launch System Preferences and click Security & Privacy.
Click the Privacy tab.
Click Accessibility.
Click the Add button (+).
Choose an app and click Open.
Select the checkbox to the left of the app.
When running an app that requires accessibility control for the first time, the system prompts you to enable it. See Figure 37-1.
Attempting to run an app that has not been given permission to use accessibility features results in an error. See Figure 37-2.
Targeting an App
User interface scripting terminology is found in the Processes Suite of the System Events scripting dictionary. This suite includes terminology for interacting with most types of user interface elements, including windows, buttons, checkboxes, menus, radio buttons, text fields, and more. In System Events, the process
class represents a running app. Listing 37-1 shows how to target an app using this class.
APPLESCRIPT
tell application "System Events"
tell process "Safari"
-- Perform user interface scripting tasks
end tell
end tell
To control the user interface of an app, you must first inspect the app and determine its element hierarchy. This can be done by querying the app. For example, Listing 37-2 asks Safari for a list of menus in the menu bar.
APPLESCRIPT
tell application "System Events"
tell process "Safari"
name of every menu of menu bar 1
end tell
end tell
--> Result: {"Apple", "Safari", "File", "Edit", "View", "History", "Bookmarks", "Develop", "Window", "Help"}
Accessibility Inspector (Figure 37-3) makes it even easier to identify user interface element information. This app is included with Xcode. To use it, open Xcode and select Xcode > Open Developer Tool > Accessibility Inspector.
Once you know how an element fits into an interface, you target it within that hierarchy. For example, button X of window Y of process Z
.
Clicking a Button
Use the click
command to click a button. Listing 37-3 clicks a button in the Safari toolbar to toggle the sidebar between open and closed.
APPLESCRIPT
tell application "System Events"
tell process "Safari"
tell toolbar of window 1
click (first button where its accessibility description = "Sidebar")
end tell
end tell
end tell
--> Result: {button 1 of toolbar 1 of window "AppleScript: Graphic User Interface (GUI) Scripting" of application process "Safari" of application "System Events"}
Choosing a Menu Item
Menu items can have a fairly deep hierarchy within the interface of an app. A menu item generally resides within a menu, which resides within a menu bar. In scripting, they must be addressed as such. Listing 37-4 selects the Pin Tab menu item in the Window menu of Safari.
APPLESCRIPT
tell application "System Events"
tell process "Safari"
set frontmost to true
click menu item "Pin Tab" of menu "Window" of menu bar 1
end tell
end tell
--> Result: menu item "Pin Tab" of menu "Window" of menu bar item "Window" of menu bar 1 of application process "Safari" of application "System Events"
Choosing a Submenu Item
Some menus contain other menus. In these cases, it may be necessary to select a menu item in a submenu of a menu. Listing 37-7 demonstrates how this would be done by selecting a submenu item in Safari.
APPLESCRIPT
tell application "System Events"
tell process "Safari"
set frontmost to true
click menu item "Email This Page" of menu of menu item "Share" of menu "File" of menu bar 1
end tell
end tell
--> Result: {menu item "Email This Page" of menu "Share" of menu item "Share" of menu "File" of menu bar item "File" of menu bar 1 of application process "Safari" of application "System Events"}
Copyright © 2018 Apple Inc. All rights reserved. Terms of Use | Privacy Policy | Updated: 2016-06-13