fix: properly reactive frame sizing
This commit is contained in:
@@ -66,7 +66,7 @@ struct AppSettings: Codable, Equatable, Hashable {
|
|||||||
hasCompletedOnboarding: Bool = false,
|
hasCompletedOnboarding: Bool = false,
|
||||||
launchAtLogin: Bool = false,
|
launchAtLogin: Bool = false,
|
||||||
playSounds: Bool = true,
|
playSounds: Bool = true,
|
||||||
isAppStoreVersion: Bool = false
|
isAppStoreVersion: Bool = true
|
||||||
) {
|
) {
|
||||||
self.lookAwayTimer = lookAwayTimer
|
self.lookAwayTimer = lookAwayTimer
|
||||||
self.lookAwayCountdownSeconds = lookAwayCountdownSeconds
|
self.lookAwayCountdownSeconds = lookAwayCountdownSeconds
|
||||||
|
|||||||
@@ -31,8 +31,14 @@ struct OnboardingContainerView: View {
|
|||||||
@State private var postureIntervalMinutes = 30
|
@State private var postureIntervalMinutes = 30
|
||||||
@State private var launchAtLogin = false
|
@State private var launchAtLogin = false
|
||||||
@State private var subtleReminderSize: ReminderSize = .medium
|
@State private var subtleReminderSize: ReminderSize = .medium
|
||||||
|
@State private var isAppStoreVersion: Bool
|
||||||
@Environment(\.dismiss) private var dismiss
|
@Environment(\.dismiss) private var dismiss
|
||||||
|
|
||||||
|
init(settingsManager: SettingsManager) {
|
||||||
|
self.settingsManager = settingsManager
|
||||||
|
_isAppStoreVersion = State(initialValue: settingsManager.settings.isAppStoreVersion)
|
||||||
|
}
|
||||||
|
|
||||||
var body: some View {
|
var body: some View {
|
||||||
ZStack {
|
ZStack {
|
||||||
VisualEffectView(material: .hudWindow, blendingMode: .behindWindow)
|
VisualEffectView(material: .hudWindow, blendingMode: .behindWindow)
|
||||||
@@ -78,10 +84,7 @@ struct OnboardingContainerView: View {
|
|||||||
GeneralSetupView(
|
GeneralSetupView(
|
||||||
launchAtLogin: $launchAtLogin,
|
launchAtLogin: $launchAtLogin,
|
||||||
subtleReminderSize: $subtleReminderSize,
|
subtleReminderSize: $subtleReminderSize,
|
||||||
isAppStoreVersion: Binding(
|
isAppStoreVersion: .constant(isAppStoreVersion),
|
||||||
get: { settingsManager.settings.isAppStoreVersion },
|
|
||||||
set: { _ in }
|
|
||||||
),
|
|
||||||
isOnboarding: true
|
isOnboarding: true
|
||||||
)
|
)
|
||||||
.tag(4)
|
.tag(4)
|
||||||
@@ -149,7 +152,14 @@ struct OnboardingContainerView: View {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.frame(minWidth: 1000, minHeight: 800)
|
|
||||||
|
.frame(
|
||||||
|
minWidth: 1000,
|
||||||
|
minHeight: isAppStoreVersion ? 700 : 900
|
||||||
|
)
|
||||||
|
.onReceive(settingsManager.$settings) { newSettings in
|
||||||
|
isAppStoreVersion = newSettings.isAppStoreVersion
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private func completeOnboarding() {
|
private func completeOnboarding() {
|
||||||
|
|||||||
@@ -20,6 +20,7 @@ struct SettingsWindowView: View {
|
|||||||
@State private var launchAtLogin: Bool
|
@State private var launchAtLogin: Bool
|
||||||
@State private var subtleReminderSize: ReminderSize
|
@State private var subtleReminderSize: ReminderSize
|
||||||
@State private var userTimers: [UserTimer]
|
@State private var userTimers: [UserTimer]
|
||||||
|
@State private var isAppStoreVersion: Bool
|
||||||
|
|
||||||
init(settingsManager: SettingsManager, initialTab: Int = 0) {
|
init(settingsManager: SettingsManager, initialTab: Int = 0) {
|
||||||
self.settingsManager = settingsManager
|
self.settingsManager = settingsManager
|
||||||
@@ -40,6 +41,7 @@ struct SettingsWindowView: View {
|
|||||||
_subtleReminderSize = State(
|
_subtleReminderSize = State(
|
||||||
initialValue: settingsManager.settings.subtleReminderSize)
|
initialValue: settingsManager.settings.subtleReminderSize)
|
||||||
_userTimers = State(initialValue: settingsManager.settings.userTimers)
|
_userTimers = State(initialValue: settingsManager.settings.userTimers)
|
||||||
|
_isAppStoreVersion = State(initialValue: settingsManager.settings.isAppStoreVersion)
|
||||||
}
|
}
|
||||||
|
|
||||||
var body: some View {
|
var body: some View {
|
||||||
@@ -84,10 +86,7 @@ struct SettingsWindowView: View {
|
|||||||
GeneralSetupView(
|
GeneralSetupView(
|
||||||
launchAtLogin: $launchAtLogin,
|
launchAtLogin: $launchAtLogin,
|
||||||
subtleReminderSize: $subtleReminderSize,
|
subtleReminderSize: $subtleReminderSize,
|
||||||
isAppStoreVersion: Binding(
|
isAppStoreVersion: .constant(isAppStoreVersion),
|
||||||
get: { settingsManager.settings.isAppStoreVersion },
|
|
||||||
set: { _ in }
|
|
||||||
),
|
|
||||||
isOnboarding: false
|
isOnboarding: false
|
||||||
)
|
)
|
||||||
.tag(4)
|
.tag(4)
|
||||||
@@ -115,7 +114,13 @@ struct SettingsWindowView: View {
|
|||||||
}
|
}
|
||||||
.padding()
|
.padding()
|
||||||
}
|
}
|
||||||
.frame(minWidth: 750, minHeight: 850)
|
.frame(
|
||||||
|
minWidth: 750,
|
||||||
|
minHeight: isAppStoreVersion ? 700 : 900
|
||||||
|
)
|
||||||
|
.onReceive(settingsManager.$settings) { newSettings in
|
||||||
|
isAppStoreVersion = newSettings.isAppStoreVersion
|
||||||
|
}
|
||||||
.onReceive(
|
.onReceive(
|
||||||
NotificationCenter.default.publisher(for: Notification.Name("SwitchToSettingsTab"))
|
NotificationCenter.default.publisher(for: Notification.Name("SwitchToSettingsTab"))
|
||||||
) { notification in
|
) { notification in
|
||||||
@@ -147,7 +152,7 @@ struct SettingsWindowView: View {
|
|||||||
hasCompletedOnboarding: settingsManager.settings.hasCompletedOnboarding,
|
hasCompletedOnboarding: settingsManager.settings.hasCompletedOnboarding,
|
||||||
launchAtLogin: launchAtLogin,
|
launchAtLogin: launchAtLogin,
|
||||||
playSounds: settingsManager.settings.playSounds,
|
playSounds: settingsManager.settings.playSounds,
|
||||||
isAppStoreVersion: settingsManager.settings.isAppStoreVersion
|
isAppStoreVersion: isAppStoreVersion
|
||||||
)
|
)
|
||||||
|
|
||||||
// Assign the entire settings object to trigger didSet and observers
|
// Assign the entire settings object to trigger didSet and observers
|
||||||
|
|||||||
Reference in New Issue
Block a user