core-data - 如何在 Intent Handler 中使用获取数据来编辑 Widget iOS 14?

标签 core-data swiftui widgetkit

我目前正在使用 SwiftUI 开发应用程序。

我正在尝试让一个 WidgetKit 用户可以使用IntentConfiguration编辑一些数据

我想使用 IntentHandler 类中的 CoreData 获取一些数据来编辑 WidgetKit ,如下图所示。

enter image description here

我尝试编写一些代码,但它们不起作用...

我该如何解决我的代码?


代码如下:

IntentHandler.swift

import WidgetKit
import SwiftUI
import CoreData
import Intents

class IntentHandler: INExtension, ConfigurationIntentHandling {
    
    var moc = PersistenceController.shared.managedObjectContext

    var timerEntity_0:TimerEntity?
    var timerEntity_1:TimerEntity?
    var timerEntity_2:TimerEntity?

    init(context : NSManagedObjectContext) {
        self.moc = context

        let request = NSFetchRequest<TimerEntity>(entityName: "TimerEntity")

        do{
            let result = try moc.fetch(request)
            timerEntity_0 = result[0]
            timerEntity_1 = result[1]
            timerEntity_2 = result[2]
        }
        catch let error as NSError{
            print("Could not fetch.\(error.userInfo)")
        }
    }
   
    func provideNameOptionsCollection(for intent: ConfigurationIntent, searchTerm: String?, with completion: @escaping (INObjectCollection<NSString>?, Error?) -> Void) {
        
        let nameIdentifiers:[NSString] = [
            NSString(string: timerEntity_0?.task ?? "default"),
            NSString(string: timerEntity_1?.task ?? "default"),
            NSString(string: timerEntity_2?.task ?? "default")
            // "meeting",
            // "cooking",
            // "shoping"
        ]
        let allNameIdentifiers = INObjectCollection(items: nameIdentifiers)
        
        completion(allNameIdentifiers,nil)
    }
    
    override func handler(for intent: INIntent) -> Any {
        
        return self
    }
}

WidgetKit .swift

import WidgetKit
import SwiftUI
import Intents

struct Provider: IntentTimelineProvider {
    
    typealias Intent = ConfigurationIntent
    
    func placeholder(in context: Context) -> SimpleEntry {
        SimpleEntry(date: Date(), configuration: ConfigurationIntent(), name: "")
    }

    func getSnapshot(for configuration: ConfigurationIntent, in context: Context, completion: @escaping (SimpleEntry) -> ()) {
        let entry = SimpleEntry(date: Date(), configuration: configuration, name: "")
        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(date: entryDate, configuration: configuration, name: configuration.Name ?? "")
            entries.append(entry)
        }

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

struct SimpleEntry: TimelineEntry {
    let date: Date
    let configuration: ConfigurationIntent
    var name:String
}

struct TimerIntentWidgetEntryView : View {
    var entry: Provider.Entry

    var body: some View {
        Text(entry.name)
            .font(.title)
        Text(entry.date, style: .time)
    }
}

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

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

tWidget.intent 定义 enter image description here


Xcode:版本 12.0.1

iOS: 14.0

生命周期:SwiftUI 应用

最佳答案

我可以使用从 CoreData 获取数据来在 WidgetKit 中显示一个列表,如下面的代码:


IntentHandler.swift

import WidgetKit
import SwiftUI
import CoreData
import Intents

class IntentHandler: INExtension, ConfigurationIntentHandling {
    
    var moc = PersistenceController.shared.managedObjectContext

    var timerEntity_0:TimerEntity?
    var timerEntity_1:TimerEntity?
    var timerEntity_2:TimerEntity?

    func provideNameOptionsCollection(for intent: ConfigurationIntent, searchTerm: String?, with completion: @escaping (INObjectCollection<NSString>?, Error?) -> Void) {
        
        let request = NSFetchRequest<TimerEntity>(entityName: "TimerEntity")

        do{
            let result = try moc.fetch(request)
            timerEntity_0 = result[0]
            timerEntity_1 = result[1]
            timerEntity_2 = result[2]
        }
        catch let error as NSError{
            print("Could not fetch.\(error.userInfo)")
        }

        let nameIdentifiers:[NSString] = [
            NSString(string: timerEntity_0?.task ?? "default"),
            NSString(string: timerEntity_1?.task ?? "default"),
            NSString(string: timerEntity_2?.task ?? "default")
            // "meeting",
            // "cooking",
            // "shoping"
        ]
        let allNameIdentifiers = INObjectCollection(items: nameIdentifiers)
        
        completion(allNameIdentifiers,nil)
    }
    
    override func handler(for intent: INIntent) -> Any {
        
        return self
    }
}

关于core-data - 如何在 Intent Handler 中使用获取数据来编辑 Widget iOS 14?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65606797/

相关文章:

iphone - 为什么 NSManagedObject 和 NSEntityDescription 是单独的类?

SwiftUI 和 Mac 催化剂 : Sidebar is not displayed correctly

SwiftUI 按钮选择

SwiftUI iOS 14 WidgetKit 倒计时

ios - 如何更改 WidgetKit 中心 ‘Add Widget’ 按钮的颜色

ios - 当 SwiftUI Widget 的相对文本字段计数器为零时停止?

xcode - CoreData 位于哪里?

ios - 核心数据:我只想在第一次运行时填充数据库

ios - 带有导航链接的 SwiftUI 消失后退按钮

ios - 核心数据 - executeFetchRequest Swift 1.2 Release模式崩溃