passforios/pass/Controllers/AboutRepositoryTableViewController.swift

108 lines
4 KiB
Swift
Raw Permalink Normal View History

2017-02-09 22:13:31 +08:00
//
// AboutRepositoryTableViewController.swift
// pass
//
// Created by Mingshen Sun on 9/2/2017.
// Copyright © 2017 Bob Sun. All rights reserved.
//
import passKit
import UIKit
2017-02-09 22:13:31 +08:00
class AboutRepositoryTableViewController: BasicStaticTableViewController {
2019-01-14 20:57:45 +01:00
private static let VALUE_NOT_AVAILABLE = "ValueNotAvailable".localize()
private var needRefresh = false
private var indicator = UIActivityIndicatorView(style: .medium)
private let passwordStore = PasswordStore.shared
2017-02-09 22:13:31 +08:00
override func viewDidLoad() {
super.viewDidLoad()
2017-03-19 14:36:20 -07:00
2017-03-24 21:54:31 +08:00
indicator.center = CGPoint(x: view.bounds.midX, y: view.bounds.height * 0.382)
tableView.addSubview(indicator)
2018-12-09 16:59:07 -08:00
setTableData()
2018-12-09 16:59:07 -08:00
// all password store updates (including erase, discard) will trigger the refresh
NotificationCenter.default.addObserver(self, selector: #selector(setNeedRefresh), name: .passwordStoreUpdated, object: nil)
}
2018-12-09 16:59:07 -08:00
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)
if needRefresh {
setTableData()
needRefresh = false
}
}
2018-12-09 16:59:07 -08:00
private func setTableData() {
// clear current contents (if any)
tableData.removeAll(keepingCapacity: true)
tableView.reloadData()
indicator.startAnimating()
2018-12-09 16:59:07 -08:00
// reload the table
DispatchQueue.global(qos: .userInitiated).async {
let passwords = self.numberOfPasswordsString()
let size = self.sizeOfRepositoryString()
let localCommits = String(self.passwordStore.numberOfLocalCommits)
let lastSynced = self.lastSyncedTimeString()
let commits = self.numberOfCommitsString()
2018-12-09 16:59:07 -08:00
DispatchQueue.main.async { [weak self] in
guard let strongSelf = self else {
return
}
2019-05-01 17:49:27 +02:00
let type = UITableViewCell.AccessoryType.none
strongSelf.tableData = [
// section 0
[
[.style: CellDataStyle.value1, .accessoryType: type, .title: "Passwords".localize(), .detailText: passwords],
[.style: CellDataStyle.value1, .accessoryType: type, .title: "Size".localize(), .detailText: size],
[.style: CellDataStyle.value1, .accessoryType: type, .title: "LocalCommits".localize(), .detailText: localCommits],
[.style: CellDataStyle.value1, .accessoryType: type, .title: "LastSynced".localize(), .detailText: lastSynced],
[.style: CellDataStyle.value1, .accessoryType: type, .title: "Commits".localize(), .detailText: commits],
[.title: "CommitLogs".localize(), .action: "segue", .link: "showCommitLogsSegue"],
],
]
strongSelf.indicator.stopAnimating()
strongSelf.tableView.reloadData()
}
}
}
private func numberOfPasswordsString() -> String {
let formatter = NumberFormatter()
formatter.numberStyle = NumberFormatter.Style.decimal
return formatter.string(from: NSNumber(value: passwordStore.numberOfPasswords)) ?? ""
}
private func sizeOfRepositoryString() -> String {
ByteCountFormatter.string(fromByteCount: Int64(passwordStore.sizeOfRepositoryByteCount), countStyle: ByteCountFormatter.CountStyle.file)
}
private func lastSyncedTimeString() -> String {
guard let date = passwordStore.lastSyncedTime else {
2019-01-14 20:57:45 +01:00
return "SyncAgain?".localize()
2017-02-10 00:50:03 +08:00
}
let formatter = DateFormatter()
formatter.dateStyle = .medium
formatter.timeStyle = .short
return formatter.string(from: date)
2017-02-09 22:13:31 +08:00
}
2018-12-09 16:59:07 -08:00
private func numberOfCommitsString() -> String {
if let numberOfCommits = passwordStore.numberOfCommits {
return String(numberOfCommits)
}
return Self.VALUE_NOT_AVAILABLE
}
@objc
func setNeedRefresh() {
needRefresh = true
}
2017-02-09 22:13:31 +08:00
}