From 75951b3f8fd94c508a5b7b7ed969b08159dad52b Mon Sep 17 00:00:00 2001 From: Anh Do Date: Mon, 30 Dec 2024 15:32:54 +0700 Subject: [PATCH] Fix GeometryReader breaking interaction --- .../View/PreferencesAboutView.swift | 66 +++++++++++-------- 1 file changed, 37 insertions(+), 29 deletions(-) diff --git a/DuckDuckGo/Preferences/View/PreferencesAboutView.swift b/DuckDuckGo/Preferences/View/PreferencesAboutView.swift index d6fe08b06a..3a7a57fecf 100644 --- a/DuckDuckGo/Preferences/View/PreferencesAboutView.swift +++ b/DuckDuckGo/Preferences/View/PreferencesAboutView.swift @@ -33,52 +33,37 @@ extension Preferences { var body: some View { PreferencePane { - GeometryReader { geometry in - VStack(alignment: .leading) { - TextMenuTitle(UserText.aboutDuckDuckGo) + VStack(alignment: .leading) { + TextMenuTitle(UserText.aboutDuckDuckGo) - if !model.isCurrentOsReceivingUpdates { - UnsupportedDeviceInfoBox(wide: true) - .padding(.top, 10) - .padding(.leading, -20) - } + if !model.isCurrentOsReceivingUpdates { + UnsupportedDeviceInfoBox(wide: true) + .padding(.top, 10) + .padding(.leading, -20) + } - AboutContentSection(geometry: geometry, model: model) + AboutContentSection(model: model) #if SPARKLE - UpdatesSection(areAutomaticUpdatesEnabled: $areAutomaticUpdatesEnabled, model: model) + UpdatesSection(areAutomaticUpdatesEnabled: $areAutomaticUpdatesEnabled, model: model) #endif - } } } } } struct AboutContentSection: View { - var geometry: GeometryProxy @ObservedObject var model: AboutPreferences var body: some View { PreferencePaneSection { - if geometry.size.width > 400 { - HStack(alignment: .top) { - Image(.aboutPageLogo) - .padding(.top, 2) - VStack(alignment: .leading, spacing: 8) { - rightColumnContent - } - .padding(.top, 10) + if #available(macOS 13.0, *) { + ViewThatFits(in: .horizontal) { + horizontalPageLogo + verticalPageLogo } - .padding(.bottom, 8) } else { - VStack(alignment: .leading) { - Image(.aboutPageLogo) - VStack(alignment: .leading, spacing: 8) { - rightColumnContent - } - .padding(.top, 10) - } - .padding(.bottom, 8) + horizontalPageLogo } TextButton(UserText.moreAt(url: model.displayableAboutURL)) { @@ -139,6 +124,29 @@ extension Preferences { } } + private var horizontalPageLogo: some View { + HStack(alignment: .top) { + Image(.aboutPageLogo) + .padding(.top, 2) + VStack(alignment: .leading, spacing: 8) { + rightColumnContent + } + .padding(.top, 10) + } + .padding(.bottom, 8) + } + + private var verticalPageLogo: some View { + VStack(alignment: .leading) { + Image(.aboutPageLogo) + VStack(alignment: .leading, spacing: 8) { + rightColumnContent + } + .padding(.top, 10) + } + .padding(.bottom, 8) + } + #if SPARKLE private var hasPendingUpdate: Bool { model.updateController?.hasPendingUpdate == true