Migrate from Core Data to SwiftData

- Replace Core Data with SwiftData for iOS 18+
- Create MoodEntryModel as @Model class replacing MoodEntry entity
- Create SharedModelContainer for App Group container sharing
- Create DataController with CRUD extensions replacing PersistenceController
- Update all views and view models to use MoodEntryModel
- Update widget extension to use SwiftData
- Remove old Core Data files (Persistence*.swift, .xcdatamodeld)
- Add EntryType enum with all entry type cases
- Fix widget label truncation with proper spacing and text scaling

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
Trey t
2025-12-10 15:08:05 -06:00
parent 443f4dfc55
commit aaaf04f05e
51 changed files with 926 additions and 962 deletions

View File

@@ -6,7 +6,7 @@
//
import SwiftUI
import CoreData
import SwiftData
import Charts
struct DayViewConstants {
@@ -15,8 +15,6 @@ struct DayViewConstants {
}
struct DayView: View {
@Environment(\.managedObjectContext) private var viewContext
@AppStorage(UserDefaultsStore.Keys.deleteEnable.rawValue, store: GroupUserDefaults.groupDefaults) private var deleteEnabled = true
@AppStorage(UserDefaultsStore.Keys.theme.rawValue, store: GroupUserDefaults.groupDefaults) private var theme: Theme = .system
@@ -30,7 +28,7 @@ struct DayView: View {
// MARK: edit row properties
@State private var showingSheet = false
@State private var selectedEntry: MoodEntry?
@State private var selectedEntry: MoodEntryModel?
//
// MARK: ?? properties
@@ -100,7 +98,7 @@ struct DayView: View {
}
.padding([.leading, .trailing])
.onReceive(NotificationCenter.default.publisher(for: UIApplication.willEnterForegroundNotification)) { _ in
PersistenceController.shared.fillInMissingDates()
DataController.shared.fillInMissingDates()
viewModel.updateData()
}
.background(
@@ -164,13 +162,13 @@ extension DayView {
.background(.ultraThinMaterial)
}
private func monthListView(month: Int, year: Int, entries: [MoodEntry]) -> some View {
private func monthListView(month: Int, year: Int, entries: [MoodEntryModel]) -> some View {
VStack(spacing: 12) {
// for reach all entries
ForEach(entries.sorted(by: {
return $0.forDate! > $1.forDate!
return $0.forDate > $1.forDate
}), id: \.self) { entry in
if filteredDays.currentFilters.contains(Int(entry.weekDay)) {
if filteredDays.currentFilters.contains(entry.weekDay) {
EntryListView(entry: entry)
.contentShape(Rectangle())
.onTapGesture(perform: {
@@ -195,13 +193,14 @@ struct ViewOffsetKey: PreferenceKey {
struct DayView_Previews: PreviewProvider {
static var previews: some View {
DayView(viewModel: DayViewViewModel(addMonthStartWeekdayPadding: false)).environment(\.managedObjectContext, PersistenceController.shared.viewContext)
DayView(viewModel: DayViewViewModel(addMonthStartWeekdayPadding: false))
.modelContainer(DataController.shared.container)
.onAppear(perform: {
PersistenceController.shared.populateMemory()
DataController.shared.populateMemory()
})
DayView(viewModel: DayViewViewModel(addMonthStartWeekdayPadding: false))
.preferredColorScheme(.dark)
.environment(\.managedObjectContext, PersistenceController.shared.viewContext)
.modelContainer(DataController.shared.container)
}
}