2025-10-17 09:13:08 +05:45

85 lines
2.8 KiB
Swift

import SwiftUI
/// A reusable info tip component that displays helpful information in a popover
struct InfoTip: View {
// Content configuration
var title: String
var message: String
var learnMoreLink: URL?
var learnMoreText: String = "Learn More"
// Appearance customization
var iconName: String = "info.circle.fill"
var iconSize: Image.Scale = .medium
var iconColor: Color = .primary
var width: CGFloat = 300
// State
@State private var isShowingTip: Bool = false
var body: some View {
Image(systemName: iconName)
.imageScale(iconSize)
.foregroundColor(iconColor)
.fontWeight(.semibold)
.padding(5)
.contentShape(Rectangle())
.popover(isPresented: $isShowingTip) {
VStack(alignment: .leading, spacing: 12) {
Text(title)
.font(.headline)
.foregroundColor(.primary)
Text(message)
.font(.body)
.foregroundColor(.secondary)
.fixedSize(horizontal: false, vertical: true)
.frame(width: width, alignment: .leading)
if let url = learnMoreLink {
Link(destination: url) {
HStack(spacing: 4) {
Text(learnMoreText)
.font(.caption)
.fontWeight(.medium)
Image(systemName: "arrow.up.forward")
.font(.caption2)
}
.foregroundColor(.white)
.padding(.horizontal, 10)
.padding(.vertical, 6)
.background(
RoundedRectangle(cornerRadius: 6)
.fill(Color.accentColor)
)
}
.buttonStyle(.plain)
.padding(.top, 8)
}
}
.padding(16)
}
.onTapGesture {
isShowingTip.toggle()
}
}
}
// MARK: - Convenience initializers
extension InfoTip {
/// Creates an InfoTip with just title and message
init(title: String, message: String) {
self.title = title
self.message = message
self.learnMoreLink = nil
}
/// Creates an InfoTip with a learn more link
init(title: String, message: String, learnMoreURL: String) {
self.title = title
self.message = message
self.learnMoreLink = URL(string: learnMoreURL)
}
}