mirror of
https://github.com/samsonjs/vibetunnel.git
synced 2026-03-25 09:25:50 +00:00
173 lines
7.3 KiB
Swift
173 lines
7.3 KiB
Swift
import SwiftUI
|
|
|
|
/// Sheet for selecting terminal color themes.
|
|
struct TerminalThemeSheet: View {
|
|
@Binding var selectedTheme: TerminalTheme
|
|
@Environment(\.dismiss) var dismiss
|
|
|
|
var body: some View {
|
|
NavigationStack {
|
|
ScrollView {
|
|
VStack(spacing: Theme.Spacing.large) {
|
|
// Current theme preview
|
|
VStack(alignment: .leading, spacing: Theme.Spacing.small) {
|
|
Text("Preview")
|
|
.font(.caption)
|
|
.foregroundColor(Theme.Colors.terminalForeground.opacity(0.7))
|
|
|
|
TerminalThemePreview(theme: selectedTheme)
|
|
.frame(height: 120)
|
|
}
|
|
.padding(.horizontal)
|
|
.padding(.top)
|
|
|
|
// Theme list
|
|
VStack(spacing: Theme.Spacing.medium) {
|
|
ForEach(TerminalTheme.allThemes) { theme in
|
|
Button(action: {
|
|
selectedTheme = theme
|
|
HapticFeedback.impact(.light)
|
|
// Save to UserDefaults
|
|
TerminalTheme.selected = theme
|
|
}) {
|
|
HStack(spacing: Theme.Spacing.medium) {
|
|
// Color preview
|
|
HStack(spacing: 2) {
|
|
ForEach(
|
|
[theme.red, theme.green, theme.yellow, theme.blue],
|
|
id: \.self
|
|
) { color in
|
|
Rectangle()
|
|
.fill(color)
|
|
.frame(width: 8, height: 32)
|
|
}
|
|
}
|
|
.cornerRadius(4)
|
|
.overlay(
|
|
RoundedRectangle(cornerRadius: 4)
|
|
.stroke(Theme.Colors.cardBorder, lineWidth: 1)
|
|
)
|
|
|
|
// Theme info
|
|
VStack(alignment: .leading, spacing: Theme.Spacing.extraSmall) {
|
|
Text(theme.name)
|
|
.font(.headline)
|
|
.foregroundColor(Theme.Colors.terminalForeground)
|
|
|
|
Text(theme.description)
|
|
.font(.caption)
|
|
.foregroundColor(Theme.Colors.terminalForeground.opacity(0.7))
|
|
.fixedSize(horizontal: false, vertical: true)
|
|
}
|
|
|
|
Spacer()
|
|
|
|
// Selection indicator
|
|
if selectedTheme.id == theme.id {
|
|
Image(systemName: "checkmark.circle.fill")
|
|
.font(.system(size: 20))
|
|
.foregroundColor(Theme.Colors.successAccent)
|
|
}
|
|
}
|
|
.padding()
|
|
.background(
|
|
RoundedRectangle(cornerRadius: Theme.CornerRadius.medium)
|
|
.fill(selectedTheme.id == theme.id
|
|
? Theme.Colors.primaryAccent.opacity(0.1)
|
|
: Theme.Colors.cardBorder.opacity(0.1)
|
|
)
|
|
)
|
|
.overlay(
|
|
RoundedRectangle(cornerRadius: Theme.CornerRadius.medium)
|
|
.stroke(
|
|
selectedTheme.id == theme.id
|
|
? Theme.Colors.primaryAccent
|
|
: Theme.Colors.cardBorder,
|
|
lineWidth: 1
|
|
)
|
|
)
|
|
}
|
|
.buttonStyle(PlainButtonStyle())
|
|
}
|
|
}
|
|
.padding(.horizontal)
|
|
|
|
Spacer(minLength: Theme.Spacing.large)
|
|
}
|
|
}
|
|
.background(Theme.Colors.cardBackground)
|
|
.navigationTitle("Terminal Theme")
|
|
.navigationBarTitleDisplayMode(.inline)
|
|
.toolbar {
|
|
ToolbarItem(placement: .navigationBarTrailing) {
|
|
Button("Done") {
|
|
dismiss()
|
|
}
|
|
.foregroundColor(Theme.Colors.primaryAccent)
|
|
}
|
|
}
|
|
}
|
|
.preferredColorScheme(.dark)
|
|
}
|
|
}
|
|
|
|
/// Preview of a terminal theme showing sample text with colors.
|
|
struct TerminalThemePreview: View {
|
|
let theme: TerminalTheme
|
|
|
|
var body: some View {
|
|
VStack(alignment: .leading, spacing: 2) {
|
|
// Terminal prompt with colors
|
|
HStack(spacing: 0) {
|
|
Text("user")
|
|
.foregroundColor(theme.green)
|
|
Text("@")
|
|
.foregroundColor(theme.foreground)
|
|
Text("vibetunnel")
|
|
.foregroundColor(theme.blue)
|
|
Text(":")
|
|
.foregroundColor(theme.foreground)
|
|
Text("~/projects")
|
|
.foregroundColor(theme.cyan)
|
|
Text(" $ ")
|
|
.foregroundColor(theme.foreground)
|
|
}
|
|
.font(Theme.Typography.terminal(size: 12))
|
|
|
|
// Sample command
|
|
Text("git status")
|
|
.foregroundColor(theme.foreground)
|
|
.font(Theme.Typography.terminal(size: 12))
|
|
|
|
// Sample output with different colors
|
|
Text("On branch ")
|
|
.foregroundColor(theme.foreground) +
|
|
Text("main")
|
|
.foregroundColor(theme.green)
|
|
|
|
Text("Changes not staged for commit:")
|
|
.foregroundColor(theme.red)
|
|
.font(Theme.Typography.terminal(size: 12))
|
|
|
|
HStack(spacing: 0) {
|
|
Text(" modified: ")
|
|
.foregroundColor(theme.red)
|
|
Text("file.swift")
|
|
.foregroundColor(theme.foreground)
|
|
}
|
|
.font(Theme.Typography.terminal(size: 12))
|
|
}
|
|
.padding()
|
|
.frame(maxWidth: .infinity, maxHeight: .infinity, alignment: .topLeading)
|
|
.background(theme.background)
|
|
.cornerRadius(Theme.CornerRadius.medium)
|
|
.overlay(
|
|
RoundedRectangle(cornerRadius: Theme.CornerRadius.medium)
|
|
.stroke(Theme.Colors.cardBorder, lineWidth: 1)
|
|
)
|
|
}
|
|
}
|
|
|
|
#Preview {
|
|
TerminalThemeSheet(selectedTheme: .constant(TerminalTheme.vibeTunnel))
|
|
}
|