Merge branch 'feature/iphone_functional' into 'develop'

Make it more user friendly

See merge request BPHV_MIPS/jsoncreator_ios!1
This commit is contained in:
Pfeil, Scott Robert 2019-08-14 15:47:43 -04:00
commit 775139401a
4 changed files with 97 additions and 27 deletions

View File

@ -13,15 +13,10 @@ import MVMCoreUI
class AppDelegate: UIResponder, UIApplicationDelegate, UISplitViewControllerDelegate { class AppDelegate: UIResponder, UIApplicationDelegate, UISplitViewControllerDelegate {
var window: UIWindow? var window: UIWindow?
var mvcNav: UINavigationController?
func itera(_ path: String) { var dvcNav: UINavigationController?
let fileManager = FileManager.default var mvc: UIViewController?
let enumerator = fileManager.enumerator(atPath: path)! var dvc: UIViewController?
for element in enumerator {
//do something
print(element)
}
}
func application(_ application: UIApplication, willFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey : Any]? = nil) -> Bool { func application(_ application: UIApplication, willFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey : Any]? = nil) -> Bool {
// Setup our core object with the default implementation // Setup our core object with the default implementation
@ -30,14 +25,29 @@ class AppDelegate: UIResponder, UIApplicationDelegate, UISplitViewControllerDele
} }
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool { func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
itera(Bundle.main.resourcePath! + "/JSON")
// Override point for customization after application launch. // Override point for customization after application launch.
let splitViewController = window!.rootViewController as! UISplitViewController let splitViewController = window!.rootViewController as! UISplitViewController
let navigationController = splitViewController.viewControllers[splitViewController.viewControllers.count-1] as! UINavigationController mvcNav = splitViewController.viewControllers[0] as? UINavigationController
navigationController.topViewController!.navigationItem.leftBarButtonItem = splitViewController.displayModeButtonItem mvcNav?.delegate = self
mvc = mvcNav?.topViewController
dvcNav = splitViewController.viewControllers[splitViewController.viewControllers.count-1] as? UINavigationController
dvc = dvcNav?.topViewController
dvc?.navigationItem.leftBarButtonItem = splitViewController.displayModeButtonItem
dvc?.navigationItem.leftItemsSupplementBackButton = true
splitViewController.delegate = self splitViewController.delegate = self
splitViewController.preferredDisplayMode = .allVisible splitViewController.preferredDisplayMode = .allVisible
NotificationCenter.default.addObserver(forName: UIViewController.showDetailTargetDidChangeNotification, object: splitViewController, queue: nil) { [weak self] (notification) in
if let strongSelf = self, let svc = notification.object as? UISplitViewController {
if svc.isCollapsed {
strongSelf.mvc?.navigationItem.rightBarButtonItem = UIBarButtonItem(title: "Editor", style: .plain, target: self, action: #selector(self?.showEditor))
} else {
strongSelf.mvcNav?.setViewControllers([strongSelf.mvc!], animated: false)
strongSelf.mvc?.navigationItem.rightBarButtonItem = nil
}
}
}
return true return true
} }
@ -66,10 +76,21 @@ class AppDelegate: UIResponder, UIApplicationDelegate, UISplitViewControllerDele
// MARK: - Split view // MARK: - Split view
func splitViewController(_ splitViewController: UISplitViewController, collapseSecondary secondaryViewController:UIViewController, onto primaryViewController:UIViewController) -> Bool { func splitViewController(_ splitViewController: UISplitViewController, collapseSecondary secondaryViewController:UIViewController, onto primaryViewController:UIViewController) -> Bool {
guard let secondaryAsNavController = secondaryViewController as? UINavigationController else { return false } //guard let secondaryAsNavController = secondaryViewController as? UINavigationController else { return false }
guard let _ = secondaryAsNavController.topViewController as? DetailViewController else { return false } //guard let _ = secondaryAsNavController.topViewController as? DetailViewController else { return false }
return false return true
} }
@objc func showEditor() {
mvcNav?.pushViewController(dvc!, animated: true)
}
}
extension AppDelegate: UINavigationControllerDelegate {
func navigationController(_ navigationController: UINavigationController, didShow viewController: UIViewController, animated: Bool) {
if mvc == viewController {
dvcNav?.setViewControllers([dvc!], animated: false)
}
}
} }

View File

@ -20,7 +20,11 @@ class DetailViewController: UIViewController {
return return
} }
view.addSubview(textView) view.addSubview(textView)
textView.font = UIFont.systemFont(ofSize: 40) if UIDevice.current.userInterfaceIdiom == .pad {
textView.font = UIFont.systemFont(ofSize: 40)
} else {
textView.font = UIFont.systemFont(ofSize: 14)
}
textView.translatesAutoresizingMaskIntoConstraints = false textView.translatesAutoresizingMaskIntoConstraints = false
textView.leadingAnchor.constraint(equalTo: view.leadingAnchor).isActive = true textView.leadingAnchor.constraint(equalTo: view.leadingAnchor).isActive = true
textView.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor).isActive = true textView.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor).isActive = true

View File

