Skip to content

A library to receive and show notification for Android.

License

Notifications You must be signed in to change notification settings

basalam/notification

Repository files navigation

Basalam Notification

A library to receive and show notiffication for Android.

  • Register or unregister user to your server.
  • Receive Notifictation per 15 minutes.
  • Show notification as soon as received.
  • Handle on notification click.

Download

Add the package dependencies to your build.gradle file:

    dependencies {
       implementation 'com.basalam.notificationmodule:notification:1.0.4'
    }

Add the repository to your build.gradle file:

repositories {
    maven {
            url = uri("https://maven.pkg.github.com/basalam/notification")
            credentials {
                username = "**"
                password = "**"
            }
        }
}

ask for credentials via [email protected]

How to use

Your application class:

@HiltAndroidApp
class App : Application(), Configuration.Provider {

    @Inject
    lateinit var workerFactory: HiltWorkerFactory

    override fun getWorkManagerConfiguration(): Configuration =
        Configuration.Builder()
            .setMinimumLoggingLevel(android.util.Log.INFO)
            .setWorkerFactory(workerFactory)
            .build()
}

add App to manifest:

        android:name=".App"

Your MainActivity class:

        @Inject
        lateinit var notificationCore: NotificationCore

To init library:

        notificationCore.init(application = application, owner = this)

To Create Worker:

        notificationCore.createWorker(
            application,
            token = "token",
            endPoint = "https://example.basalam.com/api/api_v1.0/notifications/",
            deviceId = "test",
            notificationImage = R.drawable.basalam,
            notificationPackageName = "com.basalam.notification",
            notificationClassPackageName = "com.basalam.notification.MainActivity"
        )

To cancel Worker:

        notificationCore.cancelWorker(application)

To register user:

        notificationCore.registerUser(
            token = "token",
            endPoint = "https://example.basalam.com/api/api_v1.0/notifications/register",
            deviceId = "test",
            isCustomerApp = true
        )

To unregister user:

        notificationCore.unregisterUser(
            token = "token",
            endPoint = "https://example.basalam.com/api/api_v1.0/notifications/unregister",
            deviceId = "test",
            isCustomerApp = true
        )

To handle on notification click:

    override fun onResume() {
        super.onResume()
        checkIntent(intent)
    }

    private fun checkIntent(intent: Intent?) {
        intent?.let {
            if (it.hasExtra(NotificationCore.NOTIFICATION_EXTRA)) {
                val endPoint = it.getStringExtra(NotificationCore.NOTIFICATION_CLICK_ENDPOINT)
                val id = it.getStringExtra(NotificationCore.NOTIFICATION_ID)

                if (endPoint != null && id != null) {
                    notificationCore.clickedOnNotification(
                        endPoint = endPoint,
                        token = "token",
                        id = id
                    )
                }
            }
        }
    }

About

A library to receive and show notification for Android.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Languages