Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/myussufz/react-native-ipay88-sdk

React Native for integrating with iPay88 payment gateway's mobile SDK
https://github.com/myussufz/react-native-ipay88-sdk

android ios ipay88 ipay88-sdk javascript react-native sdk

Last synced: about 1 month ago
JSON representation

React Native for integrating with iPay88 payment gateway's mobile SDK

Awesome Lists containing this project

README

        

# React Native ipay88-sdk

## Getting started

`$ npm install ipay88-sdk --save`

### Mostly automatic installation

`$ react-native link ipay88-sdk`

### Manual installation

#### iOS

1. In XCode, in the project navigator, right click `Libraries` ➜ `Add Files to [your project's name]`
2. Go to `node_modules` ➜ `ipay88-sdk` and add `RNIpay88Sdk.xcodeproj`
3. In XCode, in the project navigator, select your project. Add `libRNIpay88Sdk.a` to your project's `Build Phases` ➜ `Link Binary With Libraries`
4. Run your project (`Cmd+R`)<

#### Android

1. Open up `android/app/src/main/java/[...]/MainActivity.java`

* Add `import com.ipay88.IPay88Package;` to the imports at the top of the file
* Add `new IPay88Package()` to the list returned by the `getPackages()` method

2. Append the following lines to `android/settings.gradle`:
```
include ':ipay88-sdk'
project(':ipay88-sdk').projectDir = new File(rootProject.projectDir, '../node_modules/ipay88-sdk/android')
```
3. Insert the following lines inside the dependencies block in `android/app/build.gradle`:
```
compile project(':ipay88-sdk')
```

## Usage

```javascript
import React, { Component } from "react";
import {
Platform,
StyleSheet,
Button,
Text,
View,
Alert,
ToastAndroid
} from "react-native";
import IPay88, { Pay } from "ipay88-sdk";

export default class App extends Component {
successNotify = data => {
if (Platform.OS === "ios") {
const {
transactionId,
referenceNo,
amount,
remark,
authorizationCode
} = data;

Alert.alert("Message", `Payment authcode is ${authorizationCode}`, {
cancelable: true
});
} else {
ToastAndroid.show(
`Message: Payment authcode is ${authorizationCode}`,
ToastAndroid.LONG
);
}
};

cancelNotify = data => {
const { transactionId, referenceNo, amount, remark, error } = data;

if (Platform.OS === "ios") {
Alert.alert("Message", `${error}`, { cancelable: true });
} else {
ToastAndroid.show(`Message: ${error}`, ToastAndroid.LONG);
}
};

failedNotify = data => {
const { transactionId, referenceNo, amount, remark, error } = data;

if (Platform.OS === "ios") {
Alert.alert("Message", `${error}`, { cancelable: true });
} else {
ToastAndroid.show(`Message: ${error}`, ToastAndroid.LONG);
}
};

pay = () => {
try {
const data = {};
data.paymentId = "2"; // refer to ipay88 docs
data.merchantKey = "{{ merchantKey }}";
data.merchantCode = "{{ merchantCode }}";
data.referenceNo = "1234565";
data.amount = "1.00";
data.currency = "MYR";
data.productDescription = "Payment";
data.userName = "test";
data.userEmail = "[email protected]";
data.userContact = "0123456789";
data.remark = "me";
data.utfLang = "UTF-8";
data.country = "MY";
data.backendUrl = "http://sample.com";
const errs = Pay(data);
if (Object.keys(errs).length > 0) {
console.log(errs);
}
} catch (e) {
console.log(e);
}
};

render() {
return (




);
}
}
```

### Make Payment

// Refer to ipay88 docs for more info

* paymentId // optional
* merchantKey // required
* merchantCode // required
* referenceNo // required
* amount // required
* currency // required
* productDescription // required
* userName // required
* userEmail // required
* userContact // required
* remark // optional
* utfLang // optional
* country // required
* backendUrl // required

### Success Notify

* transactionId
* referenceNo
* amount
* remark
* authorizationCode

### Failed Notify

* transactionId
* referenceNo
* amount
* remark
* error

### Cancel Notify

* transactionId
* referenceNo
* amount
* remark
* error