import { HStack, Image, Spacer, Text } from "@expo/ui/swift-ui"; import { font, foregroundStyle, lineLimit, minimumScaleFactor, monospacedDigit, padding, widgetAccentedRenderingMode, } from "@expo/ui/swift-ui/modifiers"; import { createLiveActivity, type LiveActivityEnvironment } from "expo-widgets"; import type { TimeClockActivityProps } from "@/lib/time-clock-live-activity.types"; function TimeClockActivity(props: TimeClockActivityProps, _environment: LiveActivityEnvironment) { "widget"; const green = "green"; const title = props.description.trim() || "Clock In"; const clientLabel = props.clientName.trim() || title; const subtitle = props.invoiceLabel.trim(); const timerMods = [ font({ design: "monospaced", weight: "bold", size: 20 }), monospacedDigit(), foregroundStyle(green), lineLimit(1), minimumScaleFactor(0.85), ]; const compactTimerMods = [ font({ design: "monospaced", weight: "semibold", size: 11 }), monospacedDigit(), foregroundStyle(green), lineLimit(1), minimumScaleFactor(0.8), ]; const clientMods = [ font({ weight: "semibold", size: 13 }), foregroundStyle({ type: "hierarchical", style: "primary" }), lineLimit(1), minimumScaleFactor(0.85), ]; const subtitleMods = [ font({ size: 11 }), foregroundStyle({ type: "hierarchical", style: "secondary" }), lineLimit(1), minimumScaleFactor(0.85), ]; return { banner: ( {clientLabel} {props.elapsedShort} ), bannerSmall: ( {clientLabel} {props.elapsedShort} ), compactLeading: ( ), compactTrailing: {props.elapsedShort}, minimal: ( ), expandedLeading: ( ), expandedCenter: {clientLabel}, expandedTrailing: {props.elapsedShort}, expandedBottom: ( {subtitle || "beenvoice"} ), }; } export default createLiveActivity("TimeClockActivity", TimeClockActivity);