forked from intitni/CopilotForXcode
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCodeBlockSuggestionPanel.swift
More file actions
95 lines (83 loc) · 3.06 KB
/
CodeBlockSuggestionPanel.swift
File metadata and controls
95 lines (83 loc) · 3.06 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
import SwiftUI
struct CodeBlock: View {
var suggestion: SuggestionPanelViewModel.Suggestion
var body: some View {
VStack {
ForEach(0..<suggestion.code.endIndex, id: \.self) { index in
HStack(alignment: .firstTextBaseline) {
Text("\(index + suggestion.startLineIndex + 1)")
.multilineTextAlignment(.trailing)
.foregroundColor(.secondary)
.frame(minWidth: 40)
Text(AttributedString(suggestion.code[index]))
.foregroundColor(.white.opacity(0.1))
.frame(maxWidth: .infinity, alignment: .leading)
.multilineTextAlignment(.leading)
.lineSpacing(4)
}
}
}
.foregroundColor(.white)
.font(.system(size: 12, design: .monospaced))
.padding()
}
}
struct CodeBlockSuggestionPanel: View {
@ObservedObject var viewModel: SuggestionPanelViewModel
var suggestion: SuggestionPanelViewModel.Suggestion
struct ToolBar: View {
@ObservedObject var viewModel: SuggestionPanelViewModel
var suggestion: SuggestionPanelViewModel.Suggestion
var body: some View {
HStack {
Button(action: {
viewModel.onPreviousButtonTapped?()
}) {
Image(systemName: "chevron.left")
}.buttonStyle(.plain)
Text(
"\(suggestion.currentSuggestionIndex + 1) / \(suggestion.suggestionCount)"
)
.monospacedDigit()
Button(action: {
viewModel.onNextButtonTapped?()
}) {
Image(systemName: "chevron.right")
}.buttonStyle(.plain)
Spacer()
Button(action: {
viewModel.onRejectButtonTapped?()
}) {
Text("Reject")
}.buttonStyle(CommandButtonStyle(color: .gray))
Button(action: {
viewModel.onAcceptButtonTapped?()
}) {
Text("Accept")
}.buttonStyle(CommandButtonStyle(color: .indigo))
}
.padding()
.foregroundColor(.secondary)
.background(.regularMaterial)
}
}
var body: some View {
VStack(spacing: 0) {
ScrollView {
CodeBlock(suggestion: suggestion)
.frame(maxWidth: .infinity)
}
.background(Color(nsColor: {
switch viewModel.colorScheme {
case .dark:
return #colorLiteral(red: 0.1580096483, green: 0.1730263829, blue: 0.2026666105, alpha: 1)
case .light:
return .white
@unknown default:
return .white
}
}()))
ToolBar(viewModel: viewModel, suggestion: suggestion)
}
}
}