Flutter Midtrans Payment Plugin
Please Read Midtrans Documentation before use this library and make sure you are already has Midtrans account for accessing the dashboard.
Only support AndroidX and compile targe minimum 28
Add style to your android/app/src/main/res/values/styles.xml :
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<item name="windowActionBar">false</item>
<item name="windowNoTitle">true</item>
</style>
And full styles.xml will be like below :
<?xml version="1.0" encoding="utf-8"?>
<resources>
<style name="LaunchTheme" parent="@android:style/Theme.Black.NoTitleBar">
<!-- Show a splash screen on the activity. Automatically removed when
Flutter draws its first frame -->
<item name="android:windowBackground">@drawable/launch_background</item>
</style>
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<item name="windowActionBar">false</item>
<item name="windowNoTitle">true</item>
</style>
</resources>
And add the style to you Android Manifest in your application tag :
android:theme="@style/AppTheme"
No specific setup required
Make sure you are already prepare these variables.
YOUR_CLIENT_ID
: Midtrans CLIENT IDYOUR_URL_BASE
: Your backend URL base API to process payment
import 'package:flutrans/flutrans.dart';
...
final flutrans = Flutrans();
//Init the client ID you URL base
flutrans.init("YOUR_CLIENT_ID", "YOUR_URL_BASE");
//Setup the callback when payment finished
flutrans.setFinishCallback((finished) {
//finished is TransactionFinished
});
//Make payment
flutrans
.makePayment(
MidtransTransaction(
7500,
MidtransCustomer(
"Apin", "Prastya", "[email protected]", "08123456789"),
[
MidtransItem(
"5c18ea1256f67560cb6a00cdde3c3c7a81026c29",
7500,
2,
"USB FlashDisk",
)
],
skipCustomer: true,
customField1: "ANYCUSTOMFIELD"),
)
.catchError((err) => print("ERROR $err"));