I am trying to add UIKit context menu to a SwiftUI view because SwiftUI context menu is pretty limited. I managed to do it, but UIViewControllerRepresentable takes more space than it needs. How can I resize it to fit the content inside it? Here is my code.
SwiftUI code
struct TrackerCard: View {
var tracker: Tracker
var body: some View {
HStack {
HStack {
...
}
.padding()
.background(Color("Wrapper"))
.cornerRadius(15)
}
.padding(.horizontal)
}
}
struct TrackerCardView: View {
var tracker: Tracker
var body: some View {
ContextMenuView(card: TrackerCard(tracker: tracker))
}
}
UIKit code
class ContextMenuController : UIViewController, UIContextMenuInteractionDelegate {
var card: TrackerCard?
var hostingViewController: UIHostingController<TrackerCard>?
func setViewController(_ controller : UIHostingController<TrackerCard>) {
hostingViewController = controller
self.addChild(controller)
controller.view.translatesAutoresizingMaskIntoConstraints = false
view.backgroundColor = .init(white: 1, alpha: 1)
view.addSubview(controller.view)
controller.didMove(toParent: self)
controller.view.widthAnchor.constraint(equalTo: view.widthAnchor).isActive = true
}
func setInteraction() {
let interaction = UIContextMenuInteraction(delegate: self)
hostingViewController?.view.addInteraction(interaction)
}
func contextMenuInteraction(_ interaction: UIContextMenuInteraction, configurationForMenuAtLocation location: CGPoint) -> UIContextMenuConfiguration? {
return ...
}
struct ContextMenuView: UIViewControllerRepresentable {
typealias UIViewControllerType = ContextMenuController
var card: TrackerCard
var controller : UIViewControllerType? = nil
func makeUIViewController(context: Context) -> ContextMenuController {
let contextMenuController = controller ?? ContextMenuController()
contextMenuController.card = card
return contextMenuController
}
func updateUIViewController(_ contextMenuController: ContextMenuController, context: Context) {
contextMenuController.setViewController(UIHostingController(rootView: card))
contextMenuController.setInteraction()
}
}