Search code examples
macosswiftuimac-catalyst

UIDocumentPickerViewController with Catalyst on MACOS


I have this code for show picker with Catalyst in MacOS:

final class DocumentPicker: NSObject, UIViewControllerRepresentable, ObservableObject {
    typealias UIViewControllerType = UIDocumentPickerViewController
    @Published var urlsPicked = [URL]()

    lazy var viewController:UIDocumentPickerViewController = {
        // For picked only folder
        let vc = UIDocumentPickerViewController(documentTypes: ["public.folder"], in: .open)
        vc.allowsMultipleSelection = false
        vc.delegate = self
        return vc
    }()        
    ........

and:

struct ContentView: View {
    @ObservedObject var picker = DocumentPicker()
    @State private var urlPick = ""

    var body: some View {
        HStack {
            Text(urlPicked())
                .padding()
                .overlay(
                    RoundedRectangle(cornerRadius: 10)
                        .stroke(Color.white, lineWidth: 1)
                )
            TextField("", text: $urlPick)
                .textFieldStyle(RoundedBorderTextFieldStyle())
                .font(.system(size: 10))
                .disabled(true)
            Spacer()
            Button(action: {
                #if targetEnvironment(macCatalyst)
                let viewController = UIApplication.shared.windows[0].rootViewController!
                viewController.present(self.picker.viewController, animated: true)
                self.picker.objectWillChange.send()
                #endif
                print("Hai premuto il pulsante per determinare il path della GeoFolder")
            }) {
                Image(systemName: "square.and.arrow.up")
            }
        }
        .padding()
    }

    private func urlPicked() -> String {
        var urlP = ""
        if picker.urlsPicked.count > 0 {
            urlP = picker.urlsPicked[0].path
            urlPick = picker.urlsPicked[0].path
        }
        return urlP
    }
}

If I run the above code I get the chosen correct path in text, while in textfield nothing and also I have the error in urlPick = picker.urlsPicked[0].path: Modifying state during view update, this will cause undefined behavior. How can I modify the code to show the correct path chosen also in textfield?


Solution

  • have the error in urlPick = picker.urlsPicked[0].path: Modifying state during view update, this will cause undefined behavior. How can I modify the code to show the correct path chosen also in textfield?

    Try the following

        if picker.urlsPicked.count > 0 {
            urlP = picker.urlsPicked[0].path
            DispatchQueue.main.async {
                urlPick = picker.urlsPicked[0].path
            }
        }