@kkiapay-org/react-native-sdk
v0.1.5
Published
React Native SDK for KKiaPay easy integration
Downloads
65
Readme
@kkiapay-org/react-native-sdk
React Native SDK for KKiaPay integration
Installation
npx expo install react-native-webview
npm install @kkiapay-org/react-native-sdk
Usage
- Import KKiaPay provider to access all context's features
// In your app file -- App
import { KkiapayProvider } from '@kkiapay-org/react-native-sdk';
import TestComponent from './TestComponent';
export default function App() {
return (
<KkiapayProvider>
<TestComponent />
</KkiapayProvider>
);
}
- Use the useKkiapay hook and get all available functions
// In your component -- TestComponent
import { Button, StyleSheet, View } from 'react-native';
import { useKkiapay } from '@kkiapay-org/react-native-sdk';
export default function TestComponent() {
const { openKkiapayWidget } = useKkiapay();
const openWidget = () => {
openKkiapayWidget({
amount: 100,
key: 'xxxxxxxxxxxxxxxxxxxxxxxxx',
sandbox: true,
reason: 'Payment',
});
};
return (
<View style={styles.container}>
<Button title="Pay now" onPress={openWidget} />
</View>
);
}
const styles = StyleSheet.create({
container: {
flex: 1,
alignItems: 'center',
justifyContent: 'center',
},
box: {
width: 60,
height: 60,
marginVertical: 20,
},
});
// Types
type VoidFunction = () => void;
type VoidCallback = (cb: VoidFunction) => void;
type DefaultEvent = { name: string; data: any };
type DefaultEventListener = (x: { name: string; data: any }) => void;
interface IData {
amount: number;
theme?: string;
countries?: string[];
paymentMethods?: string[];
paymentmethod?: string[];
fullname?: string;
name?: string;
email?: string;
phone?: string;
sandbox?: boolean;
position?: string;
key?: string;
data?: string;
api_key?: string;
publicAPIKey?: string;
callback?: string;
url?: string;
direct?: string;
split?: string;
partnerId?: string;
reason: string;
}
interface ListenerData {
transactionId: string;
flwRef?: string;
}
enum ListenerEventName {
NETWORK_STATE_CHANGED = 'NETWORK_STATE_CHANGED',
INIT_WIDGET = 'INIT_WIDGET',
WIDGET_SUCCESSFULLY_INIT = 'WIDGET_SUCCESSFULLY_INIT',
CLOSE_WIDGET = 'CLOSE_WIDGET',
DESTROY_WIDGET = 'DESTROY_WIDGET',
WIDGET_SUCCESSFULLY_DESTROYED = 'WIDGET_SUCCESSFULLY_DESTROYED',
PAYMENT_INIT = 'PAYMENT_INIT',
PAYMENT_ABORTED = 'PAYMENT_ABORTED',
PENDING_PAYMENT = 'PENDING_PAYMENT',
ON_USER_FEEDBACK = 'ON_USER_FEEDBACK',
PAYMENT_FAILED = 'PAYMENT_FAILED',
PAYMENT_SUCCESS = 'PAYMENT_SUCCESS',
PAYMENT_END = 'PAYMENT_END',
RETRY_PAYMENT = 'RETRY_PAYMENT',
}
interface ILibrary {
openKkiapayWidget: (configs: IData) => void;
closeKkiapayWidget: () => void;
addSuccessListener: (cb: (data?: any) => void) => void;
addWidgetInitListener: VoidCallback;
addKkiapayCloseListener: VoidCallback;
addWidgetDestroyedListener: VoidCallback;
addPaymentInitListener: VoidCallback;
addPaymentAbortedListener: VoidCallback;
addFeedbackListener: VoidCallback;
addPendingListener: VoidCallback;
addFailedListener: (cb: (data?: any) => void) => void;
addPaymentEndListener: VoidCallback;
removeKkiapayListener: (event: 'success' | 'failed') => void;
addKkiapayListener: (
event: 'success' | 'failed',
cb: (data?: any) => void
) => void;
onNetworkStateChanged: VoidCallback;
}
Contributing
See the contributing guide to learn how to contribute to the repository and the development workflow.
License
MIT
Made with create-react-native-library