- Migrate from SwiftData to CoreData with CloudKit sync - Add core models: Split, Exercise, Workout, WorkoutLog - Implement tab-based UI: Workout Logs, Splits, Settings - Add SF Symbols picker for split icons - Add exercise picker filtered by split with exclusion of added exercises - Integrate IndieAbout for settings/about section - Add Yams for YAML exercise definition parsing - Include starter exercise libraries (bodyweight, Planet Fitness) - Add Date extensions for formatting (formattedTime, isSameDay) - Format workout date ranges to show time-only for same-day end dates - Add build number update script - Add app icons
46 lines
1.2 KiB
Swift
46 lines
1.2 KiB
Swift
//
|
|
// CheckboxListItem.swift
|
|
// Workouts
|
|
//
|
|
// Created by rzen on 7/13/25 at 10:42 AM.
|
|
//
|
|
// Copyright 2025 Rouslan Zenetl. All Rights Reserved.
|
|
//
|
|
|
|
import SwiftUI
|
|
|
|
struct CheckboxListItem: View {
|
|
var status: CheckboxStatus
|
|
var title: String
|
|
var subtitle: String?
|
|
var count: Int?
|
|
|
|
var body: some View {
|
|
HStack(alignment: .top) {
|
|
Image(systemName: status.systemName)
|
|
.resizable()
|
|
.scaledToFit()
|
|
.frame(width: 30)
|
|
.foregroundStyle(status.color)
|
|
VStack(alignment: .leading) {
|
|
Text("\(title)")
|
|
.font(.headline)
|
|
HStack(alignment: .bottom) {
|
|
if let subtitle = subtitle {
|
|
Text("\(subtitle)")
|
|
.font(.footnote)
|
|
}
|
|
}
|
|
}
|
|
if let count = count {
|
|
Spacer()
|
|
Text("\(count)")
|
|
.font(.caption)
|
|
.foregroundColor(.gray)
|
|
}
|
|
}
|
|
.frame(maxWidth: .infinity, alignment: .leading)
|
|
.contentShape(Rectangle())
|
|
}
|
|
}
|