From bc0876fe736d89925baf3cb492590141d93195b2 Mon Sep 17 00:00:00 2001 From: streetturtle Date: Sat, 16 Nov 2024 14:50:56 -0500 Subject: [PATCH 1/3] Fix tab view --- pullBar.xcodeproj/project.pbxproj | 8 +++--- pullBar/AppDelegate.swift | 44 +++++++++++------------------ pullBar/GitHub/GitHubClient.swift | 29 ++++++++----------- pullBar/Views/PreferencesView.swift | 19 ++++++------- 4 files changed, 40 insertions(+), 60 deletions(-) diff --git a/pullBar.xcodeproj/project.pbxproj b/pullBar.xcodeproj/project.pbxproj index a4fd4ee..740a34b 100644 --- a/pullBar.xcodeproj/project.pbxproj +++ b/pullBar.xcodeproj/project.pbxproj @@ -402,7 +402,7 @@ "CODE_SIGN_IDENTITY[sdk=macosx*]" = "Apple Development"; CODE_SIGN_STYLE = Automatic; COMBINE_HIDPI_IMAGES = YES; - CURRENT_PROJECT_VERSION = 14gh; + CURRENT_PROJECT_VERSION = 15gh; DEAD_CODE_STRIPPING = YES; DEVELOPMENT_TEAM = UV3HUS49VJ; ENABLE_HARDENED_RUNTIME = YES; @@ -416,7 +416,7 @@ "$(inherited)", "@executable_path/../Frameworks", ); - MARKETING_VERSION = 1.10; + MARKETING_VERSION = 1.11; PRODUCT_BUNDLE_IDENTIFIER = debug.com.pavelmakhov.pullBar; PRODUCT_NAME = "$(TARGET_NAME)"; SWIFT_EMIT_LOC_STRINGS = YES; @@ -434,7 +434,7 @@ "CODE_SIGN_IDENTITY[sdk=macosx*]" = "Apple Development"; CODE_SIGN_STYLE = Automatic; COMBINE_HIDPI_IMAGES = YES; - CURRENT_PROJECT_VERSION = 14gh; + CURRENT_PROJECT_VERSION = 15gh; DEAD_CODE_STRIPPING = YES; DEVELOPMENT_TEAM = UV3HUS49VJ; ENABLE_HARDENED_RUNTIME = YES; @@ -448,7 +448,7 @@ "$(inherited)", "@executable_path/../Frameworks", ); - MARKETING_VERSION = 1.10; + MARKETING_VERSION = 1.11; PRODUCT_BUNDLE_IDENTIFIER = com.pavelmakhov.pullBar; PRODUCT_NAME = "$(TARGET_NAME)"; SWIFT_EMIT_LOC_STRINGS = YES; diff --git a/pullBar/AppDelegate.swift b/pullBar/AppDelegate.swift index e6c1312..5ecd4df 100644 --- a/pullBar/AppDelegate.swift +++ b/pullBar/AppDelegate.swift @@ -13,19 +13,7 @@ import KeychainAccess @main class AppDelegate: NSObject, NSApplicationDelegate { - - @Default(.showAssigned) var showAssigned - @Default(.showCreated) var showCreated - @Default(.showRequested) var showRequested - - @Default(.showAvatar) var showAvatar - @Default(.showLabels) var showLabels - - @Default(.refreshRate) var refreshRate - @Default(.buildType) var buildType - @Default(.counterType) var counterType - - @Default(.githubUsername) var githubUsername + @FromKeychain(.githubToken) var githubToken let ghClient = GitHubClient() @@ -51,7 +39,7 @@ class AppDelegate: NSObject, NSApplicationDelegate { statusBarItem.menu = menu timer = Timer.scheduledTimer( - timeInterval: Double(refreshRate * 60), + timeInterval: Double(Defaults[.refreshRate] * 60), target: self, selector: #selector(refreshMenu), userInfo: nil, @@ -86,7 +74,7 @@ extension AppDelegate { NSLog("Refreshing menu") self.menu.removeAllItems() - if (githubUsername == "" || githubToken == "") { + if (Defaults[.githubUsername] == "" || githubToken == "") { addMenuFooterItems() return } @@ -99,7 +87,7 @@ extension AppDelegate { let group = DispatchGroup() - if showAssigned { + if Defaults[.showAssigned] { group.enter() ghClient.getAssignedPulls() { pulls in assignedPulls?.append(contentsOf: pulls) @@ -107,7 +95,7 @@ extension AppDelegate { } } - if showCreated { + if Defaults[.showCreated] { group.enter() ghClient.getCreatedPulls() { pulls in createdPulls?.append(contentsOf: pulls) @@ -115,7 +103,7 @@ extension AppDelegate { } } - if showRequested { + if Defaults[.showRequested] { group.enter() ghClient.getReviewRequestedPulls() { pulls in reviewRequestedPulls?.append(contentsOf: pulls) @@ -128,8 +116,8 @@ extension AppDelegate { if let assignedPulls = assignedPulls, let createdPulls = createdPulls, let reviewRequestedPulls = reviewRequestedPulls { self.statusBarItem.button?.title = "" - if self.showAssigned && !assignedPulls.isEmpty { - if self.counterType == .assigned { + if Defaults[.showAssigned] && !assignedPulls.isEmpty { + if Defaults[.counterType] == .assigned { self.statusBarItem.button?.title = String(assignedPulls.count) } @@ -140,8 +128,8 @@ extension AppDelegate { self.menu.addItem(.separator()) } - if self.showCreated && !createdPulls.isEmpty { - if self.counterType == .created { + if Defaults[.showCreated] && !createdPulls.isEmpty { + if Defaults[.counterType] == .created { self.statusBarItem.button?.title = String(createdPulls.count) } @@ -152,8 +140,8 @@ extension AppDelegate { self.menu.addItem(.separator()) } - if self.showRequested && !reviewRequestedPulls.isEmpty { - if self.counterType == .reviewRequested { + if Defaults[.showRequested] && !reviewRequestedPulls.isEmpty { + if Defaults[.counterType] == .reviewRequested { self.statusBarItem.button?.title = String(reviewRequestedPulls.count) } @@ -195,7 +183,7 @@ extension AppDelegate { .appendIcon(iconName: "person") .appendString(string: pull.node.author.login) - if !pull.node.labels.nodes.isEmpty && self.showLabels { + if !pull.node.labels.nodes.isEmpty && Defaults[.showLabels] { issueItemTitle .appendNewLine() .appendIcon(iconName: "tag", color: NSColor(.secondary)) @@ -208,7 +196,7 @@ extension AppDelegate { issueItemTitle.appendNewLine() - let approvedByMe = pull.node.reviews.edges.contains{ $0.node.author.login == githubUsername } + let approvedByMe = pull.node.reviews.edges.contains{ $0.node.author.login == Defaults[.githubUsername] } issueItemTitle .appendIcon(iconName: "check-circle", color: approvedByMe ? NSColor(named: "green")! : NSColor.secondaryLabelColor) .appendString(string: " " + String(pull.node.reviews.totalCount)) @@ -219,7 +207,7 @@ extension AppDelegate { .appendIcon(iconName: "calendar") .appendString(string: pull.node.createdAt.getElapsedInterval()) - if showAvatar { + if Defaults[.showAvatar] { var image = NSImage() if let imageURL = pull.node.author.avatarUrl { image = NSImage.imageFromUrl(fromURL: imageURL) ?? NSImage(named: "person")! @@ -400,7 +388,7 @@ extension AppDelegate { if (windowTitle == "Preferences") { timer?.invalidate() timer = Timer.scheduledTimer( - timeInterval: Double(refreshRate * 60), + timeInterval: Double(Defaults[.refreshRate] * 60), target: self, selector: #selector(refreshMenu), userInfo: nil, diff --git a/pullBar/GitHub/GitHubClient.swift b/pullBar/GitHub/GitHubClient.swift index 92f7833..dd22d6f 100644 --- a/pullBar/GitHub/GitHubClient.swift +++ b/pullBar/GitHub/GitHubClient.swift @@ -12,16 +12,11 @@ import KeychainAccess public class GitHubClient { - @Default(.githubApiBaseUrl) var githubApiBaseUrl - @Default(.githubUsername) var githubUsername - @Default(.githubAdditionalQuery) var githubAdditionalQuery @FromKeychain(.githubToken) var githubToken - - @Default(.buildType) var buildType func getAssignedPulls(completion:@escaping (([Edge]) -> Void)) -> Void { - if (githubUsername == "" || githubToken == "") { + if (Defaults[.githubUsername] == "" || githubToken == "") { completion([Edge]()) } @@ -30,14 +25,14 @@ public class GitHubClient { .accept("application/json") ] - let graphQlQuery = buildGraphQlQuery(queryString: "is:open is:pr assignee:\(githubUsername) archived:false \(githubAdditionalQuery)") + let graphQlQuery = buildGraphQlQuery(queryString: "is:open is:pr assignee:\(Defaults[.githubUsername]) archived:false \(Defaults[.githubAdditionalQuery])") let parameters = [ "query": graphQlQuery, "variables":[] ] as [String: Any] - AF.request(githubApiBaseUrl + "/graphql", method: .post, parameters: parameters, encoding: JSONEncoding.default, headers: headers) + AF.request(Defaults[.githubApiBaseUrl] + "/graphql", method: .post, parameters: parameters, encoding: JSONEncoding.default, headers: headers) .validate(statusCode: 200..<300) .responseDecodable(of: GraphQlSearchResp.self, decoder: GithubDecoder()) { response in switch response.result { @@ -53,7 +48,7 @@ public class GitHubClient { func getCreatedPulls(completion:@escaping (([Edge]) -> Void)) -> Void { - if (githubUsername == "" || githubToken == "") { + if (Defaults[.githubUsername] == "" || githubToken == "") { completion([Edge]()) } @@ -61,14 +56,14 @@ public class GitHubClient { .authorization(bearerToken: githubToken), .accept("application/json") ] - let graphQlQuery = buildGraphQlQuery(queryString: "is:open is:pr author:\(githubUsername) archived:false \(githubAdditionalQuery)") + let graphQlQuery = buildGraphQlQuery(queryString: "is:open is:pr author:\(Defaults[.githubUsername]) archived:false \(Defaults[.githubAdditionalQuery])") let parameters = [ "query": graphQlQuery, "variables":[] ] as [String: Any] - AF.request(githubApiBaseUrl + "/graphql", method: .post, parameters: parameters, encoding: JSONEncoding.default, headers: headers) + AF.request(Defaults[.githubApiBaseUrl] + "/graphql", method: .post, parameters: parameters, encoding: JSONEncoding.default, headers: headers) .validate(statusCode: 200..<300) .responseDecodable(of: GraphQlSearchResp.self, decoder: GithubDecoder()) { response in switch response.result { @@ -83,7 +78,7 @@ public class GitHubClient { } func getReviewRequestedPulls(completion:@escaping (([Edge]) -> Void)) -> Void { - if (githubUsername == "" || githubToken == "") { + if (Defaults[.githubUsername] == "" || githubToken == "") { completion([Edge]()) } @@ -91,14 +86,14 @@ public class GitHubClient { .authorization(bearerToken: githubToken), .accept("application/json") ] - let graphQlQuery = buildGraphQlQuery(queryString: "is:open is:pr review-requested:\(githubUsername) archived:false \(githubAdditionalQuery)") + let graphQlQuery = buildGraphQlQuery(queryString: "is:open is:pr review-requested:\(Defaults[.githubUsername]) archived:false \(Defaults[.githubAdditionalQuery])") let parameters = [ "query": graphQlQuery, "variables":[] ] as [String: Any] - AF.request(githubApiBaseUrl + "/graphql", method: .post, parameters: parameters, encoding: JSONEncoding.default, headers: headers) + AF.request(Defaults[.githubApiBaseUrl] + "/graphql", method: .post, parameters: parameters, encoding: JSONEncoding.default, headers: headers) .validate(statusCode: 200..<300) .responseDecodable(of: GraphQlSearchResp.self, decoder: GithubDecoder()) { response in switch response.result { @@ -115,7 +110,7 @@ public class GitHubClient { var build = "" - switch buildType { + switch Defaults[.buildType] { case .checks: build = """ commits(last: 1) { @@ -233,7 +228,7 @@ public class GitHubClient { .accept("application/json") ] - AF.request(githubApiBaseUrl + "/user", + AF.request(Defaults[.githubApiBaseUrl] + "/user", method: .get, headers: headers) .validate(statusCode: 200..<300) @@ -251,7 +246,7 @@ public class GitHubClient { func getLatestRelease(completion:@escaping (((LatestRelease?) -> Void))) -> Void { let headers: HTTPHeaders = [ - .authorization(username: githubUsername, password: githubToken), + .authorization(username: Defaults[.githubUsername], password: githubToken), .contentType("application/json"), .accept("application/json") ] diff --git a/pullBar/Views/PreferencesView.swift b/pullBar/Views/PreferencesView.swift index 78f3080..fce32aa 100644 --- a/pullBar/Views/PreferencesView.swift +++ b/pullBar/Views/PreferencesView.swift @@ -29,8 +29,6 @@ struct PreferencesView: View { @Default(.counterType) var counterType @State private var showGhAlert = false - - @State private var selectedTab: Int = 1 @StateObject private var githubTokenValidator = GithubTokenValidator() @ObservedObject private var launchAtLogin = LaunchAtLogin.observable @@ -39,7 +37,7 @@ struct PreferencesView: View { var body: some View { - TabView (selection: $selectedTab) { + TabView { Form { HStack(alignment: .center) { Text("Pull Requests:").frame(width: 120, alignment: .trailing) @@ -49,7 +47,7 @@ struct PreferencesView: View { Toggle("review requested", isOn: $showRequested) } } - + HStack(alignment: .center) { Text("Build Information:").frame(width: 120, alignment: .trailing) Picker("", selection: $builtType, content: { @@ -61,17 +59,17 @@ struct PreferencesView: View { .pickerStyle(RadioGroupPickerStyle()) .frame(width: 120) } - + HStack(alignment: .center) { Text("Show Avatar:").frame(width: 120, alignment: .trailing) Toggle("", isOn: $showAvatar) } - + HStack(alignment: .center) { Text("Show Labels:").frame(width: 120, alignment: .trailing) Toggle("", isOn: $showLabels) } - + HStack(alignment: .center) { Text("Refresh Rate:").frame(width: 120, alignment: .trailing) Picker("", selection: $refreshRate, content: { @@ -84,13 +82,12 @@ struct PreferencesView: View { .pickerStyle(MenuPickerStyle()) .frame(width: 100) } - + HStack(alignment: .center) { Text("Launch at login:").frame(width: 120, alignment: .trailing) Toggle("", isOn: $launchAtLogin.isEnabled) - } - + } .padding(8) .frame(maxWidth: .infinity) @@ -149,7 +146,6 @@ struct PreferencesView: View { githubTokenValidator.validate() } .tabItem{Text("Authentication")} - .tag(1) Form { HStack(alignment: .center) { @@ -191,6 +187,7 @@ struct PreferencesView: View { .tabItem{Text("Advanced")} } + .frame(width: 600) .padding() } From 201bbfc310028d796d952b6d85190c71cda30250 Mon Sep 17 00:00:00 2001 From: streetturtle Date: Sat, 16 Nov 2024 14:52:23 -0500 Subject: [PATCH 2/3] revert version change --- pullBar.xcodeproj/project.pbxproj | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/pullBar.xcodeproj/project.pbxproj b/pullBar.xcodeproj/project.pbxproj index 740a34b..a4fd4ee 100644 --- a/pullBar.xcodeproj/project.pbxproj +++ b/pullBar.xcodeproj/project.pbxproj @@ -402,7 +402,7 @@ "CODE_SIGN_IDENTITY[sdk=macosx*]" = "Apple Development"; CODE_SIGN_STYLE = Automatic; COMBINE_HIDPI_IMAGES = YES; - CURRENT_PROJECT_VERSION = 15gh; + CURRENT_PROJECT_VERSION = 14gh; DEAD_CODE_STRIPPING = YES; DEVELOPMENT_TEAM = UV3HUS49VJ; ENABLE_HARDENED_RUNTIME = YES; @@ -416,7 +416,7 @@ "$(inherited)", "@executable_path/../Frameworks", ); - MARKETING_VERSION = 1.11; + MARKETING_VERSION = 1.10; PRODUCT_BUNDLE_IDENTIFIER = debug.com.pavelmakhov.pullBar; PRODUCT_NAME = "$(TARGET_NAME)"; SWIFT_EMIT_LOC_STRINGS = YES; @@ -434,7 +434,7 @@ "CODE_SIGN_IDENTITY[sdk=macosx*]" = "Apple Development"; CODE_SIGN_STYLE = Automatic; COMBINE_HIDPI_IMAGES = YES; - CURRENT_PROJECT_VERSION = 15gh; + CURRENT_PROJECT_VERSION = 14gh; DEAD_CODE_STRIPPING = YES; DEVELOPMENT_TEAM = UV3HUS49VJ; ENABLE_HARDENED_RUNTIME = YES; @@ -448,7 +448,7 @@ "$(inherited)", "@executable_path/../Frameworks", ); - MARKETING_VERSION = 1.11; + MARKETING_VERSION = 1.10; PRODUCT_BUNDLE_IDENTIFIER = com.pavelmakhov.pullBar; PRODUCT_NAME = "$(TARGET_NAME)"; SWIFT_EMIT_LOC_STRINGS = YES; From 21800f6c189598a31232f89bf8042706c121ff2c Mon Sep 17 00:00:00 2001 From: streetturtle Date: Sat, 16 Nov 2024 14:53:42 -0500 Subject: [PATCH 3/3] Fix empty lines Signed-off-by: streetturtle --- pullBar/Views/PreferencesView.swift | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/pullBar/Views/PreferencesView.swift b/pullBar/Views/PreferencesView.swift index fce32aa..b143d96 100644 --- a/pullBar/Views/PreferencesView.swift +++ b/pullBar/Views/PreferencesView.swift @@ -47,7 +47,7 @@ struct PreferencesView: View { Toggle("review requested", isOn: $showRequested) } } - + HStack(alignment: .center) { Text("Build Information:").frame(width: 120, alignment: .trailing) Picker("", selection: $builtType, content: { @@ -59,17 +59,17 @@ struct PreferencesView: View { .pickerStyle(RadioGroupPickerStyle()) .frame(width: 120) } - + HStack(alignment: .center) { Text("Show Avatar:").frame(width: 120, alignment: .trailing) Toggle("", isOn: $showAvatar) } - + HStack(alignment: .center) { Text("Show Labels:").frame(width: 120, alignment: .trailing) Toggle("", isOn: $showLabels) } - + HStack(alignment: .center) { Text("Refresh Rate:").frame(width: 120, alignment: .trailing) Picker("", selection: $refreshRate, content: { @@ -82,17 +82,17 @@ struct PreferencesView: View { .pickerStyle(MenuPickerStyle()) .frame(width: 100) } - + HStack(alignment: .center) { Text("Launch at login:").frame(width: 120, alignment: .trailing) Toggle("", isOn: $launchAtLogin.isEnabled) } - + } .padding(8) .frame(maxWidth: .infinity) .tabItem{Text("General")} - + Form { HStack(alignment: .center) { Text("API Base URL:").frame(width: 120, alignment: .trailing)