MacOS(macOS Monterey12.0.1)、Xcode(13.1)、swift(5.5.1)
実行環境 シミュレーション(iPhone12pro)
現状FCalenderにて選択日付をラベルに表示することはできているのですが、realmより選択日付に登録してあるデータを取得してtablecellに対して表示するという処理を実装したいです。
下記サイトを見ているのですが、具体的にどのようにデータをUIに対して渡しているのか等の処理がわからないです。
どのように取得したデータをUIに渡すのかを教えてほしいです。
コードを挿入すると当たり前ですが、このようになってしまいます。
swift
1 //選択日付を表示する 2 func calendar(_ calendar: FSCalendar, didSelect date: Date, at monthPosition: FSCalendarMonthPosition) { 3 //選択日付をフォーマット 4 let tmpDate = Calendar(identifier: .gregorian) 5 let year = tmpDate.component(.year, from: date) 6 let month = tmpDate.component(.month, from: date) 7 let day = tmpDate.component(.day, from: date) 8 labelDate.text = "\(year)年\(month)月\(day)日" 9 10 filterModel() 11 TableView.reloadData() 12 13 //********************************** 14 // 15 // セルイベント 16 // 17 //********************************** 18 19 //セルの個数を返すメソッド 20 func tableView(_ tableView: UITableView,numberOfRowsInSection section: Int) -> Int { 21 return getModel(date: labelDate.text!).count 22 } 23 24 //セクション内に表示するセルのテキストを返すメソッド 25 func tableView(_ tableView: UITableView, cellForRowAt IndexPath: IndexPath) -> UITableViewCell { 26 let cell = TableView.dequeueReusableCell(withIdentifier: "cell", for: IndexPath) 27 let data = getModel(date: labelDate.text!) 28 29 return cell 30 } 31 } 32 33 [リンク内容](![url](https://ddjkaamml8q8x.cloudfront.net/questions/2022-05-18/cb7be340-ba7d-4daf-9f28-49a250c17ec8.png)) 34 //データベース上に保存されているデータを配列に格納する。 35 func getModel(date:String) -> Array<Any>{ 36 let realm = try! Realm() 37 let results = realm.objects(calender.self) 38 var param: [[String:String]] = [] 39 for result in results { 40 param.append(["reason": result.outreason, 41 "payout": String(result.payout), 42 "date": result.date 43 ]) 44 45 } 46 return param 47 } 48 49 func filterModel() { 50 var filterdEvents: [[String:String]] = [] 51 for eventModel in eventModels { 52 if eventModel["date"] == stringFromDate(date: selectedDate as Date, format: "yyyy.MM.dd") { 53 filterdEvents.append(eventModel) 54 } 55 } 56 filterdModels = filterdEvents 57 } 58} 59
あなたの回答
tips
プレビュー