-
-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Expand file tree
/
Copy pathEditorAreaFileView.swift
More file actions
91 lines (81 loc) · 2.78 KB
/
Copy pathEditorAreaFileView.swift
File metadata and controls
91 lines (81 loc) · 2.78 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
//
// EditorAreaFileView.swift
// CodeEdit
//
// Created by Pavel Kasila on 20.03.22.
//
import AppKit
import AVKit
import CodeEditSourceEditor
import SwiftUI
struct EditorAreaFileView: View {
@EnvironmentObject private var editorManager: EditorManager
@EnvironmentObject private var editor: Editor
@EnvironmentObject private var statusBarViewModel: StatusBarViewModel
@Environment(\.edgeInsets)
private var edgeInsets
var editorInstance: EditorInstance
var codeFile: CodeFileDocument
@StateObject private var previewRunner = SwiftUIPreviewRunner()
@State private var hasSwiftUIPreview = false
@ViewBuilder var editorAreaFileView: some View {
if let utType = codeFile.utType, utType.conforms(to: .text) {
if hasSwiftUIPreview {
HSplitView {
CodeFileView(
editorInstance: editorInstance,
codeFile: codeFile
)
SwiftUIPreviewCanvasView(runner: previewRunner)
}
} else {
CodeFileView(
editorInstance: editorInstance,
codeFile: codeFile
)
}
} else {
NonTextFileView(fileDocument: codeFile)
.padding(.top, edgeInsets.top - 1.74)
.padding(.bottom, StatusBarView.height + 1.26)
.modifier(UpdateStatusBarInfo(with: codeFile.fileURL))
.onDisappear {
statusBarViewModel.dimensions = nil
statusBarViewModel.fileSize = nil
}
}
}
var body: some View {
editorAreaFileView
.frame(maxWidth: .infinity, maxHeight: .infinity)
.onAppear {
updateSwiftUIPreview()
}
.onChange(of: codeFile.fileURL) { _, _ in
updateSwiftUIPreview()
}
.onReceive(codeFile.contentCoordinator.textUpdatePublisher) { _ in
updateSwiftUIPreview()
}
.onHover { hover in
DispatchQueue.main.async {
if hover {
NSCursor.iBeam.push()
} else {
NSCursor.pop()
}
}
}
}
private func updateSwiftUIPreview() {
guard codeFile.fileURL?.pathExtension.lowercased() == "swift",
let source = codeFile.content?.string,
SwiftUIPreviewParser.firstPreview(in: source) != nil else {
hasSwiftUIPreview = false
previewRunner.clear()
return
}
hasSwiftUIPreview = true
previewRunner.compile(source: source, fileURL: codeFile.fileURL)
}
}