// // ContentModeViewModel.swift // Feels (iOS) // // Created by Trey Tartt on 1/20/22. // import SwiftUI import CoreData class ContentModeViewModel: ObservableObject { @Published var grouped = [Int: [Int: [MoodEntry]]]() @Published var numberOfItems = 0 let addMonthStartWeekdayPadding: Bool var hasNoData: Bool { grouped.isEmpty } private var numberOfEntries: Int { var num = 0 grouped.keys.forEach({ let year = grouped[$0] let monthKeys = year?.keys monthKeys?.forEach({ num += year![$0]!.count }) }) return num // grouped.keys.map{ // grouped[$0]!.values.reduce(0) { sum, array in // sum + array.count // } // }.reduce(0, +) } init(addMonthStartWeekdayPadding: Bool) { self.addMonthStartWeekdayPadding = addMonthStartWeekdayPadding PersistenceController.shared.switchContainerListeners.append { self.getGroupedData(addMonthStartWeekdayPadding: self.addMonthStartWeekdayPadding) } updateData() } private func getGroupedData(addMonthStartWeekdayPadding: Bool) { grouped = PersistenceController.shared.splitIntoYearMonth() if addMonthStartWeekdayPadding { var newGrouped = [Int: [Int: [MoodEntry]]]() let allYears = grouped.keys.sorted(by: > ) for year in allYears { var newMonth = [Int: [MoodEntry]]() let oldMonths = grouped[year]! let monthKeys = oldMonths.keys.sorted(by: > ) for key in monthKeys { if let entries = oldMonths[key] { let sortedEntries = entries.sorted(by: { $0.forDate! < $1.forDate! }) var mutableEntries = sortedEntries if let firstDate = sortedEntries.first { let date = firstDate.forDate! let weekday = Int16(Calendar.current.component(.weekday, from: date)) for _ in 1.. $1.forDate! }) var entriesToDelete = [MoodEntry]() for idx in offsets { let obj = mutableEntries.remove(at: idx) entriesToDelete.append(obj) } entriesToDelete.forEach({ entry in let entryDate = entry.forDate! PersistenceController.shared.viewContext.delete(entry) self.add(mood: .missing, forDate: entryDate, entryType: .listView) }) } do { try PersistenceController.shared.viewContext.save() updateData() } catch { // Replace this implementation with code to handle the error appropriately. // fatalError() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development. let nsError = error as NSError fatalError("Unresolved error \(nsError), \(nsError.userInfo)") } } static func updateTitleHeader(forEntry entry: MoodEntry?) -> String { guard let entry = entry else { return "" } guard let forDate = entry.forDate else { return "" } let components = Calendar.current.dateComponents([.day, .month, .year], from: forDate) // let day = components.day! let month = components.month! let year = components.year! let monthName = Random.monthName(fromMonthInt: month) let weekday = Random.weekdayName(fromDate:entry.forDate!) let dayz = Random.dayFormat(fromDate:entry.forDate!) let string = weekday + " " + monthName + " " + dayz + " " + String(year) return String(format: String(localized: "content_view_fill_in_missing_entry"), string) } }