I tried to delete the storyboard file and related Info.plist entry but this time extension stopped working; it doesn't even launch from XCode.
The operation couldn’t be completed. (LaunchServicesError error 0.)
It is easy on the regular app (containing app) as we see it's entry point and application delegate, but how to do it on extensions too?
Create your own widget stacksTouch and hold an app or empty area on the Home Screen or Today View until the apps jiggle. Drag a widget on top of another widget. You can stack up to 10 widgets. Tap Done.
Open your app project in Xcode and choose File > New > Target. From the Application Extension group, select Widget Extension, and then click Next. Enter the name of your extension. If the widget provides user-configurable properties, check the Include Configuration Intent checkbox.
I did the following steps:
Go to the NSExtension Dictionary, remove this key: NSExtensionMainStoryboard. Replace it with this key NSExtensionPrincipalClass and add your ViewController as the value, e.g. TodayViewController.
before:
<key>NSExtension</key>
<dict>
    <key>NSExtensionMainStoryboard</key>
    <string>MainInterface</string>
    <key>NSExtensionPointIdentifier</key>
    <string>com.apple.widget-extension</string>
</dict>
after:
<key>NSExtension</key>
<dict>
    <key>NSExtensionPrincipalClass</key>
    <string>TodayViewController</string>
    <key>NSExtensionPointIdentifier</key>
    <string>com.apple.widget-extension</string>
</dict>
@objc (TodayViewController) in my TodayViewController class (after the imports).The app should run now. But there were two other things I had to do:
So add these lines:
override func loadView()
{
    view = UIView(frame:CGRect(x:0.0, y:0, width:320.0, height:200.0))
}
self.preferredContentSize = CGSizeMake(0, 200)
Remove NSExtensionMainStoryboard from Info.plist
Add NSExtensionPrincipalClass = YourViewController
Don't forget to create your own view in loadView
FWIW, it didn't work for me until I added a prefix of the module name for my Swift view controller class, e.g.
<key>NSExtension</key>
<dict>
    <!-- ... -->
    <key>NSExtensionPrincipalClass</key>
    <string>SafariActionExtension.RootViewController</string>
    <!-- ... -->
</dict>
That is probably because class lookup for Swift modules turns module names into prefix for class name. E.g. to create your class in code you would write NSStringFromClass("SafariActionExtension.RootViewController"), hence the prefix.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With