Overview
Apple Watch App Beta feature enables embedding a watch app in NativeScript application by adding watchapp and watchextension folders inside App_Resources/iOS/.
The watch app should be created and developed inside Xcode. Once the user is happy with the result, the folder containing the watch app and the watch app extension should be copied inside App_Resources/iOS/watchapp and App_Resources/iOS/watchextension respectively. Optionally you can add watchapp.json and extension.json which support multiple configurations for the build of the watch app and watch app extension.
Example JSON file:
{
"assetcatalogCompilerAppiconName": "AppIcon",
"targetBuildConfigurationProperties": {
"WATCHOS_DEPLOYMENT_TARGET": 4.1
}
}
In the example above you should have an .xcassets catalog with AppIcon.appiconset inside the watchapp folder.
More information can be found in the feature issue here.
Workflow:
- Create Single Page App from Xcode.
- Add watch app target - File>New>Target>WatchKit App
- Add a name to your watch app, for example
MyFirstWatchApp
- Copy the generated "MyFirstWatchApp" and
MyFirstWatchApp Extension to .../apps/MyApp/app/App_Resources/iOS/watchapp/MyFirstWatchApp and .../apps/MyApp/app/App_Resources/iOS/watchextension/MyFirstWatchApp Extension respectively.
- Inside the
Info.plist of the Watch App replace the value of WKCompanionAppBundleIdentifier with $(WK_APP_BUNDLE_IDENTIFIER).
6 Inside the Info.plist of the Watch Extension replace the value of WKAppBundleIdentifier with $(WK_APP_BUNDLE_IDENTIFIER).
- You can populate the
Assets.xcassets of the Watch App and the Watch Extension and add the name of the appiconset to the .../apps/MyApp/app/App_Resources/iOS/watchapp/MyFirstWatchApp/watchapp.json and .../apps/MyApp/app/App_Resources/iOS/watchextension/MyFirstWatchApp Extension/extension.json respectively:
{
"assetcatalogCompilerAppiconName": "AppIcon"
}
- You can modify the
WATCHOS_DEPLOYMENT_TARGET of the Watch App by adding the value inside the watchapp.json like this:
{
"assetcatalogCompilerAppiconName": "AppIcon",
"targetBuildConfigurationProperties": {
"WATCHOS_DEPLOYMENT_TARGET": 4.1
}
}
- Run the NativeScript application
Known issues
Discussion
Please, don't report problems here. Instead, open a new issue and link it to this one.
Let's use this discussion for suggestions and improvement ideas. We would love to hear from you!
Overview
Apple Watch App Beta feature enables embedding a watch app in NativeScript application by adding
watchappandwatchextensionfolders insideApp_Resources/iOS/.The watch app should be created and developed inside Xcode. Once the user is happy with the result, the folder containing the watch app and the watch app extension should be copied inside
App_Resources/iOS/watchappandApp_Resources/iOS/watchextensionrespectively. Optionally you can addwatchapp.jsonandextension.jsonwhich support multiple configurations for the build of the watch app and watch app extension.Example JSON file:
{ "assetcatalogCompilerAppiconName": "AppIcon", "targetBuildConfigurationProperties": { "WATCHOS_DEPLOYMENT_TARGET": 4.1 } }In the example above you should have an
.xcassetscatalog withAppIcon.appiconsetinside the watchapp folder.More information can be found in the feature issue here.
Workflow:
MyFirstWatchAppMyFirstWatchApp Extensionto.../apps/MyApp/app/App_Resources/iOS/watchapp/MyFirstWatchAppand.../apps/MyApp/app/App_Resources/iOS/watchextension/MyFirstWatchApp Extensionrespectively.Info.plistof the Watch App replace the value ofWKCompanionAppBundleIdentifierwith$(WK_APP_BUNDLE_IDENTIFIER).6 Inside the
Info.plistof the Watch Extension replace the value ofWKAppBundleIdentifierwith$(WK_APP_BUNDLE_IDENTIFIER).Assets.xcassetsof the Watch App and the Watch Extension and add the name of theappiconsetto the.../apps/MyApp/app/App_Resources/iOS/watchapp/MyFirstWatchApp/watchapp.jsonand.../apps/MyApp/app/App_Resources/iOS/watchextension/MyFirstWatchApp Extension/extension.jsonrespectively:{ "assetcatalogCompilerAppiconName": "AppIcon" }WATCHOS_DEPLOYMENT_TARGETof the Watch App by adding the value inside thewatchapp.jsonlike this:{ "assetcatalogCompilerAppiconName": "AppIcon", "targetBuildConfigurationProperties": { "WATCHOS_DEPLOYMENT_TARGET": 4.1 } }Known issues
Automaticcode signing. Any provision configuration insideApp_Resources/iOS/build.xcconfigwill be ignored. And the application build will most probably fail..entitlementsfile, the prepare step of the project will fail. - Apple Watch extension with space in name and.entitlementsfile not working. #5005Discussion
Please, don't report problems here. Instead, open a new issue and link it to this one.
Let's use this discussion for suggestions and improvement ideas. We would love to hear from you!