HistoryView: Compact UI for phones
This commit is contained in:
@@ -86,7 +86,7 @@ class BrowserHistory
|
||||
}
|
||||
}
|
||||
|
||||
public func viewModel(forFilterString filterString: String? = nil, limit: Int? = nil) -> ViewModel {
|
||||
public func viewModel(forFilterString filterString: String? = nil, limit: Int = 500) -> ViewModel {
|
||||
let resultsController = fetchRequestController(forQuery: filterString, limit: limit)
|
||||
return ViewModel(fetchedResultsController: resultsController, historyController: self)
|
||||
}
|
||||
@@ -107,7 +107,7 @@ class BrowserHistory
|
||||
}
|
||||
}
|
||||
|
||||
public func allHistory(filteredBy filterString: String? = nil, limit: Int? = nil) -> [HistoryItem] {
|
||||
public func allHistory(filteredBy filterString: String? = nil, limit: Int = 500) -> [HistoryItem] {
|
||||
let dataContext = persistentContainer.viewContext
|
||||
let fetchRequest = fetchRequest(forStringContaining: filterString, limit: limit)
|
||||
let entities: [HistoryItemEntity] = (try? dataContext.fetch(fetchRequest)) ?? []
|
||||
@@ -160,24 +160,21 @@ class BrowserHistory
|
||||
|
||||
extension BrowserHistory
|
||||
{
|
||||
fileprivate func fetchRequestController(forQuery query: String? = nil, limit: Int? = nil) -> NSFetchedResultsController<HistoryItemEntity> {
|
||||
fileprivate func fetchRequestController(forQuery query: String? = nil, limit: Int = 500) -> NSFetchedResultsController<HistoryItemEntity> {
|
||||
let fetchRequest = fetchRequest(forStringContaining: query, limit: limit)
|
||||
return NSFetchedResultsController(fetchRequest: fetchRequest,
|
||||
managedObjectContext: persistentContainer.viewContext,
|
||||
sectionNameKeyPath: nil, cacheName: nil)
|
||||
}
|
||||
|
||||
fileprivate func fetchRequest(forStringContaining filterString: String? = nil, limit: Int? = nil) -> NSFetchRequest<HistoryItemEntity> {
|
||||
fileprivate func fetchRequest(forStringContaining filterString: String? = nil, limit: Int = 500) -> NSFetchRequest<HistoryItemEntity> {
|
||||
let fetchRequest: NSFetchRequest<HistoryItemEntity> = HistoryItemEntity.fetchRequest()
|
||||
fetchRequest.fetchLimit = limit
|
||||
fetchRequest.sortDescriptors = [
|
||||
// Sort by date
|
||||
NSSortDescriptor(keyPath: \HistoryItemEntity.lastVisited, ascending: false)
|
||||
]
|
||||
|
||||
if let limit {
|
||||
fetchRequest.fetchLimit = limit
|
||||
}
|
||||
|
||||
if let filterString, filterString.count > 0 {
|
||||
fetchRequest.predicate = NSPredicate(format: """
|
||||
host CONTAINS[cd] %@
|
||||
|
||||
@@ -5,6 +5,7 @@
|
||||
// Created by James Magahern on 8/14/20.
|
||||
//
|
||||
|
||||
import CoreData
|
||||
import Foundation
|
||||
|
||||
struct HistoryItem: Hashable, Identifiable
|
||||
|
||||
@@ -473,6 +473,7 @@ class BrowserViewController: UIViewController
|
||||
let historyViewController = HistoryBrowserViewController()
|
||||
historyViewController.title = "History"
|
||||
historyViewController.navigationItem.rightBarButtonItem = UIBarButtonItem(systemItem: .done, primaryAction: UIAction { _ in
|
||||
// xxx: This is not the SwiftUI-y way to do this.
|
||||
historyViewController.dismiss(animated: true)
|
||||
})
|
||||
|
||||
|
||||
@@ -19,16 +19,25 @@ struct HistoryView: View {
|
||||
}
|
||||
|
||||
@Environment(\.dismiss) private var dismissAction
|
||||
|
||||
@Environment(\.horizontalSizeClass) private var horizontalSizeClass
|
||||
|
||||
var body: some View {
|
||||
Table(viewModel.historyItems, selection: $selectedItems) {
|
||||
TableColumn("Title", value: \.title)
|
||||
|
||||
TableColumn("URL") { item in
|
||||
Text(item.url.absoluteString)
|
||||
TableColumn("Title") { item in
|
||||
VStack(alignment: .leading) {
|
||||
Text(item.title.count > 0 ? item.title : item.url.absoluteString)
|
||||
.lineLimit(1)
|
||||
|
||||
if horizontalSizeClass == .compact {
|
||||
Text(item.url.shortString()).font(.caption).lineLimit(1)
|
||||
Text(dateFormatter.string(from: item.lastVisited))
|
||||
.font(.caption)
|
||||
.foregroundColor(.secondary)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
TableColumn("Last Visited") { item in
|
||||
TableColumn("URL", value: \.url.absoluteString)
|
||||
TableColumn("Last Visited") { item in
|
||||
Text(dateFormatter.string(from: item.lastVisited))
|
||||
}
|
||||
}
|
||||
@@ -61,3 +70,9 @@ struct HistoryViewPreviewProvider: PreviewProvider {
|
||||
}
|
||||
}
|
||||
|
||||
extension URL {
|
||||
public func shortString() -> String {
|
||||
return String(absoluteString.trimmingPrefix(try! Regex("(.+)://")))
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user