passforios/pass/Controllers/AboutRepositoryTableViewController.swift

93 lines
3.8 KiB
Swift
Raw 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 UIKit
class AboutRepositoryTableViewController: BasicStaticTableViewController {
var needRefresh = false
2017-03-19 14:36:20 -07:00
var indicator: UIActivityIndicatorView = {
let indicator = UIActivityIndicatorView(activityIndicatorStyle: .gray)
return indicator
}()
let passwordStore = PasswordStore.shared
2017-02-09 22:13:31 +08:00
override func viewDidLoad() {
navigationItemTitle = "About Repository"
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)
setTableData()
// all password store updates (including erase, discard) will trigger the refresh
NotificationCenter.default.addObserver(self, selector: #selector(setNeedRefresh), name: .passwordStoreUpdated, object: nil)
}
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)
if needRefresh {
setTableData()
needRefresh = false
}
}
private func setTableData() {
// clear current contents (if any)
self.tableData.removeAll(keepingCapacity: true)
self.tableView.reloadData()
indicator.startAnimating()
// reload the table
DispatchQueue.global(qos: .userInitiated).async {
2017-02-10 17:49:20 +08:00
let numberFormatter = NumberFormatter()
numberFormatter.numberStyle = NumberFormatter.Style.decimal
let fm = FileManager.default
2017-02-10 17:49:20 +08:00
let passwordEntities = self.passwordStore.fetchPasswordEntityCoreData(withDir: false)
2017-02-10 17:49:20 +08:00
let numberOfPasswords = numberFormatter.string(from: NSNumber(value: passwordEntities.count))!
var size = UInt64(0)
do {
if fm.fileExists(atPath: self.passwordStore.storeURL.path) {
size = try fm.allocatedSizeOfDirectoryAtURL(directoryURL: self.passwordStore.storeURL)
2017-02-13 14:30:38 +08:00
}
} catch {
print(error)
}
2017-02-10 17:49:20 +08:00
let sizeOfRepository = ByteCountFormatter.string(fromByteCount: Int64(size), countStyle: ByteCountFormatter.CountStyle.file)
let numberOfCommits = self.passwordStore.storeRepository?.numberOfCommits(inCurrentBranch: NSErrorPointer(nilLiteral: ())) ?? 0
2017-02-10 17:49:20 +08:00
let numberOfCommitsString = numberFormatter.string(from: NSNumber(value: numberOfCommits))!
DispatchQueue.main.async { [weak self] in
2017-02-10 17:49:20 +08:00
let type = UITableViewCellAccessoryType.none
self?.tableData = [
// section 0
2017-02-10 17:49:20 +08:00
[[.style: CellDataStyle.value1, .accessoryType: type, .title: "Passwords", .detailText: numberOfPasswords],
2017-03-19 14:36:20 -07:00
[.style: CellDataStyle.value1, .accessoryType: type, .title: "Size", .detailText: sizeOfRepository],
[.style: CellDataStyle.value1, .accessoryType: type, .title: "Local Commits", .detailText: String(self?.passwordStore.numberOfLocalCommits() ?? 0)],
2017-02-10 17:49:20 +08:00
[.style: CellDataStyle.value1, .accessoryType: type, .title: "Last Synced", .detailText: Utils.getLastUpdatedTimeString()],
[.style: CellDataStyle.value1, .accessoryType: type, .title: "Commits", .detailText: numberOfCommitsString],
[.title: "Commit Logs", .action: "segue", .link: "showCommitLogsSegue"],
],
]
self?.indicator.stopAnimating()
self?.tableView.reloadData()
}
2017-02-10 00:50:03 +08:00
}
2017-02-09 22:13:31 +08:00
}
func setNeedRefresh() {
needRefresh = true
}
2017-02-09 22:13:31 +08:00
}