Flutter预付费功能支持插件prepaid_lib_flutter_null_safety的使用
Flutter预付费功能支持插件prepaid_lib_flutter_null_safety的使用
Getting Started
本项目是一个用于Flutter的插件包,该插件包包含针对Android和/或iOS的平台特定实现代码。
对于如何开始使用Flutter,可以查看我们的在线文档,其中包含教程、示例、移动开发指南以及完整的API参考。
示例代码
example/lib/main.dart
import 'dart:convert';
import 'dart:io';
import 'package:flutter/material.dart';
import 'package:intl/intl.dart';
import 'package:prepaid_lib_flutter_null_safety/unik_lib_flutter.dart';
import 'package:unik_lib_flutter_example/screen/TapCard.dart';
void main() {
WidgetsFlutterBinding.ensureInitialized();
runApp(MyApp());
}
class MyApp extends StatelessWidget {
[@override](/user/override)
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: Center(child: NfcScan()),
),
);
}
}
class NfcScan extends StatefulWidget {
[@override](/user/override)
_MyAppState createState() => _MyAppState();
}
class _MyAppState extends State<NfcScan> {
String _balance = "0", _cardNumber = "000000000000000", _status = "Unknown";
String _bgCard = "images/mandiri_bg.png";
bool _isLoading = false;
String? paidAmount;
String _identifier = 'Unknown';
String? _bankName;
bool? isSuccessInit;
List<dynamic>? listHistory;
[@override](/user/override)
void initState() {
super.initState();
initLibrary();
}
void initLibrary() async {
// isSuccessInit = await UnikLibFlutter.initUnikLib(
// "49df5f81d59fae23ec6f542372fc9999" , 1); //prod
isSuccessInit = await UnikLibFlutter.initUnikLib(
"1234567abc", 0); //dev
print("isSuccessInit $isSuccessInit");
}
void getCardInfo() async {
_setStateDefault();
/// optional you can use List<String> varName = List<String>.filled(1, "");
List<String> cardUid = [''];
List<String> cardNumber = [''];
List<String> balance = [''];
List<String> bankName = [''];
List<String> history = [''];
bool isSuccess = await UnikLibFlutter.getCardInfo(
cardUid, cardNumber, balance, bankName,
startPooling: true,
callbackTimeout: (bool isTimeout) => print("timeout $isTimeout"),
errorNfc: (bool nfcIsNotDetected) =>
print("--> errorNfc $nfcIsNotDetected"));
print(
"isSuccess $isSuccess, cardNumber ${cardNumber[0]}, balance ${balance[0]}, bankName ${bankName[0]}");
bool jsonHistory = await UnikLibFlutter.getHistory(history);
if(jsonHistory) {
print("jsonHistory ${history[0]}");
this.setState(() {
listHistory = jsonDecode(history[0]);
});
}
UnikLibFlutter.stopReader(messageSuccess: "Cek saldo berhasil");
_setStateCard(true, cardNumber[0], balance[0], bankName[0]);
// bool historyStatus = await UnikLibFlutter.getHistory(history);
//
// print("History Transaction ${jsonEncode(historyStatus)}");
}
void updateBalance() async {
_setStateDefault();
List<String> status = [''];
List<String> cardNumber = [''];
List<String> balance = [''];
List<String> bankName = [''];
List<String> beforeBalance = [''];
// if (isSuccessInit) {
bool isSuccess = await UnikLibFlutter.updateBalance(status, cardNumber,
balance, bankName, beforeBalance, "085735442829", "developer@mdd.co.id",
callbackState: (String stateOperation) =>
(stateOperation == UnikLibFlutter.WAITING_STATUS)
? UnikLibFlutter.setIosMessage(
"Mohon tunggu, jangan lepaskan kartu")
: print("state operation DONE"),
callbackTimeout: (bool isTimeout) => print("timeout $isTimeout"),
errorNfc: (bool value) => print("error nfc $value"));
print("isSuccess $isSuccess");
print("status update ${status[0]}");
print("cardNumber ${cardNumber[0]}");
this.setState(() {
_status = status[0];
});
if (isSuccess) {
UnikLibFlutter.stopReader(messageSuccess: "Update balance berhasil");
_setStateCard(true, cardNumber[0], balance[0], bankName[0]);
} else {
print("Terjadi kesalahan");
UnikLibFlutter.stopReader(messageError: "Update balance gagal");
_setStateCard(false, cardNumber[0], balance[0], bankName[0]);
// Navigator.of(context).pop();
}
// }
}
void _setStateCard(bool isSuccess, String cardNumber, String balance, String bankName) {
this.setState(() {
_cardNumber = cardNumber;
_balance = balance;
_bgCard =
(bankName == "BNI") ? "images/bni_bg.png" : "images/mandiri_bg.png";
_bankName = bankName;
});
if (Platform.isAndroid) Navigator.pop(context);
}
void _setStateDefault() {
this.setState(() {
_cardNumber = "0000000000000000";
_balance = "0";
_bgCard = "images/mandiri_bg.png";
listHistory = null;
_status = "Unknown";
});
}
Widget listViewBuilder(List<dynamic> list) {
return Container(
height: 300,
child: ListView.builder(
itemBuilder: (context, index) {
return Column(
children: [
Text("amount : ${list[index]["amount"]}"),
Text("date : ${list[index]["date"]}"),
Text("type : ${list[index]["type"]}"),
SizedBox(
height: 10,
)
],
);
},
itemCount: list.length,
),
);
}
[@override](/user/override)
Widget build(BuildContext context) {
void _showBottomSheet(dynamic screen, dynamic height) {
showModalBottomSheet(
isScrollControlled: true,
shape: RoundedRectangleBorder(
borderRadius: new BorderRadius.only(
topLeft: const Radius.circular(25.0),
topRight: const Radius.circular(25.0),
),
),
context: context,
builder: (builder) {
return new Container(
height: MediaQuery.of(context).size.height * height,
color: Colors.transparent,
//could change this to Color(0xFF737373),
//so you don't have to change MaterialApp canvasColor
child: new Container(
child: new Center(
child: screen,
)),
);
});
}
return Scaffold(
body: Container(
height: MediaQuery.of(context).size.height,
width: MediaQuery.of(context).size.width,
child: SingleChildScrollView(
child: Column(
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Container(
width: MediaQuery.of(context).size.width,
height: 200,
decoration: BoxDecoration(
image: DecorationImage(
fit: BoxFit.fill,
image: AssetImage('images/bg_home.png'),
)),
child: Align(
alignment: Alignment(0, 17),
child: Container(
padding: EdgeInsets.only(left: 20, right: 20),
decoration: BoxDecoration(
image: DecorationImage(
fit: BoxFit.fill, image: AssetImage(_bgCard)),
borderRadius: BorderRadius.circular(25),
color: Colors.white,
boxShadow: [
BoxShadow(
color: Colors.grey.withOpacity(0.3),
spreadRadius: 2,
blurRadius: 2,
offset:
Offset(3, 3), // changes position of shadow
),
],
),
width: 322,
height: 190,
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
SizedBox(
height: 70,
),
DefaultTextStyle(
style: TextStyle(color: Colors.black),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(
_cardNumber.replaceAllMapped(
RegExp(r".{4}"),
(match) => "${match.group(0)} "),
style: TextStyle(
color: Colors.white,
fontSize: 18)),
SizedBox(
height: 17,
),
Text("Saldo",
style: TextStyle(
color: Colors.white38,
fontSize: 15)),
SizedBox(
height: 3,
),
Text(
NumberFormat.simpleCurrency(
locale: 'id_ID')
.format(int.parse(_balance)),
style: TextStyle(color: Colors.white)),
],
))
],
)),
),
),
SizedBox(
height: 100,
),
Container(
width: 300,
child: ElevatedButton.icon(
label: Text('Update'),
icon: Icon(Icons.update_rounded),
onPressed: () {
updateBalance();
if (Platform.isAndroid)
_showBottomSheet(TapCard(), 0.50);
},
)),
SizedBox(
height: 30,
),
Align(
alignment: Alignment.center,
child: _isLoading
? CircularProgressIndicator()
: Text(_status),
),
SizedBox(
height: 10,
),
(listHistory != null)
? listViewBuilder(listHistory!)
: SizedBox(
width: 1,
)
],
),
)),
floatingActionButton: FloatingActionButton(
onPressed: () async {
// if (isSuccessInit) {
getCardInfo();
if (Platform.isAndroid) _showBottomSheet(TapCard(), 0.50);
// } else {
// print("Init Failed");
// }
},
child: const Icon(Icons.cached),
backgroundColor: Colors.blue,
),
);
}
}
更多关于Flutter预付费功能支持插件prepaid_lib_flutter_null_safety的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html
更多关于Flutter预付费功能支持插件prepaid_lib_flutter_null_safety的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
prepaid_lib_flutter_null_safety
是一个为 Flutter 应用提供预付费功能支持的插件,特别适用于需要处理预付费卡、优惠券、礼品卡等场景的应用。以下是如何在 Flutter 项目中使用该插件的基本步骤:
1. 添加依赖
首先,在 pubspec.yaml
文件中添加 prepaid_lib_flutter_null_safety
插件依赖:
dependencies:
flutter:
sdk: flutter
prepaid_lib_flutter_null_safety: ^版本号 # 请使用最新版本
然后运行 flutter pub get
以获取依赖。
2. 导入插件
在需要使用预付费功能的 Dart 文件中导入插件:
import 'package:prepaid_lib_flutter_null_safety/prepaid_lib_flutter_null_safety.dart';
3. 初始化插件
在使用插件之前,通常需要初始化它。初始化可能需要一些配置参数,具体取决于插件的实现。
void main() async {
WidgetsFlutterBinding.ensureInitialized();
// 初始化预付费插件
await PrepaidLibFlutterNullSafety.initialize(
apiKey: 'your_api_key',
environment: Environment.sandbox, // 或 Environment.production
);
runApp(MyApp());
}
4. 使用插件功能
prepaid_lib_flutter_null_safety
插件通常提供多种功能,例如创建预付费卡、查询余额、使用预付费卡支付等。以下是一些常见操作的示例:
创建预付费卡
void createPrepaidCard() async {
try {
PrepaidCard card = await PrepaidLibFlutterNullSafety.createPrepaidCard(
amount: 100.0,
currency: 'USD',
);
print('Prepaid card created: ${card.id}');
} catch (e) {
print('Failed to create prepaid card: $e');
}
}
查询余额
void checkBalance(String cardId) async {
try {
double balance = await PrepaidLibFlutterNullSafety.checkBalance(cardId);
print('Balance: $balance');
} catch (e) {
print('Failed to check balance: $e');
}
}
使用预付费卡支付
void makePayment(String cardId, double amount) async {
try {
bool success = await PrepaidLibFlutterNullSafety.makePayment(
cardId: cardId,
amount: amount,
);
if (success) {
print('Payment successful');
} else {
print('Payment failed');
}
} catch (e) {
print('Failed to make payment: $e');
}
}