refactored tilelet for color picker

Signed-off-by: Matt Bruce <matt.bruce@verizon.com>
This commit is contained in:
Matt Bruce 2024-04-18 15:52:21 -05:00
parent 9277898075
commit 21d7ee8e45

View File

@ -69,104 +69,34 @@ class TileletViewController: BaseViewController<Tilelet> {
lazy var colorPicker: UIColorPickerViewController = { lazy var colorPicker: UIColorPickerViewController = {
let picker = UIColorPickerViewController() let picker = UIColorPickerViewController()
if case .custom(let hexCode) = component.color {
picker.selectedColor = UIColor(hexString: hexCode)
}
picker.delegate = self picker.delegate = self
return picker return picker
}() }()
var colorPickerType: ColorPickerType = .backgroundColor
enum ColorPickerType {
case backgroundColor, gradientColor1, gradientColor2, contentViewBackgroundColor
}
lazy var gradientColorView1: ColorPickerView<ColorPickerType> = {
return .init(with: ColorPickerType.gradientColor1) { [weak self] picker in
self?.colorPickerType = picker.pickerType
self?.selectedColorTapped(picker)
}
}()
lazy var gradientColorView2: ColorPickerView<ColorPickerType> = {
return .init(with: ColorPickerType.gradientColor2) { [weak self] picker in
self?.colorPickerType = picker.pickerType
self?.selectedColorTapped(picker)
}
}()
lazy var backgroundColorPickerSelectorView = { lazy var backgroundColorPickerSelectorView = {
PickerSelectorView(title: "white", PickerSelectorView(title: "white",
picker: self.picker, picker: self.picker,
items: BackgroundColor.allCases) items: BackgroundColor.allCases)
}() }()
lazy var gradientColorView1: UIStackView = {
let stackView = UIStackView()
let indicatorWrapper = View()
indicatorWrapper.addSubview(gradientColor1View)
indicatorWrapper.height(32)
indicatorWrapper.pinTop()
indicatorWrapper.pinLeading()
indicatorWrapper.pinBottom()
indicatorWrapper.pinTrailingGreaterThanOrEqualTo(anchor: indicatorWrapper.trailingAnchor)
stackView.addArrangedSubview(indicatorWrapper)
stackView.distribution = .fillEqually
stackView.alignment = .fill
var button = Button().with { instance in
instance.size = .small
instance.use = .secondary
instance.text = "Select"
instance.onClick = { [weak self] in
self?.gradientColorTapped($0, view: self?.gradientColor1View)
}
}
button.tag = 1
let buttonWrapper = View()
buttonWrapper.addSubview(button)
buttonWrapper.height(32)
button.pinTop()
button.pinTrailing()
button.pinBottom()
button.pinLeadingGreaterThanOrEqualTo(anchor: buttonWrapper.leadingAnchor)
stackView.addArrangedSubview(buttonWrapper)
stackView.tag = 1
stackView.spacing = 10
return stackView
}()
lazy var gradientColorView2: UIStackView = {
let stackView = UIStackView()
stackView.distribution = .fillEqually
stackView.alignment = .fill
stackView.spacing = 10
let indicatorWrapper = View()
indicatorWrapper.addSubview(gradientColor2View)
indicatorWrapper.height(32)
indicatorWrapper.pinTop()
indicatorWrapper.pinLeading()
indicatorWrapper.pinBottom()
indicatorWrapper.pinTrailingGreaterThanOrEqualTo(anchor: indicatorWrapper.trailingAnchor)
stackView.addArrangedSubview(indicatorWrapper)
var button = Button().with { instance in
instance.size = .small
instance.use = .secondary
instance.text = "Select"
instance.onClick = { [weak self] in
self?.gradientColorTapped($0, view: self?.gradientColor2View)
}
}
button.tag = 2
let buttonWrapper = View()
buttonWrapper.addSubview(button)
buttonWrapper.height(32)
button.pinTop()
button.pinTrailing()
button.pinBottom()
button.pinLeadingGreaterThanOrEqualTo(anchor: buttonWrapper.leadingAnchor)
stackView.addArrangedSubview(buttonWrapper)
stackView.tag = 2
return stackView
}()
var gradientColor1View: UIView = {
let view = UIView()
view.translatesAutoresizingMaskIntoConstraints = false
view.widthAnchor.constraint(equalToConstant: 20).isActive = true
view.heightAnchor.constraint(equalToConstant: 20).isActive = true
view.tag = 1
return view
}()
var gradientColor2View: UIView = {
let view = UIView()
view.translatesAutoresizingMaskIntoConstraints = false
view.widthAnchor.constraint(equalToConstant: 20).isActive = true
view.heightAnchor.constraint(equalToConstant: 20).isActive = true
view.tag = 2
return view
}()
lazy var textAlignmentPickerSelectorView = { lazy var textAlignmentPickerSelectorView = {
PickerSelectorView(title: "left", PickerSelectorView(title: "left",
@ -189,7 +119,6 @@ class TileletViewController: BaseViewController<Tilelet> {
var badgeTextField = TextField() var badgeTextField = TextField()
var eyebrowIsBold = Toggle().with { $0.isOn = true } var eyebrowIsBold = Toggle().with { $0.isOn = true }
var titleIsBold = Toggle().with { $0.isOn = true } var titleIsBold = Toggle().with { $0.isOn = true }
var colorPickerType: ColorPickerType = .backgroundColor
var selectedGradient1Color: String? var selectedGradient1Color: String?
var selectedGradient2Color: String? var selectedGradient2Color: String?
var selectedGradientColorView: UIView? var selectedGradientColorView: UIView?
@ -486,12 +415,10 @@ class TileletViewController: BaseViewController<Tilelet> {
if let effect = item.effect { if let effect = item.effect {
self.component.backgroundEffect = self.getTilelet(effect: effect) self.component.backgroundEffect = self.getTilelet(effect: effect)
self.gradientColorsFormStackView.isHidden = true self.gradientColorsFormStackView.isHidden = true
self.selectedGradient1Color = nil self.gradientColorView1.selectedColor = nil
self.selectedGradient1Color = nil self.gradientColorView2.selectedColor = nil
self.gradientColor1View.backgroundColor = .clear
self.gradientColor2View.backgroundColor = .clear
} else { } else {
self.colorPickerType = .gradientColors self.colorPickerType = .gradientColor1
self.gradientColorsFormStackView.isHidden = false self.gradientColorsFormStackView.isHidden = false
} }
} }
@ -502,19 +429,15 @@ class TileletViewController: BaseViewController<Tilelet> {
backgroundColorPickerSelectorView.onPickerDidSelect = { [weak self] item in backgroundColorPickerSelectorView.onPickerDidSelect = { [weak self] item in
guard let self else { return } guard let self else { return }
self.component.color = self.getTilelet(backgroundColor: item) if let color = self.getTilelet(backgroundColor: item) {
self.component.color = color
} else {
self.colorPickerType = .backgroundColor
self.present(self.colorPicker, animated: true)
}
} }
} }
func gradientColorTapped(_ sender: Button, view: UIView?) {
selectedGradientColorView = view
let selectedColor = (sender.tag == 1) ? selectedGradient1Color : selectedGradient2Color
if let selectedColor {
colorPicker.selectedColor = UIColor(hexString: selectedColor)
}
present(colorPicker, animated: true)
}
func getTilelet(effect: TileContainer.BackgroundEffect) -> Tilelet.BackgroundEffect { func getTilelet(effect: TileContainer.BackgroundEffect) -> Tilelet.BackgroundEffect {
switch effect { switch effect {
case .transparency: case .transparency:
@ -526,7 +449,7 @@ class TileletViewController: BaseViewController<Tilelet> {
} }
} }
func getTilelet(backgroundColor: BackgroundColor) -> Tilelet.BackgroundColor { func getTilelet(backgroundColor: BackgroundColor) -> Tilelet.BackgroundColor? {
switch backgroundColor { switch backgroundColor {
case .primary: case .primary:
.primary .primary
@ -536,6 +459,8 @@ class TileletViewController: BaseViewController<Tilelet> {
.white .white
case .black: case .black:
.black .black
case .custom:
nil
} }
} }
} }
@ -556,11 +481,14 @@ extension TileletViewController: ComponentSampleable {
extension TileletViewController: UIColorPickerViewControllerDelegate { extension TileletViewController: UIColorPickerViewControllerDelegate {
//Internal helper enum to identiy the configuration func selectedColorTapped(_ picker: ColorPickerView<ColorPickerType>) {
enum ColorPickerType { let selectedColor = picker.selectedColor
case backgroundColor, gradientColors, contentViewBackgroundColor if let selectedColor {
colorPicker.selectedColor = selectedColor
}
present(colorPicker, animated: true)
} }
func colorPickerViewControllerDidFinish(_ viewController: UIColorPickerViewController) { func colorPickerViewControllerDidFinish(_ viewController: UIColorPickerViewController) {
dismiss(animated: true) dismiss(animated: true)
} }
@ -572,17 +500,19 @@ extension TileletViewController: UIColorPickerViewControllerDelegate {
component.containerView.backgroundColor = UIColor(hexString: hexString) component.containerView.backgroundColor = UIColor(hexString: hexString)
case .backgroundColor: case .backgroundColor:
component.color = .custom(hexString) component.color = .custom(hexString)
case .gradientColors: case .gradientColor1:
guard let selectedGradientColorView else { return } gradientColorView1.selectedColor = viewController.selectedColor
if selectedGradientColorView.tag == 1 { updateGradientColors()
selectedGradient1Color = hexString case .gradientColor2:
} else { gradientColorView2.selectedColor = viewController.selectedColor
selectedGradient2Color = hexString updateGradientColors()
} }
selectedGradientColorView.backgroundColor = UIColor(hexString: hexString) }
if let selectedGradient1Color, let selectedGradient2Color {
component.backgroundEffect = .gradient(selectedGradient1Color, selectedGradient2Color) func updateGradientColors(){
} if let selectedGradient1Color = gradientColorView1.selectedColor?.hexString,
let selectedGradient2Color = gradientColorView2.selectedColor?.hexString{
component.backgroundEffect = .gradient(selectedGradient1Color, selectedGradient2Color)
} }
} }
} }
@ -591,7 +521,7 @@ extension TileletViewController {
enum BackgroundColor: String, CaseIterable { enum BackgroundColor: String, CaseIterable {
case primary, secondary, white, black case primary, secondary, white, black, custom
var color: TileContainer.BackgroundColor? { var color: TileContainer.BackgroundColor? {
switch self { switch self {
@ -603,6 +533,8 @@ extension TileletViewController {
.white .white
case .black: case .black:
.black .black
case .custom:
nil
} }
} }
} }