mirror of
https://github.com/BlueWallet/BlueWallet.git
synced 2025-02-26 09:01:56 +01:00
110 lines
4.6 KiB
Swift
110 lines
4.6 KiB
Swift
//
|
|
// MarketWidget.swift
|
|
// MarketWidget
|
|
//
|
|
// Created by Marcos Rodriguez on 10/29/20.
|
|
// Copyright © 2020 BlueWallet. All rights reserved.
|
|
//
|
|
|
|
import WidgetKit
|
|
import SwiftUI
|
|
|
|
struct Provider: TimelineProvider {
|
|
func placeholder(in context: Context) -> SimpleEntry {
|
|
SimpleEntry(date: Date(), marketData: emptyMarketData)
|
|
}
|
|
|
|
func getSnapshot(in context: Context, completion: @escaping (SimpleEntry) -> ()) {
|
|
let entry: SimpleEntry
|
|
if (context.isPreview) {
|
|
entry = SimpleEntry(date: Date(), marketData: MarketData(nextBlock: "26", sats: "9 134", price: "$10 000", rate: 10000))
|
|
} else {
|
|
entry = SimpleEntry(date: Date(), marketData: emptyMarketData)
|
|
}
|
|
completion(entry)
|
|
}
|
|
|
|
func getTimeline(in context: Context, completion: @escaping (Timeline<Entry>) -> ()) {
|
|
var entries: [SimpleEntry] = []
|
|
let userPreferredCurrency = WidgetAPI.getUserPreferredCurrency();
|
|
let marketDataEntry = MarketData(nextBlock: "...", sats: "...", price: "...", rate: 0)
|
|
WidgetAPI.fetchMarketData(currency: userPreferredCurrency, completion: { (result, error) in
|
|
let entry: SimpleEntry
|
|
if let result = result {
|
|
entry = SimpleEntry(date: Date(), marketData: result)
|
|
|
|
} else {
|
|
entry = SimpleEntry(date: Date(), marketData: marketDataEntry)
|
|
}
|
|
entries.append(entry)
|
|
let timeline = Timeline(entries: entries, policy: .atEnd)
|
|
completion(timeline)
|
|
})
|
|
}
|
|
}
|
|
|
|
struct SimpleEntry: TimelineEntry {
|
|
let date: Date
|
|
let marketData: MarketData
|
|
}
|
|
|
|
struct MarketWidgetEntryView : View {
|
|
var entry: Provider.Entry
|
|
|
|
var MarketStack: some View {
|
|
VStack(alignment: .leading, spacing:23 , content: {
|
|
VStack(alignment: .leading, spacing: /*@START_MENU_TOKEN@*/nil/*@END_MENU_TOKEN@*/, content: {
|
|
Text("Market").font(.headline).foregroundColor(.textColor).bold()
|
|
Spacer()
|
|
HStack(alignment: .center, spacing: 0, content: {
|
|
Text("Next Block").bold().lineLimit(1).font(Font.system(size:11, weight: .medium, design: .default)).foregroundColor(.textColor)
|
|
Spacer()
|
|
Text(entry.marketData.formattedNextBlock).padding(EdgeInsets(top: 2, leading: 4, bottom: 2, trailing: 4)).lineLimit(1).foregroundColor(.widgetBackground).font(Font.system(size:11, weight: .semibold, design: .default)).background(Color(red: 0.29, green: 0.86, blue: 0.73)).overlay(
|
|
RoundedRectangle(cornerRadius: 4.0)
|
|
.stroke(Color.containerGreen, lineWidth: 4.0))
|
|
})
|
|
|
|
Spacer()
|
|
HStack(alignment: .center, spacing: 0, content: {
|
|
Text("Sats/Dollar").bold().lineLimit(1).font(Font.system(size:11, weight: .medium, design: .default)).foregroundColor(.textColor)
|
|
Spacer()
|
|
Text(entry.marketData.sats == "..." ? "..." : entry.marketData.sats).padding(EdgeInsets(top: 2, leading: 4, bottom: 2, trailing: 4)).lineLimit(1).foregroundColor(.widgetBackground).font(Font.system(size:11, weight: .semibold, design: .default)).background(Color(red: 0.97, green: 0.21, blue: 0.38)).overlay(
|
|
RoundedRectangle(cornerRadius: 4.0)
|
|
.stroke(Color.containerRed, lineWidth: 4.0))
|
|
})
|
|
Spacer()
|
|
HStack(alignment: .center, spacing: 0, content: {
|
|
Text("Price").bold().lineLimit(1).font(Font.system(size:11, weight: . medium, design: .default)).foregroundColor(.textColor)
|
|
Spacer()
|
|
Text(entry.marketData.price == "..." ? "..." : entry.marketData.price).padding(EdgeInsets(top: 2, leading: 4, bottom: 2, trailing: 4)).lineLimit(1).foregroundColor(.widgetBackground).font(Font.system(size:11, weight: .semibold, design: .default)).background(Color(red: 0.29, green: 0.86, blue: 0.73)).overlay(
|
|
RoundedRectangle(cornerRadius:4.0)
|
|
.stroke(Color.containerGreen, lineWidth: 4.0))
|
|
})
|
|
}).padding(EdgeInsets(top: 18, leading: 11, bottom: 18, trailing: 11))
|
|
})
|
|
}
|
|
|
|
var body: some View {
|
|
MarketStack.background(Color.widgetBackground)
|
|
}
|
|
}
|
|
|
|
@main
|
|
struct MarketWidget: Widget {
|
|
let kind: String = "MarketWidget"
|
|
|
|
var body: some WidgetConfiguration {
|
|
StaticConfiguration(kind: kind, provider: Provider()) { entry in
|
|
MarketWidgetEntryView(entry: entry)
|
|
}
|
|
.configurationDisplayName("Market")
|
|
.description("View the current market information.").supportedFamilies([.systemSmall])
|
|
}
|
|
}
|
|
|
|
struct MarketWidget_Previews: PreviewProvider {
|
|
static var previews: some View {
|
|
MarketWidgetEntryView(entry: SimpleEntry(date: Date(), marketData: MarketData(nextBlock: "26", sats: "9 134", price: "$10,000", rate: 0)))
|
|
.previewContext(WidgetPreviewContext(family: .systemSmall))
|
|
}
|
|
}
|