NumberFormatter.swift 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. //
  2. // NumberFormatter.swift
  3. // MinimedKitUI
  4. //
  5. // Created by Pete Schwamb on 3/19/23.
  6. // Copyright © 2023 LoopKit Authors. All rights reserved.
  7. //
  8. import Foundation
  9. extension NumberFormatter {
  10. func decibleString(from decibles: Int?) -> String? {
  11. if let decibles = decibles, let formatted = string(from: NSNumber(value: decibles)) {
  12. return String(format: LocalizedString("%@ dB", comment: "Unit format string for an RSSI value in decibles"), formatted)
  13. } else {
  14. return nil
  15. }
  16. }
  17. func string(from number: Double) -> String? {
  18. return string(from: NSNumber(value: number))
  19. }
  20. func string(from number: Double, unit: String, style: Formatter.UnitStyle = .medium, avoidLineBreaking: Bool = true) -> String? {
  21. guard let stringValue = string(from: number) else {
  22. return nil
  23. }
  24. let separator: String
  25. switch style {
  26. case .long:
  27. separator = " "
  28. case .medium:
  29. separator = avoidLineBreaking ? .nonBreakingSpace : " "
  30. case .short:
  31. fallthrough
  32. @unknown default:
  33. separator = avoidLineBreaking ? .wordJoiner : ""
  34. }
  35. let unit = avoidLineBreaking ? unit.replacingOccurrences(of: "/", with: "\(String.wordJoiner)/\(String.wordJoiner)") : unit
  36. return String(
  37. format: LocalizedString("%1$@%2$@%3$@", comment: "String format for value with units (1: value, 2: separator, 3: units)"),
  38. stringValue,
  39. separator,
  40. unit
  41. )
  42. }
  43. }
  44. public extension String {
  45. static let nonBreakingSpace = "\u{00a0}"
  46. static let wordJoiner = "\u{2060}"
  47. }