Creating an iMessage app without using a storyboard

471 views Asked by At

I would like to create an iMessage app without using a storyboard, and preferably using SwiftUI for the view. I am following an answer in an Apple forum, but I am not getting a view inside the iMessage window.

I changed my Info.plist to:

<key>NSExtension</key>
    <dict>
        <key>NSExtensionPointIdentifier</key>
        <string>com.apple.message-payload-provider</string>
        <key>NSExtensionPrincipalClass</key>
        <string>MessagesViewController.swift</string>
    </dict>

A simple view controller:

import Messages
import SwiftUI

@objc (MessagesViewController)
class MessagesViewController: MSMessagesAppViewController {
    override func viewDidLoad() {
        super.viewDidLoad()

        let child = UIHostingController(rootView: SwiftUIView())
        child.view.translatesAutoresizingMaskIntoConstraints = false
        self.view.addSubview(child.view)
        
        NSLayoutConstraint.activate([
            child.view.topAnchor.constraint(equalTo: view.topAnchor, constant: 0.0),
            child.view.leadingAnchor.constraint(equalTo: view.leadingAnchor, constant: 0.0),
            child.view.bottomAnchor.constraint(equalTo: view.bottomAnchor, constant: 0.0),
            child.view.trailingAnchor.constraint(equalTo: view.trailingAnchor, constant: 0.0)
            ])
    }

And finally a simple SwiftUI view:

struct SwiftUIView: View {
    var body: some View {
        Text("Hello, Earth!")
    }
}

So far, no luck. Does anyone have an idea where I've gone wrong?

1

There are 1 answers

1
Paulw11 On BEST ANSWER

Your problem is in your Info.plist file. You have specified MessagesViewController.swift as the NSExtensionPrincipalClass

This is the source file name, not the class name. You need to specify the class name (which is MessagesViewController) prefixed with your module name.

Change your Info.plist to

<key>NSExtension</key>
    <dict>
        <key>NSExtensionPointIdentifier</key>
        <string>com.apple.message-payload-provider</string>
        <key>NSExtensionPrincipalClass</key>
        <string>$(PRODUCT_MODULE_NAME).MessagesViewController</string>
    </dict>