From 96f5b51586474d5ccabac68fddb2e95d66fa5f3a Mon Sep 17 00:00:00 2001 From: Alan Hamlett Date: Tue, 26 Mar 2024 20:21:33 -0400 Subject: [PATCH] Hide browser settings when no browser monitored --- WakaTime/Helpers/MonitoringManager.swift | 12 ++++++ WakaTime/Views/SettingsView.swift | 52 +++++++++++++++--------- 2 files changed, 44 insertions(+), 20 deletions(-) diff --git a/WakaTime/Helpers/MonitoringManager.swift b/WakaTime/Helpers/MonitoringManager.swift index 9a0ea17..8e92ced 100644 --- a/WakaTime/Helpers/MonitoringManager.swift +++ b/WakaTime/Helpers/MonitoringManager.swift @@ -78,6 +78,18 @@ class MonitoringManager { ) } + static var isMonitoringBrowsing: Bool { + for bundleId in MonitoredApp.browserAppIds { + guard + AppInfo.getAppName(bundleId: bundleId) != nil, + isAppMonitored(for: bundleId) + else { continue } + + return true + } + return false + } + static func set(monitoringState: MonitoringState, for bundleId: String) { UserDefaults.standard.set(monitoringState == .on, forKey: monitoredKey(bundleId: bundleId)) UserDefaults.standard.synchronize() diff --git a/WakaTime/Views/SettingsView.swift b/WakaTime/Views/SettingsView.swift index 14b9e2a..8f31f01 100644 --- a/WakaTime/Views/SettingsView.swift +++ b/WakaTime/Views/SettingsView.swift @@ -55,7 +55,7 @@ class SettingsView: NSView, NSTextFieldDelegate, NSTextViewDelegate { // MARK: Domain Preference lazy var browserLabel: NSTextField = { - var label = NSTextField(labelWithString: "The settings below are only applicable when you’ve enabled " + + var label = NSTextField(labelWithString: "The settings below are only applicable because you’ve enabled " + "monitoring a browser in the Monitored Apps menu.") label.lineBreakMode = .byWordWrapping // Enable word wrapping label.maximumNumberOfLines = 0 // Set to 0 to allow unlimited lines @@ -167,31 +167,41 @@ class SettingsView: NSView, NSTextFieldDelegate, NSTextViewDelegate { }() lazy var stackView: NSStackView = { - let stackView = NSStackView(views: [ + var views: [NSView] = [ apiKeyStackView, - checkboxesStackView, - browserLabel, - domainStackView, - filterStackView, - versionLabel - ]) + checkboxesStackView + ] + if MonitoringManager.isMonitoringBrowsing { + views.append(contentsOf: [ + browserLabel, + domainStackView, + filterStackView, + versionLabel + ]) + } + + let stackView = NSStackView(views: views) stackView.alignment = .leading stackView.orientation = .vertical stackView.spacing = 25 stackView.distribution = .equalSpacing stackView.edgeInsets = NSEdgeInsets(top: 10, left: 10, bottom: 10, right: 10) stackView.translatesAutoresizingMaskIntoConstraints = false - stackView.addConstraint( - NSLayoutConstraint( - item: filterStackView, - attribute: .width, - relatedBy: .equal, - toItem: stackView, - attribute: .width, - multiplier: 1, - constant: -(stackView.edgeInsets.left + stackView.edgeInsets.right) + + if MonitoringManager.isMonitoringBrowsing { + stackView.addConstraint( + NSLayoutConstraint( + item: filterStackView, + attribute: .width, + relatedBy: .equal, + toItem: stackView, + attribute: .width, + multiplier: 1, + constant: -(stackView.edgeInsets.left + stackView.edgeInsets.right) + ) ) - ) + } + return stackView }() @@ -203,8 +213,10 @@ class SettingsView: NSView, NSTextFieldDelegate, NSTextViewDelegate { addSubview(stackView) setupConstraints() - updateDomainPreference(animate: false) - updateFilterControls(animate: false) + if MonitoringManager.isMonitoringBrowsing { + updateDomainPreference(animate: false) + updateFilterControls(animate: false) + } } required init?(coder: NSCoder) {