From d68d8a468abaa7932ae784e935e32c4dc065e605 Mon Sep 17 00:00:00 2001 From: Juan Manuel Pereira Date: Thu, 19 Dec 2024 11:29:20 -0300 Subject: [PATCH] Implement new button designs --- .../TabBarRemoteMessageView.swift | 53 +++++++++++-------- 1 file changed, 32 insertions(+), 21 deletions(-) diff --git a/DuckDuckGo/RemoteMessaging/TabBarRemoteMessageView.swift b/DuckDuckGo/RemoteMessaging/TabBarRemoteMessageView.swift index 4d9ed3e5fd..5332b13456 100644 --- a/DuckDuckGo/RemoteMessaging/TabBarRemoteMessageView.swift +++ b/DuckDuckGo/RemoteMessaging/TabBarRemoteMessageView.swift @@ -31,44 +31,55 @@ struct TabBarRemoteMessageView: View { let onAppear: () -> Void var body: some View { - HStack { - Text(model.buttonTitle) - .font(.system(size: 13)) - .fixedSize(horizontal: true, vertical: false) - .foregroundColor(.white) + HStack(spacing: 0) { + HStack { + Text(model.buttonTitle) + .font(.system(size: 13)) + .fixedSize(horizontal: true, vertical: false) + .foregroundColor(.white) + } + .padding([.leading, .top, .bottom], 8) + .padding(.trailing, 4) + .cornerRadius(8) + .background(wasViewHovered + ? Color("PrimaryButtonHover") + : Color("PrimaryButtonRest")) + .onTapGesture { onTap(model.surveyURL) } + .onHover { hovering in + wasViewHovered = hovering + + if hovering { + onHover() + } else { + onHoverEnd() + } + } - Button(action: { onClose() }) { + HStack { Image(.close) .resizable() .scaledToFit() .frame(width: 16, height: 16) } - .frame(width: 16, height: 16) - .buttonStyle(PlainButtonStyle()) - .background(wasCloseButtonHovered && !wasViewHovered + .padding([.top, .bottom, .trailing], 8) + .background(wasCloseButtonHovered ? Color("PrimaryButtonHover") : Color("PrimaryButtonRest")) - .cornerRadius(2) + .cornerRadius(8) + .onTapGesture { + onClose() + } .onHover { hovering in wasCloseButtonHovered = hovering } + .frame(maxWidth: .infinity) } - .padding(8) - .background(wasViewHovered + .background(wasCloseButtonHovered || wasViewHovered ? Color("PrimaryButtonHover") : Color("PrimaryButtonRest")) .frame(height: 24) .cornerRadius(8) .onAppear(perform: { onAppear() }) - .onHover { hovering in - wasViewHovered = hovering - - if hovering { - onHover() - } else { - onHoverEnd() - } - } } }