2020-10-30 10:19:38 -04:00
|
|
|
//
|
|
|
|
// MarketWidget.swift
|
|
|
|
// MarketWidget
|
|
|
|
//
|
2020-11-06 12:05:18 -05:00
|
|
|
// Created by Marcos Rodriguez on 11/6/20.
|
2020-10-30 10:19:38 -04:00
|
|
|
// Copyright © 2020 BlueWallet. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
import WidgetKit
|
|
|
|
import SwiftUI
|
|
|
|
|
2021-06-06 03:58:39 -04:00
|
|
|
struct MarketWidgetProvider: TimelineProvider {
|
2024-12-12 23:03:05 -04:00
|
|
|
static var lastSuccessfulEntry: MarketWidgetEntry?
|
2023-12-26 23:00:30 -04:00
|
|
|
|
2024-12-12 23:03:05 -04:00
|
|
|
func placeholder(in context: Context) -> MarketWidgetEntry {
|
|
|
|
return MarketWidgetEntry(date: Date(), marketData: MarketData(nextBlock: "26", sats: "9 134", price: "$10 000", rate: 10000))
|
2020-10-30 10:19:38 -04:00
|
|
|
}
|
2024-11-20 03:49:52 -04:00
|
|
|
|
2024-12-12 23:03:05 -04:00
|
|
|
func getSnapshot(in context: Context, completion: @escaping (MarketWidgetEntry) -> ()) {
|
|
|
|
let entry: MarketWidgetEntry
|
|
|
|
if context.isPreview {
|
|
|
|
entry = MarketWidgetEntry(date: Date(), marketData: MarketData(nextBlock: "26", sats: "9 134", price: "$10 000", rate: 10000))
|
|
|
|
} else {
|
|
|
|
entry = MarketWidgetEntry(date: Date(), marketData: MarketData(nextBlock: "...", sats: "...", price: "...", rate: 0))
|
|
|
|
}
|
|
|
|
completion(entry)
|
|
|
|
}
|
|
|
|
|
|
|
|
func getTimeline(in context: Context, completion: @escaping (Timeline<Entry>) -> ()) {
|
|
|
|
let currentDate = Date()
|
|
|
|
var entries: [MarketWidgetEntry] = []
|
|
|
|
|
|
|
|
var marketDataEntry = MarketWidgetEntry(date: currentDate, marketData: MarketData(nextBlock: "...", sats: "...", price: "...", rate: 0))
|
|
|
|
entries.append(marketDataEntry) // Initial entry with no data
|
|
|
|
|
|
|
|
Task {
|
|
|
|
let userPreferredCurrency = Currency.getUserPreferredCurrency()
|
|
|
|
let entry = await fetchMarketDataWithRetry(currency: userPreferredCurrency, retries: 3)
|
|
|
|
entries.append(entry)
|
|
|
|
|
|
|
|
let timeline = Timeline(entries: entries, policy: .atEnd)
|
|
|
|
completion(timeline)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private func fetchMarketDataWithRetry(currency: String, retries: Int) async -> MarketWidgetEntry {
|
|
|
|
var marketData = MarketData(nextBlock: "...", sats: "...", price: "...", rate: 0)
|
|
|
|
|
|
|
|
for attempt in 0..<retries {
|
|
|
|
do {
|
|
|
|
print("Attempt \(attempt + 1) to fetch market data.")
|
|
|
|
let fetchedData = try await fetchMarketData(currency: currency)
|
|
|
|
marketData = fetchedData
|
|
|
|
print("Successfully fetched market data on attempt \(attempt + 1).")
|
|
|
|
break
|
|
|
|
} catch {
|
|
|
|
print("Fetch market data failed (attempt \(attempt + 1)): \(error.localizedDescription)")
|
|
|
|
try? await Task.sleep(nanoseconds: UInt64(2 * 1_000_000_000)) // Wait 2 seconds before retrying
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
let marketDataEntry = MarketWidgetEntry(date: Date(), marketData: marketData)
|
|
|
|
return marketDataEntry
|
|
|
|
}
|
|
|
|
|
|
|
|
private func fetchMarketData(currency: String) async throws -> MarketData {
|
|
|
|
let marketData = try await MarketAPI.fetchMarketData(currency: currency)
|
|
|
|
return marketData
|
|
|
|
}
|
2020-10-30 10:19:38 -04:00
|
|
|
}
|
|
|
|
|
2021-06-06 03:58:39 -04:00
|
|
|
struct MarketWidgetEntry: TimelineEntry {
|
2024-12-12 23:03:05 -04:00
|
|
|
let date: Date
|
|
|
|
var marketData: MarketData
|
2020-10-30 10:19:38 -04:00
|
|
|
}
|
|
|
|
|
2024-12-12 23:03:05 -04:00
|
|
|
struct MarketWidgetEntryView: View {
|
|
|
|
var entry: MarketWidgetEntry
|
|
|
|
|
|
|
|
var MarketStack: some View {
|
|
|
|
MarketView(marketData: entry.marketData)
|
2020-11-02 08:11:28 -05:00
|
|
|
}
|
2021-02-16 21:37:57 -05:00
|
|
|
|
|
|
|
var body: some View {
|
|
|
|
VStack(content: {
|
2024-12-12 23:03:05 -04:00
|
|
|
MarketStack.containerBackground(Color.widgetBackground, for: .widget)
|
2021-02-16 21:37:57 -05:00
|
|
|
})
|
|
|
|
}
|
2020-10-30 10:19:38 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
struct MarketWidget: Widget {
|
2024-12-12 23:03:05 -04:00
|
|
|
let kind: String = "MarketWidget"
|
|
|
|
|
|
|
|
var body: some WidgetConfiguration {
|
|
|
|
StaticConfiguration(kind: kind, provider: MarketWidgetProvider()) { entry in
|
|
|
|
MarketWidgetEntryView(entry: entry)
|
|
|
|
}
|
|
|
|
.configurationDisplayName("Market")
|
|
|
|
.description("View the current market information.").supportedFamilies([.systemSmall])
|
2020-10-30 10:19:38 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct MarketWidget_Previews: PreviewProvider {
|
2024-12-12 23:03:05 -04:00
|
|
|
static var previews: some View {
|
|
|
|
MarketWidgetEntryView(entry: MarketWidgetEntry(date: Date(), marketData: MarketData(nextBlock: "26", sats: "9,134", price: "$10,000", rate: 0)))
|
|
|
|
.previewContext(WidgetPreviewContext(family: .systemSmall))
|
|
|
|
}
|
2020-10-30 10:19:38 -04:00
|
|
|
}
|