44 lines
1020 B
Swift
44 lines
1020 B
Swift
//
|
|
// StepperListItem.swift
|
|
// WorkoutsPlus
|
|
//
|
|
// Created by Felix Förtsch on 04.09.24.
|
|
//
|
|
|
|
import SwiftUI
|
|
|
|
struct StepperListItem: View {
|
|
@State var itemName: String
|
|
@Binding var itemValue: Int
|
|
|
|
var body: some View {
|
|
Stepper(
|
|
value: $itemValue,
|
|
in: 0...100,
|
|
step: 1
|
|
) {
|
|
HStack {
|
|
Text(String(itemValue))
|
|
.font(.system(size: 14, weight: .bold))
|
|
.foregroundStyle(.white)
|
|
.frame(width: 20, height: 10)
|
|
.padding(8)
|
|
.background(Color.blue)
|
|
.clipShape(RoundedRectangle(cornerRadius: 8))
|
|
Text(itemName)
|
|
.foregroundStyle(.black)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
#Preview {
|
|
@Previewable @State var itemValue = 8
|
|
|
|
List {
|
|
StepperListItem(itemName: "Short Name", itemValue: $itemValue)
|
|
StepperListItem(itemName: "Very very very very long name with whitespace", itemValue: $itemValue)
|
|
StepperListItem(itemName: "Veryveryverylonglonglonglongnamewithoutwithwhitespace", itemValue: $itemValue)
|
|
}
|
|
}
|