Skip to content

Commit ae0f6bc

Browse files
committed
Hide connections page by default since unstable
1 parent ef2bae5 commit ae0f6bc

File tree

11 files changed

+29
-25
lines changed

11 files changed

+29
-25
lines changed

ApplicationLibrary/Views/Connections/ConnectionListView.swift

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,6 @@ public struct ConnectionListView: View {
88
@State private var isLoading = true
99
@StateObject private var commandClient = CommandClient(.connections)
1010
@State private var connections: [Connection] = []
11-
@State private var selection: ConnectionListPage = .active
1211
@State private var searchText = ""
1312
@State private var alert: Alert?
1413

ApplicationLibrary/Views/Connections/ConnectionView.swift

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -67,7 +67,7 @@ public struct ConnectionView: View {
6767
Spacer()
6868
VStack(alignment: .trailing) {
6969
Text(connection.inboundType + "/" + connection.inbound)
70-
Text(connection.chain.reversed().joined(separator: "/"))
70+
Text(connection.chain[0])
7171
}
7272
}
7373
}
@@ -111,7 +111,7 @@ public struct ConnectionView: View {
111111

112112
private nonisolated func closeConnection() async {
113113
do {
114-
try LibboxNewStandaloneCommandClient()!.closeConnection(connection.id)
114+
try await LibboxNewStandaloneCommandClient()!.closeConnection(connection.id)
115115
} catch {
116116
await MainActor.run {
117117
alert = Alert(error)

ApplicationLibrary/Views/Dashboard/ActiveDashboardView.swift

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -51,7 +51,7 @@ public struct ActiveDashboardView: View {
5151
#if os(iOS) || os(tvOS)
5252
if ApplicationLibrary.inPreview || profile.status.isConnectedStrict {
5353
Picker("Page", selection: $selection) {
54-
ForEach(DashboardPage.allCases) { page in
54+
ForEach(DashboardPage.enabledCases()) { page in
5555
page.label
5656
}
5757
}
@@ -61,7 +61,7 @@ public struct ActiveDashboardView: View {
6161
.navigationBarTitleDisplayMode(.inline)
6262
#endif
6363
TabView(selection: $selection) {
64-
ForEach(DashboardPage.enabledCases) { page in
64+
ForEach(DashboardPage.enabledCases()) { page in
6565
page.contentView($profileList, $selectedProfileID, $systemProxyAvailable, $systemProxyEnabled)
6666
.tag(page)
6767
}

ApplicationLibrary/Views/Dashboard/DashboardPage.swift

Lines changed: 9 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -13,18 +13,18 @@ public enum DashboardPage: Int, CaseIterable, Identifiable {
1313
}
1414

1515
public extension DashboardPage {
16-
#if !tvOS
17-
static var enabledCases: [DashboardPage] = [
16+
static func enabledCases() -> [DashboardPage] {
17+
var cases: [DashboardPage] = [
1818
.overview,
1919
.groups,
20-
.connections,
2120
]
22-
#else
23-
static var enabledCases: [DashboardPage] = [
24-
.overview,
25-
.groups,
26-
]
27-
#endif
21+
#if !tvOS
22+
if Variant.isBeta {
23+
cases.append(.connections)
24+
}
25+
#endif
26+
return cases
27+
}
2828
}
2929

3030
public extension DashboardPage {

ApplicationLibrary/Views/Profile/ImportProfileView.swift

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -75,10 +75,9 @@
7575
private func reset() {
7676
selected = false
7777
profiles = nil
78-
if let connection = connection {
78+
if let connection {
7979
connection.cancel()
8080
self.connection = nil
81-
8281
}
8382
}
8483

@@ -87,7 +86,7 @@
8786
self.connection = NWSocket(connection)
8887
connection.stateUpdateHandler = { state in
8988
switch state {
90-
case .failed(let error):
89+
case let .failed(error):
9190
DispatchQueue.main.async { [self] in
9291
reset()
9392
alert = Alert(error)

Library/Network/CommandClient.swift

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,7 @@ public class CommandClient: ObservableObject {
2222
@Published public var clashModeList: [String]
2323
@Published public var clashMode: String
2424

25-
@Published public var connectionStateFilter = ConnectionStateFilter.all
25+
@Published public var connectionStateFilter = ConnectionStateFilter.active
2626
@Published public var connectionSort = ConnectionSort.byDate
2727
@Published public var connections: [LibboxConnection]?
2828
public var rawConnections: LibboxConnections?

Library/Shared/Variant.swift

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,5 @@
11
import Foundation
2+
import Libbox
23

34
public enum Variant {
45
#if os(macOS)
@@ -14,4 +15,6 @@ public enum Variant {
1415
#elseif os(tvOS)
1516
public static let applicationName = "SFT"
1617
#endif
18+
19+
public static var isBeta = LibboxVersion().contains("-")
1720
}

MacLibrary/SidebarView.swift

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -33,7 +33,9 @@ public struct SidebarView: View {
3333
.tint(.textColor)
3434
.tag(NavigationPage.dashboard)
3535
NavigationPage.groups.label.tag(NavigationPage.groups)
36-
NavigationPage.connections.label.tag(NavigationPage.connections)
36+
if Variant.isBeta {
37+
NavigationPage.connections.label.tag(NavigationPage.connections)
38+
}
3739
}
3840
Divider()
3941
ForEach(NavigationPage.macosDefaultPages, id: \.self) { it in

SFM.System/Application.swift

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -4,7 +4,7 @@ import SwiftUI
44

55
@main
66
struct Application: App {
7-
@NSApplicationDelegateAdaptor private var appDelegate: IndependentApplicationDelegate
7+
@NSApplicationDelegateAdaptor private var appDelegate: StandaloneApplicationDelegate
88

99
var body: some Scene {
1010
MacApplication()

SFM.System/IndependentApplicationDelegate.swift renamed to SFM.System/StandaloneApplicationDelegate.swift

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -3,9 +3,10 @@ import Foundation
33
import Library
44
import MacLibrary
55

6-
class IndependentApplicationDelegate: ApplicationDelegate {
6+
class StandaloneApplicationDelegate: ApplicationDelegate {
77
public func applicationWillFinishLaunching(_: Notification) {
88
Variant.useSystemExtension = true
9+
Variant.isBeta = false
910
Task {
1011
await setupSystemExtension()
1112
}

0 commit comments

Comments
 (0)