// // medicineLiveActivity.swift // medicine // // Created by richard on 2025/11/13. // import ActivityKit import WidgetKit import SwiftUI struct medicineAttributes: ActivityAttributes { public struct ContentState: Codable, Hashable { // Dynamic stateful properties about your activity go here! var emoji: String } // Fixed non-changing properties about your activity go here! var name: String } struct medicineLiveActivity: Widget { var body: some WidgetConfiguration { ActivityConfiguration(for: medicineAttributes.self) { context in // Lock screen/banner UI goes here VStack { Text("Hello \(context.state.emoji)") } .activityBackgroundTint(Color.cyan) .activitySystemActionForegroundColor(Color.black) } dynamicIsland: { context in DynamicIsland { // Expanded UI goes here. Compose the expanded UI through // various regions, like leading/trailing/center/bottom DynamicIslandExpandedRegion(.leading) { Text("Leading") } DynamicIslandExpandedRegion(.trailing) { Text("Trailing") } DynamicIslandExpandedRegion(.bottom) { Text("Bottom \(context.state.emoji)") // more content } } compactLeading: { Text("L") } compactTrailing: { Text("T \(context.state.emoji)") } minimal: { Text(context.state.emoji) } .widgetURL(URL(string: "http://www.apple.com")) .keylineTint(Color.red) } } } extension medicineAttributes { fileprivate static var preview: medicineAttributes { medicineAttributes(name: "World") } } extension medicineAttributes.ContentState { fileprivate static var smiley: medicineAttributes.ContentState { medicineAttributes.ContentState(emoji: "😀") } fileprivate static var starEyes: medicineAttributes.ContentState { medicineAttributes.ContentState(emoji: "🤩") } } #Preview("Notification", as: .content, using: medicineAttributes.preview) { medicineLiveActivity() } contentStates: { medicineAttributes.ContentState.smiley medicineAttributes.ContentState.starEyes }