-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Expand file tree
/
Copy pathTimezoneInfoView.swift
More file actions
60 lines (53 loc) · 1.81 KB
/
Copy pathTimezoneInfoView.swift
File metadata and controls
60 lines (53 loc) · 1.81 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
import SwiftUI
struct TimezoneInfoView: View {
@State private var showingTimezoneInfo = false
@Environment(\.context) private var context
var body: some View {
Button {
showingTimezoneInfo = true
} label: {
HStack(spacing: 8) {
Image(systemName: "location")
.font(.caption2)
Text(formattedTimeZone)
Image(systemName: "info.circle")
.font(.caption)
.foregroundColor(.accentColor)
}
.font(.footnote)
.foregroundColor(.secondary)
}
.buttonStyle(.plain)
.popover(isPresented: $showingTimezoneInfo) {
timezoneInfoContent
}
.dynamicTypeSize(...DynamicTypeSize.xLarge)
}
private var formattedTimeZone: String {
let name = context.timeZone.localizedName(for: .generic, locale: .current)
return name ?? context.timeZone.identifier
}
@ViewBuilder
private var timezoneInfoContent: some View {
VStack(alignment: .leading, spacing: 4) {
Text(Strings.DatePicker.siteTimeZone)
.font(.headline)
.foregroundStyle(.primary)
Text(verbatim: "\(formattedTimeZone) (\(context.formatters.date.formattedTimeOffset))")
.font(.footnote)
.foregroundColor(.secondary)
Text(Strings.DatePicker.siteTimeZoneDescription)
.font(.subheadline)
.foregroundColor(.secondary)
.fixedSize(horizontal: false, vertical: true)
.padding(.top, 12)
}
.padding()
.frame(idealWidth: 280, maxWidth: 320)
.presentationCompactAdaptation(.popover)
}
}
#Preview {
TimezoneInfoView()
.padding()
}