Merge branch 'feature/CXTDT-624895-Badge-Color-Updates' into 'develop'

refactored badge text/fill color

### Summary
Fixed bug in how fillColor is set.

Co-authored-by: Matt Bruce <matt.bruce@verizon.com>

See merge request https://gitlab.verizon.com/BPHV_MIPS/mvm_core_ui/-/merge_requests/1200
This commit is contained in:
Pfeil, Scott Robert 2024-10-16 01:25:12 +00:00
commit fe5bd4a9ac
4 changed files with 47 additions and 43 deletions

View File

@ -31,10 +31,10 @@ open class Badge: VDS.Badge, VDSMoleculeViewProtocol {
self.accessibilityIdentifier = accessibilityIdentifier self.accessibilityIdentifier = accessibilityIdentifier
} }
text = viewModel.text text = viewModel.text
textColor = viewModel.textColor textColor = viewModel.textColorStyle
maxWidth = viewModel.maxWidth maxWidth = viewModel.maxWidth
numberOfLines = viewModel.numberOfLines numberOfLines = viewModel.numberOfLines
fillColor = viewModel.fillColor fillColor = viewModel.fillColorStyle
surface = viewModel.surface surface = viewModel.surface
} }

View File

@ -22,15 +22,18 @@ open class BadgeModel: MoleculeModelProtocol {
// MARK: - VDS Properties // MARK: - VDS Properties
//-------------------------------------------------- //--------------------------------------------------
public var text: String = "" public var text: String = ""
public var textColor: Badge.TextColor? = nil public var textColorStyle: Badge.TextColor? = nil
public var accessibilityText: String? public var accessibilityText: String?
public var maxWidth: CGFloat? public var maxWidth: CGFloat?
public var numberOfLines: Int = 1 public var numberOfLines: Int = 1
public var fillColor = Badge.FillColor.red public var fillColorStyle = Badge.FillColor.red
public var surface: Surface = .light public var surface: Surface = .light
private enum CodingKeys: String, CodingKey { private enum CodingKeys: String, CodingKey {
case id, accessibilityIdentifier, text, textColor, accessibilityText, fillColor, surface, numberOfLines, maxWidth case id, accessibilityIdentifier, accessibilityText
case surface, numberOfLines, maxWidth
case text, textColor
case fillColor, fillColorStyle
} }
required public convenience init(from decoder: Decoder) throws { required public convenience init(from decoder: Decoder) throws {
@ -39,11 +42,20 @@ open class BadgeModel: MoleculeModelProtocol {
id = try container.decodeIfPresent(String.self, forKey: .id) ?? UUID().uuidString id = try container.decodeIfPresent(String.self, forKey: .id) ?? UUID().uuidString
accessibilityIdentifier = try container.decodeIfPresent(String.self, forKey: .accessibilityIdentifier) accessibilityIdentifier = try container.decodeIfPresent(String.self, forKey: .accessibilityIdentifier)
text = try container.decode(String.self, forKey: .text) text = try container.decode(String.self, forKey: .text)
if let foundTextColor = try container.decodeIfPresent(Color.self, forKey: .textColor) {
textColor = .custom(foundTextColor.uiColor)
}
accessibilityText = try container.decodeIfPresent(String.self, forKey: .accessibilityText) accessibilityText = try container.decodeIfPresent(String.self, forKey: .accessibilityText)
fillColor = try container.decodeIfPresent(Badge.FillColor.self, forKey: .fillColor) ?? .red
//look for a textColor
if let textColor = try container.decodeIfPresent(Color.self, forKey: .textColor) {
textColorStyle = .custom(textColor.uiColor)
}
//look for a style
fillColorStyle = try container.decodeIfPresent(Badge.FillColor.self, forKey: .fillColorStyle) ?? .red
//look for a color and set the style
if let fillColor = try container.decodeIfPresent(Color.self, forKey: .fillColor) {
fillColorStyle = .custom(fillColor.uiColor)
}
surface = try container.decodeIfPresent(Surface.self, forKey: .surface) ?? .light surface = try container.decodeIfPresent(Surface.self, forKey: .surface) ?? .light
numberOfLines = try container.decodeIfPresent(Int.self, forKey: .numberOfLines) ?? 1 numberOfLines = try container.decodeIfPresent(Int.self, forKey: .numberOfLines) ?? 1
maxWidth = try container.decodeIfPresent(CGFloat.self, forKey: .maxWidth) maxWidth = try container.decodeIfPresent(CGFloat.self, forKey: .maxWidth)
@ -55,11 +67,11 @@ open class BadgeModel: MoleculeModelProtocol {
try container.encode(text, forKey: .text) try container.encode(text, forKey: .text)
try container.encode(accessibilityText, forKey: .accessibilityText) try container.encode(accessibilityText, forKey: .accessibilityText)
try container.encodeIfPresent(accessibilityIdentifier, forKey: .accessibilityIdentifier) try container.encodeIfPresent(accessibilityIdentifier, forKey: .accessibilityIdentifier)
try container.encode(fillColor, forKey: .fillColor)
try container.encode(surface, forKey: .surface) try container.encode(surface, forKey: .surface)
try container.encode(numberOfLines, forKey: .numberOfLines) try container.encode(numberOfLines, forKey: .numberOfLines)
try container.encodeIfPresent(maxWidth, forKey: .maxWidth) try container.encodeIfPresent(maxWidth, forKey: .maxWidth)
switch textColor { try container.encode(fillColorStyle, forKey: .fillColorStyle)
switch textColorStyle {
case .custom(let color): case .custom(let color):
try container.encode(Color(uiColor: color), forKey: .textColor) try container.encode(Color(uiColor: color), forKey: .textColor)
default: default:
@ -70,7 +82,8 @@ open class BadgeModel: MoleculeModelProtocol {
public func isEqual(to model: any ModelComparisonProtocol) -> Bool { public func isEqual(to model: any ModelComparisonProtocol) -> Bool {
guard let model = model as? BadgeModel else { return false } guard let model = model as? BadgeModel else { return false }
return self.backgroundColor == model.backgroundColor return self.backgroundColor == model.backgroundColor
&& self.fillColor == model.fillColor && self.fillColorStyle == model.fillColorStyle
&& self.textColorStyle == model.textColorStyle
&& self.numberOfLines == model.numberOfLines && self.numberOfLines == model.numberOfLines
&& self.text == model.text && self.text == model.text
&& self.surface == model.surface && self.surface == model.surface

View File

@ -94,8 +94,8 @@ open class TileletModel: TileContainerBaseModel<Tilelet.Padding, Tilelet>, Molec
public func badgeModel() -> Tilelet.BadgeModel? { public func badgeModel() -> Tilelet.BadgeModel? {
guard let badge else { return nil } guard let badge else { return nil }
return .init(text: badge.text, return .init(text: badge.text,
textColor: badge.textColor, textColor: badge.textColorStyle,
fillColor: badge.fillColor, fillColor: badge.fillColorStyle,
surface: badge.surface, surface: badge.surface,
numberOfLines: badge.numberOfLines, numberOfLines: badge.numberOfLines,
maxWidth: badge.maxWidth maxWidth: badge.maxWidth

View File

@ -294,49 +294,40 @@ extension VDS.TitleLockup.TextColor: Codable {
} }
extension VDS.Badge.FillColor: Codable { extension VDS.Badge.FillColor: Codable {
enum CodingKeys: String, CodingKey {
case type
case color
}
enum CustomColorType: String, Codable {
case red, yellow, green, orange, blue, black, white
case custom
}
public init(from decoder: Decoder) throws { public init(from decoder: Decoder) throws {
let container = try decoder.container(keyedBy: CodingKeys.self) let container = try decoder.singleValueContainer()
let type = try container.decode(CustomColorType.self, forKey: .type) let type = try container.decode(String.self)
switch type { switch type {
case .red: case "red":
self = .red self = .red
case .yellow: case "yellow":
self = .yellow self = .yellow
case .green: case "green":
self = .green self = .green
case .orange: case "orange":
self = .orange self = .orange
case .blue: case "blue":
self = .blue self = .blue
case .black: case "black":
self = .black self = .black
case .white: case "white":
self = .white self = .white
case .custom: default:
let color = try container.decode(Color.self, forKey: .color) if let color = try? Color(from: decoder) {
self = .custom(color.uiColor) self = .custom(color.uiColor)
} else {
self = .custom(UIColor(hexString: type))
}
} }
} }
public func encode(to encoder: Encoder) throws { public func encode(to encoder: Encoder) throws {
var container = encoder.container(keyedBy: CodingKeys.self) var container = encoder.singleValueContainer()
switch self { switch self {
case .custom(let color): case .custom(let value):
try container.encode(CustomColorType.custom.rawValue, forKey: .type) try container.encode(Color(uiColor: value))
try container.encode(Color(uiColor: color), forKey: .color)
default: default:
try container.encode("\(self)", forKey: .type) try container.encode(String(reflecting: self))
} }
} }
} }