@ -43,6 +43,7 @@
<string>UIInterfaceOrientationPortrait</string> <string>UIInterfaceOrientationPortrait</string>
<string>UIInterfaceOrientationLandscapeLeft</string> <string>UIInterfaceOrientationLandscapeLeft</string>
<string>UIInterfaceOrientationLandscapeRight</string> <string>UIInterfaceOrientationLandscapeRight</string>
<string>UIInterfaceOrientationPortraitUpsideDown</string>
</array> </array>
<key>UISupportedInterfaceOrientations~ipad</key> <key>UISupportedInterfaceOrientations~ipad</key>
<array> <array>

View File

@ -11,31 +11,57 @@ import UIKit
class MasterViewController: UITableViewController { class MasterViewController: UITableViewController {
let folderPath = Bundle.main.resourcePath! + "/JSON" let folderPath = Bundle.main.resourcePath! + "/JSON"
var sectionsMap: [AnyHashable: Any] = [:]
override func viewDidLoad() { override func viewDidLoad() {
super.viewDidLoad() super.viewDidLoad()
// Do any additional setup after loading the view. // Do any additional setup after loading the view.
// setup the data
sectionsMap = [:]
let sections = try! FileManager.default.contentsOfDirectory(atPath: folderPath)
for section in sections {
let paths = try! FileManager.default.subpathsOfDirectory(atPath: "\(folderPath)/\(section)")
var array: [String] = []
for path in paths {
if path.hasSuffix(".json") {
array.append(path)
}
}
sectionsMap[section] = array
}
}
func getData(for indexPath: IndexPath) -> String? {
let sectionName = self.tableView(tableView, titleForHeaderInSection: indexPath.section)
let array = sectionsMap[sectionName!]! as! Array<Any>
let subPath = (array[indexPath.row] as! String)
let path = "\(folderPath)/\(sectionName!)/\(subPath)"
return try! String.init(contentsOfFile: path)
} }
// MARK: - Table View // MARK: - Table View
override func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? { override func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
return try! FileManager.default.contentsOfDirectory(atPath: folderPath)[section] return (((sectionsMap as NSDictionary).allKeys[section]) as! String)
} }
override func numberOfSections(in tableView: UITableView) -> Int { override func numberOfSections(in tableView: UITableView) -> Int {
return try! FileManager.default.contentsOfDirectory(atPath: folderPath).count return sectionsMap.count
} }
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return try! FileManager.default.contentsOfDirectory(atPath: folderPath + "/" + FileManager.default.contentsOfDirectory(atPath: folderPath)[section]).count let sectionName = self.tableView(tableView, titleForHeaderInSection: section)
let array = sectionsMap.arrayForKey(sectionName!)
return array.count
} }
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath)
let name = try! FileManager.default.contentsOfDirectory(atPath: folderPath + "/" + FileManager.default.contentsOfDirectory(atPath: folderPath)[indexPath.section])[indexPath.row] let sectionName = self.tableView(tableView, titleForHeaderInSection: indexPath.section)
cell.textLabel?.text = name let array = sectionsMap[sectionName!]! as! Array<Any>
cell.textLabel?.text = (array[indexPath.row] as! String)
if cell.interactions.first == nil { if cell.interactions.first == nil {
let dragInteraction = UIDragInteraction(delegate: self) let dragInteraction = UIDragInteraction(delegate: self)
@ -48,16 +74,34 @@ class MasterViewController: UITableViewController {
// Return false if you do not want the specified item to be editable. // Return false if you do not want the specified item to be editable.
return true return true
} }
override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
UIPasteboard.general.string = getData(for: indexPath)
let label = UILabel(frame: .zero)
label.clipsToBounds = true
label.backgroundColor = .gray
label.text = " Copied "
label.font = UIFont.systemFont(ofSize: 40)
label.translatesAutoresizingMaskIntoConstraints = false
label.layer.cornerRadius = 5
view.superview!.addSubview(label)
label.centerXAnchor.constraint(equalTo: view.superview!.centerXAnchor).isActive = true
label.centerYAnchor.constraint(equalTo: view.superview!.centerYAnchor).isActive = true
UIView.animate(withDuration: 2, animations: {
label.alpha = 0
}) { (completed) in
label.removeFromSuperview()
}
}
} }
extension MasterViewController: UIDragInteractionDelegate { extension MasterViewController: UIDragInteractionDelegate {
func dragInteraction(_ interaction: UIDragInteraction, itemsForBeginning session: UIDragSession) -> [UIDragItem] { func dragInteraction(_ interaction: UIDragInteraction, itemsForBeginning session: UIDragSession) -> [UIDragItem] {
let location = session.location(in: tableView) let location = session.location(in: tableView)
let indexPath = tableView.indexPathForRow(at: location) let indexPath = tableView.indexPathForRow(at: location)
let sectionName = try! FileManager.default.contentsOfDirectory(atPath: folderPath)[indexPath!.section] let content = getData(for: indexPath!)
let path = try! folderPath + "/" + sectionName + "/" + FileManager.default.contentsOfDirectory(atPath: folderPath + "/" + sectionName)[indexPath!.row] let provider = NSItemProvider(object: content! as NSString)
let content = try! String.init(contentsOfFile: path)
let provider = NSItemProvider(object: content as NSString)
let item = UIDragItem(itemProvider: provider) let item = UIDragItem(itemProvider: provider)
return [item] return [item]
} }