PaystackWebView class
A full-screen widget that opens a WebView
to handle Paystack checkout.
This widget loads a small HTML page that invokes the Paystack inline JavaScript SDK. Once the user completes or cancels payment, the result is sent back to Flutter over a JavaScript channel, and this page will Navigator.pop with a result map.
Example
final result = await Navigator.push(
context,
MaterialPageRoute(
builder: (_) => PaystackWebView(
publicKey: 'pk_test_12345',
amountSmallestUnit: 150000, // ₦1,500 in kobo
currency: 'NGN',
email: 'customer@example.com',
reference: 'order-123',
),
),
);
if (result['status'] == 'success') {
debugPrint('Payment ref: ${result['reference']}');
} else if (result['status'] == 'cancelled') {
debugPrint('User closed the checkout.');
}
- Inheritance
-
- Object
- DiagnosticableTree
- Widget
- StatefulWidget
- PaystackWebView
Constructors
Properties
- amountSmallestUnit → int
-
Amount to charge in the smallest unit (e.g., kobo).
final
- currency → String
-
ISO currency code for the charge (e.g.,
"NGN"
,"USD"
).final - email → String
-
Customer email to associate with the charge.
final
- hashCode → int
-
The hash code for this object.
no setterinherited
- key → Key?
-
Controls how one widget replaces another widget in the tree.
finalinherited
- publicKey → String
-
Paystack public key (
pk_test_...
).final - reference → String
-
Unique reference string for this transaction.
final
- runtimeType → Type
-
A representation of the runtime type of the object.
no setterinherited
- title → String
-
Title displayed in the CustomAppBar.
final
Methods
-
createElement(
) → StatefulElement -
Creates a StatefulElement to manage this widget's location in the tree.
inherited
-
createState(
) → State< PaystackWebView> -
Creates the mutable state for this widget at a given location in the tree.
override
-
debugDescribeChildren(
) → List< DiagnosticsNode> -
Returns a list of DiagnosticsNode objects describing this node's
children.
inherited
-
debugFillProperties(
DiagnosticPropertiesBuilder properties) → void -
Add additional properties associated with the node.
inherited
-
noSuchMethod(
Invocation invocation) → dynamic -
Invoked when a nonexistent method or property is accessed.
inherited
-
toDiagnosticsNode(
{String? name, DiagnosticsTreeStyle? style}) → DiagnosticsNode -
Returns a debug representation of the object that is used by debugging
tools and by DiagnosticsNode.toStringDeep.
inherited
-
toString(
{DiagnosticLevel minLevel = DiagnosticLevel.info}) → String -
A string representation of this object.
inherited
-
toStringDeep(
{String prefixLineOne = '', String? prefixOtherLines, DiagnosticLevel minLevel = DiagnosticLevel.debug, int wrapWidth = 65}) → String -
Returns a string representation of this node and its descendants.
inherited
-
toStringShallow(
{String joiner = ', ', DiagnosticLevel minLevel = DiagnosticLevel.debug}) → String -
Returns a one-line detailed description of the object.
inherited
-
toStringShort(
) → String -
A short, textual description of this widget.
inherited
Operators
-
operator ==(
Object other) → bool -
The equality operator.
inherited