4.0.6 • Published 9 months ago

qplus-app-react-native-paystack-webview v4.0.6

Weekly downloads
-
License
MIT
Repository
-
Last release
9 months ago

React Native Paystack WebView

All Contributors PRs Welcome

The package allows you accept payment using paystack, install, add keys and use. No stress :)

Installation

Add React-Native-Paystack-WebView to your project by running;

npm install react-native-paystack-webview

or

yarn add react-native-paystack-webview

One more thing

To frontload the installation work, let's also install and configure dependencies used by this project, being react-native-webview

run

yarn add react-native-webview

for iOS: cd iOS && pod install && cd ..

for expo applications run;

expo install react-native-webview

and that's it, you're all good to go!

Usage 1

import React from 'react';
import  { Paystack }  from 'react-native-paystack-webview';
import { View } from 'react-native';

function Pay() {
  return (
    <View style={{ flex: 1 }}>
      <Paystack  
        paystackKey="your-public-key-here"
        amount={'25000.00'}
        billingEmail="paystackwebview@something.com"
        activityIndicatorColor="green"
        onCancel={(e) => {
          // handle response here
        }}
        onSuccess={(res) => {
          // handle response here
        }}
        autoStart={true}
      />
    </View>
  );
}

Usage 2 - Using Refs

Make use of a ref to start transaction. See example below;

import React, { useRef } from 'react';
import  { Paystack , paystackProps}  from 'react-native-paystack-webview';
import { View, TouchableOpacity,Text } from 'react-native';

function Pay(){
  const paystackWebViewRef = useRef<paystackProps.PayStackRef>(); 

  return (
    <View style={{flex: 1}}>
      <Paystack
        paystackKey="your-public-key-here"
        billingEmail="paystackwebview@something.com"
        amount={'25000.00'}
        onCancel={(e) => {
          // handle response here
        }}
        onSuccess={(res) => {
          // handle response here
        }}
        ref={paystackWebViewRef}
      />

        <TouchableOpacity onPress={()=> paystackWebViewRef.current.startTransaction()}>
          <Text>Pay Now</Text>
        </TouchableOpacity>
      </View>
  );
}

API's

all React-Native-Paystack-WebView API

Nameuse/descriptionextra
paystackKeyPublic or Private paystack key(visit paystack.com to get yours)nill
amountAmount to be paidnill
activityIndicatorColorcolor of loaderdefault: green
billingEmail(required by paystack)Billers emaildefault: nill
billingMobileBillers mobiledefault: nill
billingNameBillers Namedefault: nill
channelsSpecify payment options available to users. Available channel options are: "card", "bank", "ussd", "qr", "mobile_money". Here's an example of usage: channels={["card","ussd"]}default: ["card"]
onCancelcallback function if user cancels or payment transaction could not be verified. In a case of not being verified, transactionRef number is also returned in the callbackdefault: nill
onSuccesscallback function if transaction was successful and verified (it will also return the transactionRef number in the callback )default: nill
autoStartAuto start payment once page is openeddefault: false
refNumberReference number, if you have already generated onedefault: ''+Math.floor((Math.random() * 1000000000) + 1)
handleWebViewMessageWill be called when a WebView receives a messagedefault: true

Contributions

Want to help make this package even more awesome? Read how to contribute and feel free to send in your PR!

Licensing

This project is licensed under MIT license.

Related Projects

Video Tutorial

Don't forget to star, like and share :)

Contributors ✨

Thanks goes to these wonderful people (emoji key):

This project follows the all-contributors specification. Contributions of any kind welcome!

Roadmap

we have a lot to get done before we hit stable, here's a list;

  • Make the reference usage more user friendly
  • Since you want it to conform to InlineJS, let the variable names also match
  • Let the parameter types also conform to InlineJS parameter types
  • Paystack is a word, hence when used as a package name/class name, let it use PascalCase (Paystack) and when used as a variable, camelCase (paystack)
4.0.6

9 months ago

4.0.5

9 months ago

4.0.4

9 months ago