pay_with_paymob 1.2.2 copy "pay_with_paymob: ^1.2.2" to clipboard
pay_with_paymob: ^1.2.2 copied to clipboard

A Flutter package for integrating pay_with_paymob services, enabling Visa and mobile wallet payments with customizable UI and secure payment processing.

paymob_payment #

A Flutter package to simplify Paymob gateway integration for Visa and mobile wallet payments.

Features #

  • Easy integration with Paymob's payment system.
  • Support for multiple payment methods: Visa and mobile wallets.
  • Customizable payment view with flexible style options.
  • User data collection for enhanced payment experiences.
  • Callbacks for handling payment success and errors.

Getting Started #

Prerequisites #

  1. Flutter SDK installed on your machine.
  2. A Paymob account to acquire the API key and other necessary credentials.

Installation #

Add the following line to your pubspec.yaml file:

dependencies:  
  pay_with_paymob: ^1.1.2  

Run flutter pub get to install the package.


Usage #

Initializing Payment Data #

Before proceeding with payment, initialize your payment data (in the main function or the initState of your widget):

PaymentData.initialize(
  apiKey: "Your API Key", // Required: Obtain from dashboard -> Settings -> Account Info -> API Key
  iframeId: "Your Iframe ID", // Required: Obtain from Developers -> iframes
  integrationCardId: "Your Card Integration ID", // Required: Obtain from Developers -> Payment Integrations -> Online Card ID
  integrationMobileWalletId: "Your Wallet Integration ID", // Required: Obtain from Developers -> Payment Integrations -> Mobile Wallet ID

  // Optional User Data
  userData: UserData(
    email: "User Email", // Optional: Default is 'NA'
    phone: "User Phone", // Optional: Default is 'NA'
    firstName: "User First Name", // Optional: Default is 'NA'
    lastName: "User Last Name", // Optional: Default is 'NA'
  ),
  
  // Optional Style Customizations
  style: Style(
    primaryColor: Colors.blue, // Default: Colors.blue
    scaffoldColor: Colors.white, // Default: Colors.white
    appBarBackgroundColor: Colors.blue, // Default: Colors.blue
    appBarForegroundColor: Colors.white, // Default: Colors.white
    textStyle: TextStyle(), // Default: TextStyle()
    buttonStyle: ElevatedButton.styleFrom(), // Default: ElevatedButton.styleFrom()
    circleProgressColor: Colors.blue, // Default: Colors.blue
    unselectedColor: Colors.grey, // Default: Colors.grey
    showMobileWalletIcons: true, // Default: true
  ),
);

Once initialized, navigate to the payment view using:

Navigator.push(
  context,
  MaterialPageRoute(
    builder: (context) => PaymentView(
      onPaymentSuccess: () {
        // Handle successful payment
      },
      onPaymentError: () {
        // Handle payment error
      },
      price: 100, // Required: Total price, e.g., 100 means 100 EGP
    ),
  ),
);

Additional Information #

Test Data for Simulation #

Visa Card:

  • Card Number: 5123456789012346
  • Card Holder Name: Test Account
  • Expiry Date: 12/25
  • CVV: 123

Mobile Wallet:

  • Wallet Number: 01010101010
  • MPIN: 123456
  • One-Time Password: 123456

For further details, refer to the documentation.

Contributions #

We welcome contributions! If you encounter issues or have suggestions, feel free to open an issue on GitHub.


This version enhances readability and organization. Let me know if you'd like any further changes!

52
likes
0
points
209
downloads

Publisher

unverified uploader

Weekly Downloads

A Flutter package for integrating pay_with_paymob services, enabling Visa and mobile wallet payments with customizable UI and secure payment processing.

Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

dio, flutter, webview_flutter

More

Packages that depend on pay_with_paymob