A package for creating iOS Live Activity notification with simple countdown
yarn add @txo/live-activity-countdown-react-native @txo/live-activity-countdown-view-react-native
npx pod-install
- In Xcode:
File
>New...
>Target...
- Choose
Widget Extension
, add a name (e.g.LiveActivityCountdown
) and make sureInclude Live Activity
is enabled - Remove
LiveActivityCountdown.swift
andLiveActivityCountdownLiveActivity.swift
files - Import
LiveActivityCountdownView
and useLiveActivityCountdownLiveActivity
from the package inLiveActivityCountdownBundle.swift
import WidgetKit
import SwiftUI
+ import LiveActivityCountdownView
@main
struct LiveActivityCountdownBundle: WidgetBundle {
var body: some Widget {
- LiveActivityCountdown()
LiveActivityCountdownLiveActivity()
}
}
- Add
LiveActivityCountdownView
as pod to your Widget Extension by adding this code at the end of yourPodfile
target 'LiveActivityCountdownExtension' do
pod 'LiveActivityCountdownView', :path => '../node_modules/@txo/live-activity-countdown-view-react-native'
end
- Add
NSSupportsLiveActivities
key with valueYES
to Info.plist (More info here)
- Add your app logo (or different image) to
Assets.xcassets
under nameAppLogoLiveActivity
in Widget Extension- for multiple images you can use custom names and then specify them in JS with
imageName
attribute
- for multiple images you can use custom names and then specify them in JS with
Code:
import { createLiveActivity } from '@txo/live-activity-countdown-react-native';
createLiveActivity({
title: 'Test title',
timerTitle: 'Remaining time',
buttonTitle: 'Open App',
endDateTime: '2022-12-31T12:00:00.000Z', // Date object can be used too
timerColor: '#cccccc',
})
.then((id: string) => {
// store activity ID somewhere to use it for ending the Live Activity later
})
- When adding image, add lower resolutions - 150px is working fine for the logo (more info here - Understand constraints paragraph)
See the contributing guide to learn how to contribute to the repository and the development workflow.
MIT
Made with create-react-native-library