Передача данных, сохраненных в файле plist, в виджет в SwiftUI

#swift #class #swiftui #data-modeling

Вопрос:

В моем приложении есть основной класс с именем DataManager, который я использую для обработки данных, которые пользователь вставляет в приложение.

Этот класс имеет основной массив «хранилище», в котором сохраняются все данные, и каждый раз, когда вставляются новые значения, этот класс имеет функцию сохранения значения в файле plist и обновления представления.

 // example of my DataManager class

class DataManager: NSObject, ObservableObject {
    
    static let shared = DataManager()
    
    @Published var storage : [CovidTestModel] = []
    typealias Storage = [CovidTestModel]
    
    var filePath : String = ""
    
    override init() {
        super.init()
        caricaDati() // load data
        
        firstStartSetting()
    }

 // functions of the class to run handle the data
}


 

Я хочу включить в свое приложение виджет, чтобы отобразить последнюю запись записи, сохраненную в массиве хранения, но я не могу найти способ передать данные в виджет.

Ниже приведен мой пробный код, но примечание загружено, я впервые изучаю виджет, как я могу передать данные, сохраненные в моем массиве хранения, в виджет. ()

 
import WidgetKit
import SwiftUI
import Intents

struct Provider: IntentTimelineProvider {
    let dm = DataManager() //  looks like not loading
    
   
    
    func placeholder(in context: Context) -> SimpleEntry {
        SimpleEntry(lastTest: dm.storage.last, date: Date(), configuration: ConfigurationIntent())
    }

    func getSnapshot(for configuration: ConfigurationIntent, in context: Context, completion: @escaping (SimpleEntry) -> ()) {
        let entry = SimpleEntry(lastTest: dm.storage.last, date: Date(), configuration: configuration)
        completion(entry)
    }

    func getTimeline(for configuration: ConfigurationIntent, in context: Context, completion: @escaping (Timeline<Entry>) -> ()) {
        var entries: [SimpleEntry] = []

        // Generate a timeline consisting of five entries an hour apart, starting from the current date.
        let currentDate = Date()
        for hourOffset in 0 ..< 5 {
            let entryDate = Calendar.current.date(byAdding: .hour, value: hourOffset, to: currentDate)!
            let entry = SimpleEntry(lastTest: dm.storage.last, date: entryDate, configuration: configuration)
            entries.append(entry)
        }

        let timeline = Timeline(entries: entries, policy: .atEnd)
        completion(timeline)
    }
}

struct SimpleEntry: TimelineEntry {
    let lastTest : CovidTestModel?
    let date: Date
    let configuration: ConfigurationIntent
}

struct NAT_WidjetEntryView : View {
    var entry: Provider.Entry
    
    var body: some View {
        Text(entry.lastTest?.expireOn ?? "NOT Working")
    }
}

@main
struct NAT_Widjet: Widget {
    let kind: String = "NAT_Widjet"

    var body: some WidgetConfiguration {
        IntentConfiguration(kind: kind, intent: ConfigurationIntent.self, provider: Provider()) { entry in
            NAT_WidjetEntryView(entry: entry)
        }
        .configurationDisplayName("My Widget")
        .description("This is an example widget.")
    }
}

struct NAT_Widjet_Previews: PreviewProvider {
    static var previews: some View {
        NAT_WidjetEntryView(entry: SimpleEntry(lastTest: CovidTestModel(id: "3432", location: nil, valitidityHours: 0, validityDays: 2, isValidyBy: 0, dateInDate: Date()), date: Date(), configuration: ConfigurationIntent()))
            .previewContext(WidgetPreviewContext(family: .systemSmall))
    }
}


 

Когда я открываю приложение, я вижу все сохраненные данные, но в виджет ничего не загружено.

Комментарии:

1. Похоже, вы не показываете ни одного кода, относящегося к загрузке a plist . Я предполагаю (не имея возможности видеть ваш код), что вы не храните plist их в контейнере, доступном как для приложения, так и для виджета. In должен находиться в контейнере группы приложений

2. Большое спасибо, да, проблема была именно в этом, я не реализовал контейнер группы приложений