Including shortcuts help could be a good way to distinguish your app and provide wonderful integration into the iOS ecosystem. Shortcuts enable your customers to work together along with your app with out launching and navigating into particular screens to carry out duties. Shortcuts can use voice, textual content or Highlight to perform fast duties with out a lot psychological overhead. Your customers may also construct bigger workflows along with your shortcuts to perform many duties concurrently.
Up to now, including Shortcuts and exposing them to the system could possibly be cumbersome and time-consuming. After your shortcut was arrange and accessible, you had to determine one of the simplest ways to tell the consumer that it existed and present easy methods to use it. In iOS 16, Apple revamped the method of including and exposing your app’s Shortcuts to iOS. The previous technique of including Shortcuts included finicky visible editors and mapping code information to Intent Definition information.
The brand new App Intents framework permits you to create shortcuts from the identical language you utilize day by day – Swift! The whole lot is statically typed and ingested into iOS upon set up. Your shortcuts are instantly accessible to customers through Siri, the Shortcuts app and Highlight.
It’s time to dive into this new easy means so as to add Shortcuts to the system!
Getting Began
Obtain the starter undertaking by clicking the Obtain Supplies button on the prime or backside of the tutorial.
The BreakLogger app lets you document break occasions all through the day. Open the starter app undertaking. Construct and run BreakLogger. You’ll see an empty break listing:
Faucet the Add button on the backside of the display, and also you’ll be prompted to document a break:
Choose a break so as to add. Subsequent, you’ll see a listing of the breaks you’ve added — together with the one you simply recorded:
Proper now, the one method to log a break is from inside the app. However iOS has a number of different methods to work together with apps all through its ecosystem. Customers could wish to log a break as half of a bigger workflow, combining a number of actions into one shortcut. They might additionally wish to inform Siri to log a break with out opening the app whereas on the go. These use instances are potential should you combine the App Intents framework into your app.
iOS 16 launched the App Intents framework. Shortcut definitions at the moment are constructed totally in Swift, with no code era or further steps wanted to make them accessible throughout iOS. You now not want to make use of Intent Definition information or the visible editors. Get began constructing your individual along with your first App Intent.
Defining Your First App Intent
Contained in the starter undertaking, right-click the Supply group and choose New Group. Identify the group Intents. Inside the brand new group, right-click once more and choose New File… . Choose the Swift File template and select Subsequent. Identify the file LogBreakIntent.swift.
Create a LogBreakIntent
struct that conforms to AppIntent
:
import AppIntents
import SwiftUI
// 1
struct LogBreakIntent: AppIntent {
// 2
static let title: LocalizedStringResource = "Log a Break"
// 3
func carry out() async throws -> some IntentResult & ProvidesDialog {
// 4
let loggerManager = LoggerManager()
loggerManager.logBreak(for: .quarterHour)
// 5
return .consequence(dialog: "Logged a 15 minute break")
}
}
Right here’s what’s taking place within the code above:
- Creates a
struct
to characterize your shortcut. Provides conformance to theAppIntent
protocol. - Provides a
title
property. That is of sortLocalizedStringResource
, which makes the string accessible out of course of for localization lookup. Bear in mind this code additionally runs when your app isn’t in reminiscence. - Provides a
carry out()
perform to finalize conformance to theAppIntent
protocol. Signifies it returns anIntentResult
and that it offers a dialog. - Makes use of the
LoggerManager
comfort sort to log a 15-minute break. This motion additionally saves the break to the Core Information retailer. - Returns the
IntentResult
as a dialog.
With the present setup, a consumer can create a shortcut and the intents from BreakLogger will seem as accessible actions. These actions run by themselves or as half of a bigger shortcut composed of many actions. As quickly as a consumer installs BreakLogger your intents can be found as shortcut actions.
Construct and run to make sure the up to date code installs to the simulator. Subsequent, background the app with the keyboard shortcut Command + Shift + H
. You’ll see the Shortcuts app on the identical display. Open Shortcuts.
Faucet the + button on the highest proper. The New Shortcut view masses.
On the New Shortcut view, faucet Add Motion. Within the segmented management on the prime, choose Apps.
Choose BreakLogger from the listing, then faucet Log a Break.
Faucet Accomplished. The view dismisses and takes you again to the Shortcuts tab within the app. You’ll see your new shortcut on the display now. You’ve created a shortcut along with your first app intent!
Faucet the Log a Break shortcut to run it. You’ll see a dialog drop down after a second or two with the content material you arrange within the carry out()
perform.
Faucet Accomplished, shut Shortcuts and open BreakLogger once more. You’ll see the break you simply logged added to the listing.
Nicely completed! You added Shortcuts integration into your app with just a few Swift information in just a few steps. Subsequent, you’ll add an app shortcut to BreakLogger.
Including an App Shortcut
Again in Xcode, add a brand new Swift file to the Intents group you created earlier. Identify the file BreakLoggerShortcuts.swift.
Add the next:
import AppIntents
// 1
struct BreakLoggerShortcuts: AppShortcutsProvider {
// 2
static var appShortcuts: [AppShortcut] {
// 3
AppShortcut(
// 4
intent: LogBreakIntent(),
// 5
phrases: [
"Log a break",
"Log a (.applicationName) break"
]
)
}
}
Right here’s what this code does:
- Creates a struct that conforms to
AppShortcutsProvider
. This lets iOS know to index the shortcuts right here. - Provides a static property that returns an array of
AppShortcut
cases. For this instance, you’ll solely be offering one. - Creates an
AppShortcut
. - Makes use of
LogBreakIntent
because the intent behind the shortcut. - Gives a listing of phrases that may set off this shortcut. Be aware using the particular token
.applicationName
, which resolves to the localized identify of your app.
Now, construct and run.
Background the app. You’ll be capable of begin Siri on the simulator and say, “Use BreakLogger to a break” and have the shortcut run instantly.
You’ll see a immediate asking you to allow BreakLogger shortcuts with Siri:
Then, you’ll see a affirmation dialog:
Lastly, open BreakLogger once more. You’ll see your second logged break from the shortcut you simply ran.
Be aware: Siri could be finicky on the simulator. You’ll have to reset the machine and take a look at a number of occasions to get the shortcut to run through voice. Additionally, be certain there isn’t a whole lot of background noise within the room you’re working in.
Subsequent, you’ll create a customized affirmation view to point out each time the intent has run.