forked from intitni/CopilotForXcode
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSuggestionPanelView.swift
More file actions
79 lines (73 loc) · 2.82 KB
/
SuggestionPanelView.swift
File metadata and controls
79 lines (73 loc) · 2.82 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
import ComposableArchitecture
import Foundation
import SwiftUI
struct SuggestionPanelView: View {
let store: StoreOf<SuggestionPanelFeature>
@AppStorage(\.suggestionPresentationMode) var suggestionPresentationMode
struct OverallState: Equatable {
var isPanelDisplayed: Bool
var opacity: Double
var colorScheme: ColorScheme
var isPanelOutOfFrame: Bool
var alignTopToAnchor: Bool
}
var body: some View {
WithViewStore(
store,
observe: { OverallState(
isPanelDisplayed: $0.isPanelDisplayed,
opacity: $0.opacity,
colorScheme: $0.colorScheme,
isPanelOutOfFrame: $0.isPanelOutOfFrame,
alignTopToAnchor: $0.alignTopToAnchor
) }
) { viewStore in
VStack(spacing: 0) {
if !viewStore.alignTopToAnchor {
Spacer()
.frame(minHeight: 0, maxHeight: .infinity)
.allowsHitTesting(false)
}
IfLetStore(store.scope(state: \.content, action: { $0 })) { store in
WithViewStore(store) { viewStore in
ZStack(alignment: .topLeading) {
switch suggestionPresentationMode {
case .nearbyTextCursor:
CodeBlockSuggestionPanel(suggestion: viewStore.state)
case .floatingWidget:
EmptyView()
}
}
.frame(maxWidth: .infinity, maxHeight: Style.inlineSuggestionMaxHeight)
.fixedSize(horizontal: false, vertical: true)
}
}
.allowsHitTesting(
viewStore.isPanelDisplayed && !viewStore.isPanelOutOfFrame
)
.frame(maxWidth: .infinity)
if viewStore.alignTopToAnchor {
Spacer()
.frame(minHeight: 0, maxHeight: .infinity)
.allowsHitTesting(false)
}
}
.preferredColorScheme(viewStore.colorScheme)
.opacity(viewStore.opacity)
.animation(
featureFlag: \.animationBCrashSuggestion,
.easeInOut(duration: 0.2),
value: viewStore.isPanelDisplayed
)
.animation(
featureFlag: \.animationBCrashSuggestion,
.easeInOut(duration: 0.2),
value: viewStore.isPanelOutOfFrame
)
.frame(
maxWidth: Style.inlineSuggestionMinWidth,
maxHeight: Style.inlineSuggestionMaxHeight
)
}
}
}