一覧画面にはFirestoreから取得してきたデータがが表示されており、詳細画面には削除ボタンがあります。
詳細画面に遷移し、削除ボタンをクリックして一覧画面に戻ったときに、
一覧画面から削除したデータを消したいです。
いろいろ試してみましたが、実現できなかったため、お力をお借りしたいです。
SwiftUI
1struct ListView: View { 2 @ObservedObject var fetcher = DataFetcher() 3 4 var body: some View { 5 NavigationView { 6 VStack { 7 ForEach(self.fetcher.listData.indices, id: .self) { i in 8 NavigationLink( 9 destination: DetailView(data: self.fetcher.listData[i]) 10 ) { 11 Text(self.fetcher.listData[i].name) 12 } 13 } 14 } 15 } 16 } 17} 18 19struct DetailView: View { 20 var data: DataModel 21 22 var body: some View { 23 VStack { 24 Text(self.data.name) 25 26 Button("Delete") { 27 self.deleteData(data: self.data) // Here, the corresponding data is deleted from the database. 28 } 29 } 30 } 31} 32 33class DataFetcher: ObservableObject { 34 @Published var data: [DataModel] = [] 35 private var db: Firestore! 36 37 init() { 38 db = Firestore.firestore() 39 fetchData() 40 } 41 42 private func fetchData() { 43 self.db.collection("data").getDocuments { (snaps, err) in 44 if let err = err { 45 print("Error getting documents: (err)") 46 } 47 48 guard let snaps = snaps else { return } 49 50 for document in snaps.documents { 51 self.data.append(DataModel( 52 id: document.data()["id"] as! String, 53 name: document.data()["name"] as! String 54 )) 55 } 56 } 57 } 58}
protocolなどを使い、削除ボタンをクリックしたタイミングでListViewにあるfunctionを呼び出して削除してみましたが、詳細画面に表示されていたデータが、次のデータに切り替わってしまいました。
SwiftUI
1func deleteData(data: DataModel) { 2 if let index: Int = self.fetcher.data.index(where: {$0.id==data.id}) { 3 self.fetcher.data.remove(at: index) 4 } 5}
よろしくお願いいたします。
あなたの回答
tips
プレビュー