Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nathanfallet/unlockpremium
A package to include a standard "Unlock premium" view in iOS and Android apps
https://github.com/nathanfallet/unlockpremium
android iap kotlin kotlin-library spm swift
Last synced: 3 days ago
JSON representation
A package to include a standard "Unlock premium" view in iOS and Android apps
- Host: GitHub
- URL: https://github.com/nathanfallet/unlockpremium
- Owner: nathanfallet
- License: gpl-3.0
- Created: 2022-04-15T07:57:20.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2023-05-08T17:32:06.000Z (almost 2 years ago)
- Last Synced: 2025-02-03T19:24:26.749Z (18 days ago)
- Topics: android, iap, kotlin, kotlin-library, spm, swift
- Language: Kotlin
- Homepage:
- Size: 145 KB
- Stars: 6
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# UnlockPremium
[data:image/s3,"s3://crabby-images/62b6b/62b6b07097a68ae83e42c5f80c9ed8ae72835597" alt="License"](LICENSE)
[data:image/s3,"s3://crabby-images/92311/92311d67d5a53396f84a516d96cdeb0e2b4ff17e" alt="Issues"]()
[data:image/s3,"s3://crabby-images/3a426/3a42628095b0e3b83a4264a04e1cd2dec5194f2f" alt="Pull Requests"]()
[data:image/s3,"s3://crabby-images/0948e/0948e0429040a5734e6a16728d05ec085c2d2aad" alt="Code Size"]()
[data:image/s3,"s3://crabby-images/1dbb8/1dbb853ccaba184513d0026f430fffa96dd51b35" alt="Translation status"](http://weblate.groupe-minaste.org/engage/unlockpremium/?utm_source=widget)## Installation
### iOS
Add `https://github.com/NathanFallet/UnlockPremium.git` to your Swift Package configuration (or using the Xcode menu: `File` > `Swift Packages` > `Add Package Dependency`)
Don't forget to add the `In-App Purchase` capability to your app (in `Signing & Capabilities`). This should automatically add the `StoreKit` framework to your app as well.
### Android
Add the following to your `build.gradle` file:
```groovy
repositories {
mavenCentral()
}dependencies {
implementation 'me.nathanfallet.unlockpremium:unlockpremium:1.0.0'
}
```## Usage
### iOS
Setup a configuration for the unlock view:
```swift
import UnlockPremiumextension UnlockPremiumConfig {
static func config() -> UnlockPremiumConfig {
return UnlockPremiumConfig(
arguments: [
PremiumArgument(
title: "A feature name",
description: "A feature description",
icon: "app.fill"
),
// ...
],
productIdentifier: "myAppSKU.premiumPurchase", // In-App Purchase `Product ID`
completionHandler: {
// Set your user as premium, for example:
UserService.shared.setUserPremium(to: true)
}
)
}}
```The `completionHandler` is the method called when the purchase completes successfully.
Then, show the view where you want:
```swift
.sheet(isPresented: $viewModel.showPremium) {
UnlockPremiumView(configuration: .config(), isPresented: $viewModel.showPremium)
}
```### Android
Setup a configuration for the unlock view:
```kotlin
val config = UnlockPremiumConfig(
listOf(
PremiumArgument(
"A feature name",
"A feature description",
R.drawable.ic_baseline_apps_24
),
// ...
),
"myAppSKU.premiumPurchase"
)
```Create a request, and handle the response
```kotlin
private val unlockPremiumRequest = registerForActivityResult(ActivityResultContracts.StartActivityForResult()) { it ->
it.data?.getBooleanExtra(UnlockPremiumActivity.EXTRAS.SUCCESS, false)?.let { success ->
if (success) {
// Set your user as premium, for example:
UserService.getInstance(getApplication()).setUserPremium(true)
}
}
}
```Then, show the view where you want:
```kotlin
val intent = Intent(this, UnlockPremiumActivity::class.java)
intent.putExtra(UnlockPremiumActivity.EXTRAS.CONFIGURATION, config)
unlockPremiumRequest.launch(intent)
```