-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Showing
8 changed files
with
236 additions
and
208 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
import UIKit | ||
import HealthKit | ||
import RxSwift | ||
|
||
// MARK: - MindGymKit | ||
public protocol StepCountProvider { | ||
func fetchTodayStepCount(completion: @escaping (Double?) -> Void) | ||
} | ||
|
||
open class HealthKitStepCountProvider: StepCountProvider { | ||
private let healthStore = HKHealthStore() | ||
|
||
public init() {} | ||
|
||
public func fetchTodayStepCount(completion: @escaping (Double?) -> Void) { | ||
guard HKHealthStore.isHealthDataAvailable() else { | ||
completion(nil) | ||
return | ||
} | ||
|
||
let stepType = HKQuantityType.quantityType(forIdentifier: .stepCount)! | ||
let calendar = Calendar.current | ||
let now = Date() | ||
let startOfDay = calendar.startOfDay(for: now) | ||
let endOfDay = calendar.date(byAdding: .day, value: 1, to: startOfDay)! | ||
let predicate = HKQuery.predicateForSamples(withStart: startOfDay, end: endOfDay, options: .strictStartDate) | ||
|
||
healthStore.requestAuthorization(toShare: nil, read: [stepType]) { (success, error) in | ||
if success { | ||
let query = HKStatisticsQuery(quantityType: stepType, quantitySamplePredicate: predicate, options: .cumulativeSum) { query, result, error in | ||
if let result = result, let sum = result.sumQuantity() { | ||
completion(sum.doubleValue(for: HKUnit.count())) | ||
} else { | ||
completion(nil) | ||
if let error = error { | ||
print("Error fetching step count: \(error.localizedDescription)") | ||
} | ||
} | ||
} | ||
self.healthStore.execute(query) | ||
} else { | ||
completion(nil) | ||
if let error = error { | ||
print("Error requesting HealthKit authorization: \(error.localizedDescription)") | ||
} | ||
} | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
import UIKit | ||
import RxSwift | ||
|
||
// MARK: - MindGaGymKitTimer | ||
open class MindGaGymKitTimer: NSObject, TimerControl { | ||
|
||
private var initCounter: Double = 0.0 | ||
private var counter: Double = 0.0 | ||
private var timer: Timer? | ||
private var lapTimes: [Double] = [] | ||
private let timerSubject = PublishSubject<String>() | ||
private let recordSubject = PublishSubject<[String]>() | ||
|
||
public var timeUpdate: Observable<String> { | ||
return timerSubject.asObservable() | ||
} | ||
|
||
public func setting(count: Double) { | ||
initCounter = count | ||
self.counter = count | ||
let timeString = self.timeString(from: self.counter) | ||
self.timerSubject.onNext(timeString) | ||
} | ||
|
||
public func start() { | ||
timer = Timer.scheduledTimer(withTimeInterval: 0.035, repeats: true) { [weak self] _ in | ||
guard let self = self else { return } | ||
self.counter -= 0.035 | ||
let timeString = self.timeString(from: self.counter) | ||
self.timerSubject.onNext(timeString) | ||
} | ||
} | ||
|
||
public func stop() { | ||
timer?.invalidate() | ||
timer = nil | ||
} | ||
|
||
public func restart() { | ||
counter = initCounter | ||
let timeString = self.timeString(from: self.counter) | ||
self.timerSubject.onNext(timeString) | ||
} | ||
|
||
public func reset() { | ||
counter = 0.0 | ||
initCounter = 0.0 | ||
let timeString = self.timeString(from: self.counter) | ||
self.timerSubject.onNext(timeString) | ||
} | ||
|
||
public func record() { | ||
lapTimes.append(counter) | ||
let lapTimesString = lapTimes.map { timeString(from: $0) } | ||
recordSubject.onNext(lapTimesString) | ||
} | ||
|
||
private func timeString(from counter: Double) -> String { | ||
let hours: String = String(format: "%02d", Int(counter / 3600)) | ||
let minutes: String = String(format: "%02d", Int(counter / 60)) | ||
let seconds: String = String(format: "%02d", Int(counter.truncatingRemainder(dividingBy: 60))) | ||
if counter / 3600 >= 1 { | ||
return "\(hours) : \(minutes) : \(seconds)" | ||
} else if counter / 60 > 1 { | ||
return "\(minutes) : \(seconds)" | ||
} else { | ||
return "\(minutes) : \(seconds)" | ||
} | ||
} | ||
} |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
import UIKit | ||
import RxSwift | ||
|
||
// MARK: - MindGymStopWatchKit | ||
open class MindGymStopWatchKit { | ||
public let mainStopwatch: TimerControl = Stopwatch() | ||
|
||
public func startTimer() { | ||
mainStopwatch.start() | ||
} | ||
|
||
public func stopTimer() { | ||
mainStopwatch.stop() | ||
} | ||
|
||
public func resetTimer() { | ||
mainStopwatch.reset() | ||
} | ||
|
||
public func recordTime() { | ||
(mainStopwatch as? Stopwatch)?.record() | ||
} | ||
} |
Oops, something went wrong.