API Reference

Etegram checkout is the easiest way to collect payments on your website: Import our lightweight JavaScript library on your checkout page, then call the payWithEtegram function when the customer clicks your payment button. We'll handle the payment and return to you when it's done. In this guide, we'll walk you through using Etegram checkout on your site.

Here's what the implementation of etegram-pay on a checkout page could look like:

Installation

npm install etegram-pay

if you are using yarn

yarn install etegram-pay

Usage

Basic Example

Here's what implementation of Etegram checkout on a checkout page in React could look like:

import { payWithEtegram } from 'etegram-pay';
import { useForm } from 'react-hook-form';

export default function CheckoutFormSample(

	const {register, handleSubmit} = useForm();

	const onSubmit = async (data) => {
		/* Here you would send the data from your form to the payWithEtegram.*/

   	//You can pass your reference to the function otherwise one will be generated for you

            const dataToSubmit = {
			  projectID: data.projectID,
			  publicKey: data.publicKey,
			  amount: data?.productPrice,
			  email: data.email,
			  phone: data?.phone,
			  firstname: data?.firstName,
			  lastname: data?.lastName,
		}
      		await payWithEtegram(dataToSubmit);
	};
	return (
	     <form onSubmit={handleSubmit(onSubmit)}>
	        <div>
	            <label htmlFor="firstName">FirstName</label>
	            <input {...register("firstName")} />
	        </div>
					<div>
	            <label htmlFor="lastName">FirstName</label>
	            <input {...register("lastName")} />
	        </div>
	        //Rest of your form
	        ...
	
	        <button>Submit</button>
	    </form>
  	)
)

When you use the payWithEtegram function, a checkout window will open, showing the account details and the amount your customer needs to transfer. Once the transfer is complete, and they click the confirmation button, they’ll be redirected to the callback URL you set up in your dashboard.


Parameter

ParameterTypeRequiredDescription
projectIDstringYesThe project ID is in your dashboard. Go to settings -> API & Keys to find it
publicKeystringYesThe API Key is in project dashboard. You can choose either test or live key.
amountnumberYesThe amount you want your customer to pay
emailstringYesYour customer's email
phonestringYesYour customer's phone
firstnamestringYesYour customer's firstname
lastnamestringYesYour customer's lastname
referencestringNoYou can provide a reference otherwise one will be generated for you.

Etegram Pay API

If you prefer to call our API to initialize a transaction, you can start by sending a POST request to our endpoint https://api-checkout.etegram.com/api/transaction/initialize/:projectID.

Example Request

var raw = {
	publicKey:"ksksa9232ds" ,
	amount: 100,
	email: [email protected],
	phone: 080*******,
	firstname: John,
	lastname: Doe,
}

var requestOptions = {
  method: 'POST',
  body: raw,
  redirect: 'follow'
};

fetch("https://api-checkout.etegram.com/api/transaction/initialize/66cc9f4ad602e72ea995b728", requestOptions)
  .then(response => response.text())
  .then(result => console.log(result))
  .catch(error => console.log('error', error));

Example response

{
  "status": true,
  "message": "Authorization URL created",
  "data": {
    "authorization_url": "https://checkout.etegram.com/74ec0351774543da8926deb27bbe19dd",
    "access_code": "74ec0351774543da8926deb27bbe19dd",
    "reference": "tyrhndjhfd"
  }
}

Please direct your customers to the authorization_url to complete their purchase. Once finished, they'll be redirected back to the Callback URL you provided.