handlePageResult

The handlePageResult API is called by the super app to send the processing result from the React Native page back to the SDK.

Method signature

copy
function handlePageResult(
  traceId: string,
  pageResult: Object,
  extra?: {
    success?: (success: BaseSuccess) => void;
    error?: (error: BaseError) => void;
  }
)

Request parameters

Field

Data type

Required

Description

traceId

string

Yes

The unique ID that is assigned by the SDK to identify a specific method call. This parameter correlates the processing result with the request. Obtain its value from the object that the SDK passes to the React Native page upon opening.

pageResult

Object

Yes

An object that contains the processing result from the React Native page. Construct the object by conforming to one of the following data models depending on the method that triggers the page:

  • PaymentResult for the PaymentService.pay method.
  • ScannerResult for the CodeService.scan method.
  • OAuthPageConfirmResult for the OAuthService.showAuthPage method. This model extends BaseServiceResult and does not have self-declared parameters.

extra

Object

No

An extended attribute that is used to provide additional information if necessary. The included parameters are:

  • error: OptionalThe callback that is executed upon failure to send the processing result. When executed, it receives an instance of BaseError object. Specify this parameter if you need to handle the encountered errors.
  • success: OptionalThe callback that is executed upon successfully sending the processing result. When executed, it receives an instance of BaseSuccess object. Specify this parameter if you need to handle successful operations.

Response parameters

N/A

Result codes

Result code

Result message

Further action

1000

SUCCESS

The SDK opens the mini program successfully.

N/A

2000

The result message varies depending on the error that occurs.

The SDK encounters an error when attempting to open the mini program.

Refer to the result message for specific actions.

Sample

copy
import React from 'react';
import {
  StyleSheet,
  Text,
  View,
  SafeAreaView,
  StatusBar,
  Button,
} from 'react-native';
import { Component, useState, useEffect, useContext } from 'react';
import Toast from 'react-native-root-toast';
import { handlePageResult, openApp } from 'iapminiprogram-rn';
import type {
  PaymentResult,
  BaseSuccess,
  BaseError,
  APIContext,
  PaymentRequest,
  ParsePay,
} from 'iapminiprogram-rn';
import { PAYMENT_CODE } from 'iapminiprogram-rn';
function Pay(initialProps: ParsePay) {
  return (
    <SafeAreaView style={styles.container}>
      <Text style={styles.titleText}>Pay</Text>
      <View style={styles.divider} />
      <Button
        title="Pay Success"
        onPress={() =>
          handlePayOperate(PAYMENT_CODE.CODE_SUCCESS, 'Pay Success')
        }
        color="#841584"
      />
      <View style={styles.divider} />
      <Button
        title="Pay fail"
        onPress={() => handlePayOperate(PAYMENT_CODE.CODE_FAILURE, 'Pay fail')}
        color="#841584"
      />
      <View style={styles.divider} />
      <Button
        title="Pending Pay"
        onPress={() =>
          handlePayOperate(PAYMENT_CODE.CODE_PENDING, 'Pending Pay')
        }
        color="#841584"
      />
      <View style={styles.divider} />
      <Button
        title="Cancel Pay"
        onPress={() =>
          handlePayOperate(PAYMENT_CODE.CODE_USER_CANCEL, 'Cancel Pay')
        }
        color="#841584"
      />
      <View style={styles.divider} />
      <Button
        title="Pay Off"
        onPress={() => handlePayOperate('', '')}
        color="#841584"
      />
      <View style={styles.divider} />
      <Button title="Open MiniProgram" onPress={openMiniApp} color="#841584" />
    </SafeAreaView>
  );

  function handlePayOperate(resultCode: string, resultMessage: string) {
    var result: PaymentResult = {
      resultCode: resultCode,
      resultMessage: resultMessage,
    };
    handlePageResult(initialProps.traceId, result, {
      success: (success: BaseSuccess) => {
        Toast.show('success:' + success.msg);
      },
      error: (error: BaseError) => {
        Toast.show('error:' + error.errorMsg);
      },
    });
  }
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    paddingTop: StatusBar.currentHeight,
    marginHorizontal: 16,
  },
  titleText: {
    fontSize: 20,
    fontWeight: 'bold',
  },
  divider: {
    height: 20,
  },
  title: {
    fontSize: 24,
  },
});

export default Pay;