You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
132 lines
4.2 KiB
132 lines
4.2 KiB
//
|
|
// LaunchWidgetLiveActivity.swift
|
|
// LaunchWidget
|
|
//
|
|
// Created by Laurent Morvillier on 25/01/2023.
|
|
//
|
|
|
|
import WidgetKit
|
|
import SwiftUI
|
|
import ActivityKit
|
|
|
|
struct LiveActivityView: View {
|
|
|
|
var name: String
|
|
var endDate: Date
|
|
|
|
var body: some View {
|
|
HStack {
|
|
Text(self.name)
|
|
Spacer()
|
|
Text(self.endDate, style: .timer)
|
|
.monospaced()
|
|
}.padding()
|
|
.font(.title)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
struct LaunchWidgetLiveActivity: Widget {
|
|
|
|
var body: some WidgetConfiguration {
|
|
ActivityConfiguration(for: LaunchWidgetAttributes.self) { context in
|
|
|
|
// Lock screen/banner UI goes here
|
|
VStack(alignment: .leading) {
|
|
|
|
if context.attributes.isTimer {
|
|
let range = Date()...context.attributes.date
|
|
Text(timerInterval: range,
|
|
pauseTime: range.lowerBound)
|
|
.font(.title)
|
|
} else {
|
|
Text(context.attributes.date, style: .timer)
|
|
.font(.title)
|
|
}
|
|
Text(context.attributes.name.uppercased())
|
|
.font(.callout)
|
|
|
|
}
|
|
.padding()
|
|
.monospaced()
|
|
.foregroundColor(.white)
|
|
.activitySystemActionForegroundColor(.white)
|
|
} dynamicIsland: { context in
|
|
DynamicIsland {
|
|
// Expanded UI goes here. Compose the expanded UI through
|
|
// various regions, like leading/trailing/center/bottom
|
|
DynamicIslandExpandedRegion(.leading) {
|
|
Text(context.attributes.name.uppercased())
|
|
.monospaced()
|
|
}
|
|
DynamicIslandExpandedRegion(.trailing) {
|
|
Text(context.attributes.date, style: .timer)
|
|
.monospaced()
|
|
}
|
|
DynamicIslandExpandedRegion(.bottom) {
|
|
Button {
|
|
self._stop()
|
|
} label: {
|
|
Text("Stop")
|
|
}
|
|
}
|
|
} compactLeading: {
|
|
Text(context.attributes.name.uppercased())
|
|
} compactTrailing: {
|
|
if context.attributes.isTimer {
|
|
let range = Date()...context.attributes.date
|
|
Text(timerInterval: range,
|
|
pauseTime: range.lowerBound)
|
|
} else {
|
|
Text(context.attributes.date, style: .timer)
|
|
}
|
|
} minimal: {
|
|
if context.attributes.isTimer {
|
|
let range = Date()...context.attributes.date
|
|
Text(timerInterval: range,
|
|
pauseTime: range.lowerBound)
|
|
} else {
|
|
Text(context.attributes.date, style: .timer)
|
|
}
|
|
}
|
|
.widgetURL(URL(string: context.attributes.id))
|
|
.keylineTint(Color.red)
|
|
}
|
|
}
|
|
|
|
fileprivate func _stop() {
|
|
|
|
}
|
|
}
|
|
|
|
struct LaunchWidgetLiveActivity_Previews: PreviewProvider {
|
|
|
|
static let attributes = LaunchWidgetAttributes(
|
|
id: "",
|
|
name: "Tea",
|
|
date: Date().addingTimeInterval(3600.0), isTimer: true)
|
|
|
|
static let contentState = LaunchWidgetAttributes.ContentState(ended: false)
|
|
|
|
static var previews: some View {
|
|
|
|
if #available(iOS 16.2, *) {
|
|
attributes
|
|
.previewContext(contentState, viewKind: .dynamicIsland(.compact))
|
|
.previewDisplayName("Island Compact")
|
|
attributes
|
|
.previewContext(contentState, viewKind: .dynamicIsland(.expanded))
|
|
.previewDisplayName("Island Expanded")
|
|
attributes
|
|
.previewContext(contentState, viewKind: .dynamicIsland(.minimal))
|
|
.previewDisplayName("Minimal")
|
|
attributes
|
|
.previewContext(contentState, viewKind: .content)
|
|
.previewDisplayName("Notification")
|
|
} else {
|
|
Text("no preview available")
|
|
}
|
|
|
|
}
|
|
}
|
|
|