CarbEntryStored+helper.swift 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. import CoreData
  2. import Foundation
  3. extension NSPredicate {
  4. static var fpusForChart: NSPredicate {
  5. let date = Date.oneDayAgo
  6. return NSPredicate(format: "isFPU == true AND date >= %@", date as NSDate)
  7. }
  8. static var carbsForChart: NSPredicate {
  9. let date = Date.oneDayAgo
  10. return NSPredicate(format: "isFPU == false AND date >= %@", date as NSDate)
  11. }
  12. static var carbsNotYetUploadedToNightscout: NSPredicate {
  13. let date = Date.oneDayAgo
  14. return NSPredicate(
  15. format: "date >= %@ AND isUploadedToNS == %@ AND isFPU == %@",
  16. date as NSDate,
  17. false as NSNumber,
  18. false as NSNumber
  19. )
  20. }
  21. static var carbsNotYetUploadedToHealth: NSPredicate {
  22. let date = Date.oneDayAgo
  23. return NSPredicate(
  24. format: "date >= %@ AND isUploadedToHealth == %@",
  25. date as NSDate,
  26. false as NSNumber
  27. )
  28. }
  29. static var fpusNotYetUploadedToNightscout: NSPredicate {
  30. let date = Date.oneDayAgo
  31. return NSPredicate(
  32. format: "date >= %@ AND isUploadedToNS == %@ AND isFPU == %@",
  33. date as NSDate,
  34. false as NSNumber,
  35. true as NSNumber
  36. )
  37. }
  38. }
  39. extension CarbEntryStored {
  40. static func fetch(
  41. _ predicate: NSPredicate = .predicateForOneDayAgo,
  42. fetchLimit: Int = 100,
  43. ascending: Bool = false
  44. ) -> NSFetchRequest<CarbEntryStored> {
  45. let request = CarbEntryStored.fetchRequest() as NSFetchRequest<CarbEntryStored>
  46. request.sortDescriptors = [NSSortDescriptor(keyPath: \CarbEntryStored.date, ascending: ascending)]
  47. request.fetchLimit = fetchLimit
  48. request.predicate = predicate
  49. return request
  50. }
  51. }
  52. extension CarbEntryStored: Encodable {
  53. enum CodingKeys: String, CodingKey {
  54. case actualDate
  55. case created_at
  56. case carbs
  57. case fat
  58. case id
  59. case isFPU
  60. case note
  61. case protein
  62. case enteredBy
  63. }
  64. public func encode(to encoder: Encoder) throws {
  65. var container = encoder.container(keyedBy: CodingKeys.self)
  66. let dateFormatter = ISO8601DateFormatter()
  67. dateFormatter.formatOptions = [.withInternetDateTime, .withFractionalSeconds]
  68. let formattedDate = dateFormatter.string(from: date ?? Date())
  69. try container.encode(formattedDate, forKey: .actualDate)
  70. try container.encode(formattedDate, forKey: .created_at)
  71. // TODO: handle this conditionally; pass in the enteredBy string (manual entry or via NS or Apple Health)
  72. try container.encode("Open-iAPS", forKey: .enteredBy)
  73. try container.encode(carbs, forKey: .carbs)
  74. try container.encode(fat, forKey: .fat)
  75. try container.encode(isFPU, forKey: .isFPU)
  76. try container.encode(note, forKey: .note)
  77. try container.encode(protein, forKey: .protein)
  78. try container.encode(id, forKey: .id)
  79. }
  80. }