TextViewSpecialCaseViewController.swift 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. //
  2. // TextViewSpecialCaseViewController.swift
  3. // IQKeyboard
  4. //
  5. // Created by Iftekhar on 23/09/14.
  6. // Copyright (c) 2014 Iftekhar. All rights reserved.
  7. //
  8. import UIKit
  9. class TextViewSpecialCaseViewController: UIViewController, UITextViewDelegate, UIPopoverPresentationControllerDelegate {
  10. @IBOutlet var buttonPush: UIButton!
  11. @IBOutlet var buttonPresent: UIButton!
  12. override func viewDidLoad() {
  13. super.viewDidLoad()
  14. if self.navigationController == nil {
  15. buttonPush.isHidden = true
  16. buttonPresent.setTitle("Dismiss", for: .normal)
  17. }
  18. }
  19. override func viewWillAppear (_ animated: Bool) {
  20. super.viewWillAppear(animated)
  21. }
  22. func textView(_ textView: UITextView, shouldChangeTextIn range: NSRange, replacementText text: String) -> Bool {
  23. if text == "\n" {
  24. textView.resignFirstResponder()
  25. }
  26. return true
  27. }
  28. @IBAction func presentClicked (_ barButton: UIButton!) {
  29. if (navigationController) != nil {
  30. if let controller = self.storyboard?.instantiateViewController(withIdentifier: "TextViewSpecialCaseViewController") {
  31. present(controller, animated: true, completion: nil)
  32. }
  33. } else {
  34. dismiss(animated: true, completion: nil)
  35. }
  36. }
  37. override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
  38. guard let identifier = segue.identifier else {
  39. return
  40. }
  41. if identifier == "SettingsNavigationController" {
  42. let controller = segue.destination
  43. controller.modalPresentationStyle = .popover
  44. controller.popoverPresentationController?.barButtonItem = sender as? UIBarButtonItem
  45. let heightWidth = max(UIScreen.main.bounds.width, UIScreen.main.bounds.height)
  46. controller.preferredContentSize = CGSize(width: heightWidth, height: heightWidth)
  47. controller.popoverPresentationController?.delegate = self
  48. }
  49. }
  50. func adaptivePresentationStyle(for controller: UIPresentationController) -> UIModalPresentationStyle {
  51. return .none
  52. }
  53. func prepareForPopoverPresentation(_ popoverPresentationController: UIPopoverPresentationController) {
  54. self.view.endEditing(true)
  55. }
  56. override var shouldAutorotate: Bool {
  57. return true
  58. }
  59. }