Skip to content

sentryco/LocalNotification

Repository files navigation

Tests codebeat badge License: MIT Swift 5.9 Platform iOS Swift Package Manager Compatible

LocalNotification

  • LocalNotification is a Swift package that helps you manage local notifications in your iOS application.
  • Intended to be used as a debug tool for background operations where consol output doesnt work

Note

Can be used in production, but that isn't very usefull since most people will not allow app level notifications by default, to avoid notification spam etc

Features

  • Check and request local notification permissions
  • Display notifications with a title and message using a single method call
  • Schedule notifications with a custom time interval

Usage

Here's an example of how to use the LocalNotification package:

import LocalNotification

// Request notification permission if not already granted
if !LocalNotification.isNotificationAvailable {
    LocalNotification.requestPermission()
}

// Ensure notifications are available
guard LocalNotification.isNotificationAvailable else {
    print("Error: Notifications are not allowed.")
    return
}

// Show a notification directly
LocalNotification.showNotification(
    title: "Feed the cat",
    body: "It looks hungry"
)

// Show a notification with a subtitle
LocalNotification.showNotification(
    title: "Meeting Reminder",
    subTitle: "Team Sync",
    body: "Don't forget about the team sync at 10 AM."
)

// Show a notification with a delay of 10 seconds
LocalNotification.showNotification(
    title: "Take a Break",
    body: "Stretch your legs!",
    timeInterval: 10.0
)

Installation

To install the LocalNotification package, add the following to your Package.swift file.

dependencies: [
    .package(url: "https://github.com/sentryco/LocalNotification", branch: "main")
]

Todo:

  • Error Handling: The method requestPermission() in LocalNotification.swift prints an error directly to the console. It might be more useful to handle errors in a way that allows the calling code to react accordingly, such as by using a completion handler that includes an error parameter.
  • Code Duplication: The showNotification method checks if notifications are available and requests permission if not. This logic could potentially be refactored to avoid redundancy and improve the flow of the code.
  • remove unit tests
  • Workflow Efficiency: The current GitHub Actions workflow in tests.yml is set up for basic build and test operations. Depending on the project's needs, this could be expanded to include additional checks such as linting, code style enforcement, or even automated deployment steps.
  • Documentation and Examples README Improvements: The README.md file provides a basic introduction and usage examples for the LocalNotification package. This could be enhanced with more detailed examples, better structured information, and possibly a FAQ section to help new users integrate the package more easily.

About

⚙️ Debugging background operations

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages