From a6c81362487aa8eaf67ac8e8146fa75321dc2ed3 Mon Sep 17 00:00:00 2001 From: Vadym Markov Date: Wed, 31 Jan 2018 21:15:50 +0100 Subject: [PATCH 1/2] Implement state message provider to be able to set custom info messages --- .../BarcodeScannerViewController.swift | 4 +- .../Controllers/MessageViewController.swift | 20 ++++--- Sources/DataStructures/State.swift | 59 +++++++++++-------- 3 files changed, 46 insertions(+), 37 deletions(-) diff --git a/Sources/Controllers/BarcodeScannerViewController.swift b/Sources/Controllers/BarcodeScannerViewController.swift index 0fec743..eb835dc 100644 --- a/Sources/Controllers/BarcodeScannerViewController.swift +++ b/Sources/Controllers/BarcodeScannerViewController.swift @@ -128,7 +128,7 @@ open class BarcodeScannerViewController: UIViewController { private func changeStatus(from oldValue: Status, to newValue: Status) { guard newValue.state != .notFound else { - messageViewController.state = newValue.state + messageViewController.status = newValue DispatchQueue.main.asyncAfter(deadline: DispatchTime.now() + 2.0) { self.status = Status(state: .scanning) } @@ -153,7 +153,7 @@ open class BarcodeScannerViewController: UIViewController { expandedConstraints.activate() } - messageViewController.state = newValue.state + messageViewController.status = newValue UIView.animate( withDuration: duration, diff --git a/Sources/Controllers/MessageViewController.swift b/Sources/Controllers/MessageViewController.swift index b12ccb3..87b84f9 100644 --- a/Sources/Controllers/MessageViewController.swift +++ b/Sources/Controllers/MessageViewController.swift @@ -6,6 +6,8 @@ public final class MessageViewController: UIViewController { public var regularTintColor: UIColor = .black // Image tint color for `.notFound` state. public var errorTintColor: UIColor = .red + // Customizable state messages. + public var messages = StateMessageProvider() // MARK: - UI properties @@ -23,9 +25,9 @@ public final class MessageViewController: UIViewController { // Constraints that are activated when the view is used for loading animation and error messages. private lazy var expandedConstraints: [NSLayoutConstraint] = self.makeExpandedConstraints() - var state: State = .scanning { + var status = Status(state: .scanning) { didSet { - handleStateUpdate() + handleStatusUpdate() } } @@ -36,7 +38,7 @@ public final class MessageViewController: UIViewController { view.addSubview(blurView) blurView.contentView.addSubviews(textLabel, imageView, borderView) setupSubviews() - handleStateUpdate() + handleStatusUpdate() } public override func viewDidLayoutSubviews() { @@ -58,7 +60,7 @@ public final class MessageViewController: UIViewController { - Parameter style: The current blur style. */ private func animate(blurStyle: UIBlurEffectStyle) { - guard state == .processing else { return } + guard status.state == .processing else { return } UIView.animate( withDuration: 2.0, @@ -78,7 +80,7 @@ public final class MessageViewController: UIViewController { - Parameter angle: Rotation angle. */ private func animate(borderViewAngle: CGFloat) { - guard state == .processing else { + guard status.state == .processing else { borderView.transform = .identity return } @@ -117,12 +119,12 @@ public final class MessageViewController: UIViewController { // MARK: - State handling - private func handleStateUpdate() { + private func handleStatusUpdate() { borderView.isHidden = true borderView.layer.removeAllAnimations() - textLabel.text = state.text + textLabel.text = status.text ?? messages.makeText(for: status.state) - switch state { + switch status.state { case .scanning, .unauthorized: textLabel.font = UIFont.boldSystemFont(ofSize: 14) textLabel.numberOfLines = 3 @@ -141,7 +143,7 @@ public final class MessageViewController: UIViewController { imageView.tintColor = errorTintColor } - if state == .scanning || state == .unauthorized { + if status.state == .scanning || status.state == .unauthorized { expandedConstraints.deactivate() collapsedConstraints.activate() } else { diff --git a/Sources/DataStructures/State.swift b/Sources/DataStructures/State.swift index 1d6c68f..4c42de5 100644 --- a/Sources/DataStructures/State.swift +++ b/Sources/DataStructures/State.swift @@ -1,5 +1,36 @@ import UIKit +// MARK: - State + +/// Barcode scanner state. +enum State { + case scanning + case processing + case unauthorized + case notFound +} + +/// State message provider. +public struct StateMessageProvider { + public var scanningText = localizedString("INFO_DESCRIPTION_TEXT") + public var processingText = localizedString("INFO_LOADING_TITLE") + public var unathorizedText = localizedString("ASK_FOR_PERMISSION_TEXT") + public var notFoundText = localizedString("NO_PRODUCT_ERROR_TITLE") + + func makeText(for state: State) -> String { + switch state { + case .scanning: + return scanningText + case .processing: + return processingText + case .unauthorized: + return unathorizedText + case .notFound: + return notFoundText + } + } +} + // MARK: - Status /// Status is a holder of the current state with a few additional configuration properties. @@ -9,7 +40,7 @@ struct Status { /// Flag to enable/disable animation. let animated: Bool /// Text that overrides a text from the state. - let text: String + let text: String? /** Creates a new instance of `Status`. @@ -20,30 +51,6 @@ struct Status { init(state: State, animated: Bool = true, text: String? = nil) { self.state = state self.animated = animated - self.text = text ?? state.text - } -} - -// MARK: - State - -/// Barcode scanner state. -enum State { - case scanning - case processing - case unauthorized - case notFound - - /// State message. - var text: String { - switch self { - case .scanning: - return localizedString("INFO_DESCRIPTION_TEXT") - case .processing: - return localizedString("INFO_LOADING_TITLE") - case .unauthorized: - return localizedString("ASK_FOR_PERMISSION_TEXT") - case .notFound: - return localizedString("NO_PRODUCT_ERROR_TITLE") - } + self.text = text } } From 184fd3ea8d55726de0f5a0d933e33a00d28bc3ba Mon Sep 17 00:00:00 2001 From: Vadym Markov Date: Wed, 31 Jan 2018 21:19:34 +0100 Subject: [PATCH 2/2] Update podspec --- BarcodeScanner.podspec | 2 +- Example/BarcodeScannerExample/Podfile.lock | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/BarcodeScanner.podspec b/BarcodeScanner.podspec index 567306b..36f1b49 100644 --- a/BarcodeScanner.podspec +++ b/BarcodeScanner.podspec @@ -1,7 +1,7 @@ Pod::Spec.new do |s| s.name = "BarcodeScanner" s.summary = "Simple and beautiful barcode scanner." - s.version = "4.0.1" + s.version = "4.1.0" s.homepage = "https://github.com/hyperoslo/BarcodeScanner" s.license = 'MIT' s.author = { "Hyper Interaktiv AS" => "ios@hyper.no" } diff --git a/Example/BarcodeScannerExample/Podfile.lock b/Example/BarcodeScannerExample/Podfile.lock index f94a8c4..b1a87ed 100644 --- a/Example/BarcodeScannerExample/Podfile.lock +++ b/Example/BarcodeScannerExample/Podfile.lock @@ -1,5 +1,5 @@ PODS: - - BarcodeScanner (4.0.0) + - BarcodeScanner (4.1.0) DEPENDENCIES: - BarcodeScanner (from `../../`) @@ -9,7 +9,7 @@ EXTERNAL SOURCES: :path: ../../ SPEC CHECKSUMS: - BarcodeScanner: 706068c838405a0b6b624d284c4db3b240919e29 + BarcodeScanner: 1d811612a55549741cc9dcfecdd6e562d9982edb PODFILE CHECKSUM: ea40d735f047f0ae7ae319d7a320a82facf3361f