iOS 14 的 RSS 小部件显示为空

RSS Widget For iOS 14 Shows Empty

我在 Swift 中为我的应用程序使用了 XMLParser,并且正在尝试为 iOS 14 设置一个小部件,它将在其中显示 RSS 上的最新文章。我在添加占位符时看到它很好,但它仍然是空的,只有一行文本应该是文本,而且似乎永远不会从时间轴中获取信息。

struct Provider: TimelineProvider {
    @State private var rssItems:[RSSItem]?
    let feedParser = FeedParser()
    func placeholder(in context: Context) -> SimpleEntry {
        SimpleEntry(date: Date(), title:"News", description: "News article here", link: "Http://link", pubDate: "The day it posted")
    }

    func getSnapshot(in context: Context, completion: @escaping (SimpleEntry) -> ()) {
        let entry = SimpleEntry(date: Date(), title:"News", description: "News Article Here", link: "Http://link", pubDate: "The day it posted")
        completion(entry)
    }

    func getTimeline(in context: Context, completion: @escaping (Timeline<SimpleEntry>) -> ()) {
        var entries: [SimpleEntry] = []
        feedParser.parseFeed(url: "http://fritchcoc.wordpress.com/feed") {(rssItems) in
            self.rssItems = rssItems
            let currentDate = Date()
                let entry = SimpleEntry(date: currentDate, title:rssItems[0].title, description: rssItems[0].description, link: rssItems[0].link, pubDate: rssItems[0].pubDate)
                entries.append(entry)
            
        
      
        }

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

struct SimpleEntry: TimelineEntry {
    let date: Date
    let title: String
    let description: String
    let link: String
    let pubDate: String
}

struct FritchNewsEntryView : View {
    var entry: SimpleEntry
    var body: some View {
            VStack(alignment: .leading, spacing: 4) {
                
                Text(entry.title)
               
                   
                
              
            }.frame(minWidth: 0, maxWidth: .infinity, minHeight: 0, maxHeight: .infinity, alignment: .leading)
                .padding()
                .background(LinearGradient(gradient: Gradient(colors: [.orange, .yellow]), startPoint: .top, endPoint: .bottom))
        }
    
}

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

    var body: some WidgetConfiguration {
        StaticConfiguration(kind: kind, provider: Provider()) { entry in
            FritchNewsEntryView(entry: entry)
        }
        .configurationDisplayName("My Widget")
        .description("This is an example widget.")
    }
}

OP 更新: 这确实是时间轴设置在错误位置的组合,以及导致此特定问题的解析器中的几个拼写错误。

Apple 默认不允许 HTTP 连接,最简单的解决方案是将 URL 更改为 https://fritchcoc.wordpress.com/feed

如果您想在您的应用程序(或小部件)中允许 HTTP 连接,您可以在 Info.plist 中为目标添加例外(到一个域或所有域),请参阅 Apple Docs[ 的 NSAppTransportSecurity =15=]

编辑:
仔细查看并在网上找到 FeedParser 的实现后,我注意到 parseFeed() 是异步的。

因此用一个空数组调用完成,应该在解析完​​成后调用:

struct Provider: TimelineProvider {
    ...

    func getTimeline(in context: Context, completion: @escaping (Timeline<SimpleEntry>) -> ()) {
        var entries: [SimpleEntry] = []
        feedParser.parseFeed(url: "http://fritchcoc.wordpress.com/feed") {(rssItems) in
            self.rssItems = rssItems
            let currentDate = Date()
            let entry = SimpleEntry(date: currentDate, title:rssItems[0].title, description: rssItems[0].description, link: rssItems[0].link, pubDate: rssItems[0].pubDate)
            entries.append(entry)
            
        
            let timeline = Timeline(entries: entries, policy: .atEnd)
            completion(timeline)
        }
    }
}