From 25f5e697602e0008f14966158676b077f39ecadb Mon Sep 17 00:00:00 2001 From: Kevin McGill Date: Thu, 8 Mar 2018 13:00:58 -0600 Subject: [PATCH] Allow setting toolbar items properties before setToolbarItems --- Example/Tests/McPickerTests.swift | 85 ++++++++++++++++++++++++++++++- McPicker/Classes/McPicker.swift | 26 ++++++++-- 2 files changed, 107 insertions(+), 4 deletions(-) diff --git a/Example/Tests/McPickerTests.swift b/Example/Tests/McPickerTests.swift index 5a5031f..2d20b91 100644 --- a/Example/Tests/McPickerTests.swift +++ b/Example/Tests/McPickerTests.swift @@ -89,7 +89,7 @@ class McPickerTests: XCTestCase { XCTAssertNil(mcPicker.showsSelectionIndicator) } - func testSetToolbarButtonsColorSetsCancelAndDone() { + func testSetToolbarButtons_colorSetsCancelAndDone() { // Given // let mcPicker = McPicker(data: data) @@ -106,6 +106,66 @@ class McPickerTests: XCTestCase { XCTAssertEqual(UIColor.purple, doneBarButton.tintColor) } + func testSetToolbarButtonsColorSetsCancelAndDone_setColorBeforeToolBarItems() { + // Given + // + let mcPicker = McPicker(data: data) + mcPicker.toolbarButtonsColor = UIColor.purple + + // When + // + let fixedSpace = McPickerBarButtonItem.fixedSpace(width: 20.0) + let flexibleSpace = McPickerBarButtonItem.flexibleSpace() + let fireButton = McPickerBarButtonItem.done(mcPicker: mcPicker, title: "Fire!!!") + let cancelButton = McPickerBarButtonItem.cancel(mcPicker: mcPicker, barButtonSystemItem: .cancel) + mcPicker.setToolbarItems(items: [fixedSpace, cancelButton, flexibleSpace, fireButton, fixedSpace]) + + // Then + // + XCTAssertEqual(UIColor.purple, fireButton.tintColor) + XCTAssertEqual(UIColor.purple, cancelButton.tintColor) + } + + func testSetToolbarDoneButtonsColor_setColorBeforeToolBarItems() { + // Given + // + let mcPicker = McPicker(data: data) + mcPicker.toolbarDoneButtonColor = UIColor.purple + + // When + // + let fixedSpace = McPickerBarButtonItem.fixedSpace(width: 20.0) + let flexibleSpace = McPickerBarButtonItem.flexibleSpace() + let fireButton = McPickerBarButtonItem.done(mcPicker: mcPicker, title: "Fire!!!") + let cancelButton = McPickerBarButtonItem.cancel(mcPicker: mcPicker, barButtonSystemItem: .cancel) + mcPicker.setToolbarItems(items: [fixedSpace, cancelButton, flexibleSpace, fireButton, fixedSpace]) + + // Then + // + XCTAssertEqual(UIColor.purple, fireButton.tintColor) + XCTAssertNotEqual(UIColor.purple, cancelButton.tintColor) + } + + func testSetToolbarCancelButtonsColor_setColorBeforeToolBarItems() { + // Given + // + let mcPicker = McPicker(data: data) + mcPicker.toolbarCancelButtonColor = UIColor.purple + + // When + // + let fixedSpace = McPickerBarButtonItem.fixedSpace(width: 20.0) + let flexibleSpace = McPickerBarButtonItem.flexibleSpace() + let fireButton = McPickerBarButtonItem.done(mcPicker: mcPicker, title: "Fire!!!") + let cancelButton = McPickerBarButtonItem.cancel(mcPicker: mcPicker, barButtonSystemItem: .cancel) + mcPicker.setToolbarItems(items: [fixedSpace, cancelButton, flexibleSpace, fireButton, fixedSpace]) + + // Then + // + XCTAssertNotEqual(UIColor.purple, fireButton.tintColor) + XCTAssertEqual(UIColor.purple, cancelButton.tintColor) + } + func testSetToolbarDoneButtonsColorSetsDone() { // Given // @@ -175,6 +235,29 @@ class McPickerTests: XCTestCase { XCTAssertEqual(expectedFont, doneBarButton.titleTextAttributes(for: .selected)?[NSAttributedStringKey.font.rawValue] as! UIFont) } + func testSetToolbarItemsFont_afterToolbarItemsSet() { + // Given + // + let expectedFont = UIFont(name:"American Typewriter", size: 17)! + let mcPicker = McPicker(data: data) + mcPicker.toolbarItemsFont = expectedFont + let fixedSpace = McPickerBarButtonItem.fixedSpace(width: 20.0) + let flexibleSpace = McPickerBarButtonItem.flexibleSpace() + let fireButton = McPickerBarButtonItem.done(mcPicker: mcPicker, title: "Fire!!!") + let cancelButton = McPickerBarButtonItem.cancel(mcPicker: mcPicker, barButtonSystemItem: .cancel) + + // When + // + mcPicker.setToolbarItems(items: [fixedSpace, cancelButton, flexibleSpace, fireButton, fixedSpace]) + + // Then + // + XCTAssertEqual(expectedFont, cancelButton.titleTextAttributes(for: .normal)?[NSAttributedStringKey.font.rawValue] as! UIFont) + XCTAssertEqual(expectedFont, fireButton.titleTextAttributes(for: .normal)?[NSAttributedStringKey.font.rawValue] as! UIFont) + XCTAssertEqual(expectedFont, cancelButton.titleTextAttributes(for: .selected)?[NSAttributedStringKey.font.rawValue] as! UIFont) + XCTAssertEqual(expectedFont, fireButton.titleTextAttributes(for: .selected)?[NSAttributedStringKey.font.rawValue] as! UIFont) + } + func testSetPickerBackgroundColor() { // Given // diff --git a/McPicker/Classes/McPicker.swift b/McPicker/Classes/McPicker.swift index 4f3e895..2c2e320 100644 --- a/McPicker/Classes/McPicker.swift +++ b/McPicker/Classes/McPicker.swift @@ -61,9 +61,6 @@ open class McPicker: UIView { } } } - public var toolbarBarTintColor: UIColor? { - didSet { toolbar.barTintColor = toolbarBarTintColor } - } public var toolbarItemsFont: UIFont? { didSet { applyToolbarButtonItemsSettings { (barButtonItem) in @@ -72,6 +69,9 @@ open class McPicker: UIView { } } } + public var toolbarBarTintColor: UIColor? { + didSet { toolbar.barTintColor = toolbarBarTintColor } + } public var pickerBackgroundColor: UIColor? { didSet { picker.backgroundColor = pickerBackgroundColor } } @@ -259,6 +259,8 @@ open class McPicker: UIView { open func setToolbarItems(items: [McPickerBarButtonItem]) { toolbar.items = items + + setToolbarProperties() } open override func willMove(toWindow newWindow: UIWindow?) { @@ -368,6 +370,24 @@ open class McPicker: UIView { } } + private func setToolbarProperties() { + if let _toolbarButtonsColor = toolbarButtonsColor { + toolbarButtonsColor = _toolbarButtonsColor + } + + if let _toolbarDoneButtonColor = toolbarDoneButtonColor { + toolbarDoneButtonColor = _toolbarDoneButtonColor + } + + if let _toolbarCancelButtonColor = toolbarCancelButtonColor { + toolbarCancelButtonColor = _toolbarCancelButtonColor + } + + if let _toolbarItemsFont = toolbarItemsFont { + toolbarItemsFont = _toolbarItemsFont + } + } + private func applyToolbarButtonItemsSettings(withAction: Selector? = nil, settings: (_ barButton: UIBarButtonItem) -> Void) { for item in toolbar.items ?? [] { if let action = withAction, action == item.action {