Files
Attractor/App/History UI/HistoryView.swift

64 lines
1.9 KiB
Swift
Raw Normal View History

2023-01-20 17:28:15 -08:00
//
// HistoryView.swift
// App
//
// Created by James Magahern on 1/20/23.
//
import SwiftUI
import UniformTypeIdentifiers
struct HistoryView: View {
@StateObject public var viewModel: BrowserHistory.ViewModel
2023-01-20 17:28:15 -08:00
@State public var selectedItems = Set<HistoryItem.ID>()
private let dateFormatter = DateFormatter() .. {
$0.locale = Locale.current
$0.dateStyle = .medium
$0.timeStyle = .short
2023-01-20 17:28:15 -08:00
}
@Environment(\.dismiss) private var dismissAction
2023-01-20 17:28:15 -08:00
var body: some View {
Table(viewModel.historyItems, selection: $selectedItems) {
2023-01-20 17:28:15 -08:00
TableColumn("Title", value: \.title)
TableColumn("URL") { item in
Text(item.url.absoluteString)
}
TableColumn("Last Visited") { item in
Text(dateFormatter.string(from: item.lastVisited))
}
}
.contextMenu(forSelectionType: HistoryItem.ID.self, menu: { items in
let historyItems = items.compactMap { viewModel.item(forIdentifier: $0) }
Button("Copy") {
UIPasteboard.general.setItems(historyItems.map { [
UTType.url.identifier : $0.url,
UTType.utf8PlainText.identifier : $0.url.absoluteString,
] })
}
Button("Delete") {
viewModel.deleteItems(items)
2023-01-20 17:28:15 -08:00
}
}, primaryAction: { items in
items.compactMap({ viewModel.item(forIdentifier: $0) }).forEach { item in
UIApplication.shared.open(item.url)
2023-01-20 17:28:15 -08:00
dismissAction()
}
})
.searchable(text: $viewModel.searchQuery)
2023-01-20 17:28:15 -08:00
}
}
struct HistoryViewPreviewProvider: PreviewProvider {
static var previews: some View {
HistoryView(viewModel: BrowserHistory.shared.viewModel())
2023-01-20 17:28:15 -08:00
.previewLayout(.fixed(width: 480.0, height: 800.0))
}
}