CarbEntryStored+helper.swift 3.4 KB

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