NCViewerPDF.swift 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. //
  2. // NCViewerPDF.swift
  3. // Nextcloud
  4. //
  5. // Created by Marino Faggiana on 06/02/2020.
  6. // Copyright © 2020 Marino Faggiana. All rights reserved.
  7. //
  8. // Author Marino Faggiana <marino.faggiana@nextcloud.com>
  9. //
  10. // This program is free software: you can redistribute it and/or modify
  11. // it under the terms of the GNU General Public License as published by
  12. // the Free Software Foundation, either version 3 of the License, or
  13. // (at your option) any later version.
  14. //
  15. // This program is distributed in the hope that it will be useful,
  16. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. // GNU General Public License for more details.
  19. //
  20. // You should have received a copy of the GNU General Public License
  21. // along with this program. If not, see <http://www.gnu.org/licenses/>.
  22. //
  23. import Foundation
  24. import PDFKit
  25. @available(iOS 11, *)
  26. @objc class NCViewerPDF: PDFView, NCViewerPDFSearchDelegate {
  27. private let appDelegate = UIApplication.shared.delegate as! AppDelegate
  28. private var thumbnailViewHeight: CGFloat = 40
  29. private var pdfThumbnailView: PDFThumbnailView?
  30. private var pdfDocument: PDFDocument?
  31. private let pageView = UIView()
  32. private let pageViewLabel = UILabel()
  33. private var pageViewWidthAnchor : NSLayoutConstraint?
  34. required init?(coder: NSCoder) {
  35. super.init(coder: coder)
  36. }
  37. override init(frame: CGRect) {
  38. let height = frame.height - thumbnailViewHeight
  39. super.init(frame: CGRect(x: frame.origin.x, y: frame.origin.y, width: frame.width, height: height))
  40. NotificationCenter.default.addObserver(self, selector: #selector(changeTheming), name: NSNotification.Name(rawValue: k_notificationCenter_changeTheming), object: nil)
  41. NotificationCenter.default.addObserver(self, selector: #selector(searchText), name: NSNotification.Name(rawValue: k_notificationCenter_menuSearchTextPDF), object: nil)
  42. NotificationCenter.default.addObserver(self, selector: #selector(handlePageChange), name: Notification.Name.PDFViewPageChanged, object: nil)
  43. }
  44. @objc func setupPdfView(filePath: URL, view: UIView) {
  45. pdfDocument = PDFDocument(url: filePath)
  46. document = pdfDocument
  47. backgroundColor = NCBrandColor.sharedInstance.backgroundView
  48. displayMode = .singlePageContinuous
  49. autoScales = true
  50. displayDirection = .horizontal
  51. autoresizingMask = [.flexibleWidth, .flexibleHeight, .flexibleTopMargin, .flexibleBottomMargin]
  52. usePageViewController(true, withViewOptions: nil)
  53. view.addSubview(self)
  54. pdfThumbnailView = PDFThumbnailView()
  55. pdfThumbnailView!.translatesAutoresizingMaskIntoConstraints = false
  56. pdfThumbnailView!.pdfView = self
  57. pdfThumbnailView!.layoutMode = .horizontal
  58. pdfThumbnailView!.thumbnailSize = CGSize(width: 40, height: thumbnailViewHeight)
  59. //pdfThumbnailView.layer.shadowOffset.height = -5
  60. //pdfThumbnailView.layer.shadowOpacity = 0.25
  61. view.addSubview(pdfThumbnailView!)
  62. pdfThumbnailView!.heightAnchor.constraint(equalToConstant: thumbnailViewHeight).isActive = true
  63. pdfThumbnailView!.leadingAnchor.constraint(equalTo: view.safeAreaLayoutGuide.leadingAnchor).isActive = true
  64. pdfThumbnailView!.trailingAnchor.constraint(equalTo: view.safeAreaLayoutGuide.trailingAnchor).isActive = true
  65. pdfThumbnailView!.bottomAnchor.constraint(equalTo: view.safeAreaLayoutGuide.bottomAnchor).isActive = true
  66. pageView.translatesAutoresizingMaskIntoConstraints = false
  67. pageView.layer.cornerRadius = 10
  68. pageView.backgroundColor = UIColor.gray.withAlphaComponent(0.3)
  69. view.addSubview(pageView)
  70. pageView.heightAnchor.constraint(equalToConstant: 30).isActive = true
  71. pageViewWidthAnchor = pageView.widthAnchor.constraint(equalToConstant: 10)
  72. pageViewWidthAnchor?.isActive = true
  73. pageView.topAnchor.constraint(equalTo: view.safeAreaLayoutGuide.topAnchor, constant: 5).isActive = true
  74. pageView.leftAnchor.constraint(equalTo: view.safeAreaLayoutGuide.leftAnchor, constant: 5).isActive = true
  75. pageViewLabel.translatesAutoresizingMaskIntoConstraints = false
  76. pageViewLabel.textAlignment = .center
  77. pageViewLabel.textColor = .gray
  78. pageView.addSubview(pageViewLabel)
  79. pageViewLabel.leftAnchor.constraint(equalTo: pageView.leftAnchor).isActive = true
  80. pageViewLabel.rightAnchor.constraint(equalTo: pageView.rightAnchor).isActive = true
  81. pageViewLabel.topAnchor.constraint(equalTo: pageView.topAnchor).isActive = true
  82. pageViewLabel.bottomAnchor.constraint(equalTo: pageView.bottomAnchor).isActive = true
  83. view.layoutIfNeeded()
  84. handlePageChange()
  85. let tapGesture = UITapGestureRecognizer(target: self, action: #selector(didTap(_:)))
  86. tapGesture.numberOfTapsRequired = 1
  87. view.addGestureRecognizer(tapGesture)
  88. }
  89. //MARK: - NotificationCenter
  90. @objc private func handlePageChange() {
  91. guard let curPage = currentPage?.pageRef?.pageNumber else { pageView.alpha = 0; return }
  92. guard let totalPages = document?.pageCount else { return }
  93. pageView.alpha = 1
  94. pageViewLabel.text = String(curPage) + " " + NSLocalizedString("_of_", comment: "") + " " + String(totalPages)
  95. pageViewWidthAnchor?.constant = pageViewLabel.intrinsicContentSize.width + 10
  96. UIView.animate(withDuration: 1.0, delay: 3.0, animations: {
  97. self.pageView.alpha = 0
  98. })
  99. }
  100. @objc func changeTheming() {
  101. guard let navigationController = appDelegate.activeDetail.navigationController else { return }
  102. if navigationController.isNavigationBarHidden == false {
  103. backgroundColor = NCBrandColor.sharedInstance.backgroundView
  104. }
  105. }
  106. //MARK: - Gesture Recognizer
  107. @objc func didTap(_ recognizer: UITapGestureRecognizer) {
  108. guard let navigationController = appDelegate.activeDetail.navigationController else { return }
  109. if navigationController.isNavigationBarHidden {
  110. appDelegate.activeDetail.navigateControllerBarHidden(false)
  111. pdfThumbnailView!.isHidden = false
  112. backgroundColor = NCBrandColor.sharedInstance.backgroundView
  113. } else {
  114. let point = recognizer.location(in: self)
  115. if point.y > self.frame.height - thumbnailViewHeight { return }
  116. appDelegate.activeDetail.navigateControllerBarHidden(true)
  117. pdfThumbnailView!.isHidden = true
  118. backgroundColor = .black
  119. }
  120. let size = self.appDelegate.activeDetail.backgroundView!.bounds
  121. var height: CGFloat = 0
  122. if navigationController.isNavigationBarHidden {
  123. height = size.height - size.origin.y
  124. } else {
  125. height = size.height - size.origin.y - self.thumbnailViewHeight
  126. }
  127. self.frame = CGRect(x: 0, y: 0, width: size.width, height: height)
  128. }
  129. //MARK: -
  130. @objc func searchText() {
  131. let viewerPDFSearch = UIStoryboard.init(name: "NCViewerPDF", bundle: nil).instantiateViewController(withIdentifier: "NCViewerPDFSearch") as! NCViewerPDFSearch
  132. viewerPDFSearch.delegate = self
  133. viewerPDFSearch.pdfDocument = pdfDocument
  134. let navigaionController = UINavigationController.init(rootViewController: viewerPDFSearch)
  135. appDelegate.activeDetail.present(navigaionController, animated: true)
  136. }
  137. func searchPdfSelection(_ pdfSelection: PDFSelection) {
  138. pdfSelection.color = .yellow
  139. currentSelection = pdfSelection
  140. go(to: pdfSelection)
  141. }
  142. }