lianja / Razorpay APIs / Implement Thematic Changes in Checkout
Back to Collection Items
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
loHttp = createobject("CkHttp")
loHttp.BasicAuth = .T.
loHttp.Login = "username"
loHttp.Password = "password"
// Use this online tool to generate code from sample JSON: Generate Code to Create JSON
// The following JSON is sent in the request body.
// {
// "amount": 1000,
// "currency": "INR",
// "accept_partial": true,
// "first_min_partial_amount": 100,
// "reference_id": "#423212",
// "description": "Payment for policy no #23456",
// "customer": {
// "name": "Gaurav Kumar",
// "contact": "+919999999999",
// "email": "gaurav.kumar@example.com"
// },
// "notify": {
// "sms": true,
// "email": true
// },
// "reminder_enable": true,
// "options": {
// "checkout": {
// "theme": {
// "hide_topbar": true
// }
// }
// }
// }
loJson = createobject("CkJsonObject")
loJson.UpdateInt("amount",1000)
loJson.UpdateString("currency","INR")
loJson.UpdateBool("accept_partial",.T.)
loJson.UpdateInt("first_min_partial_amount",100)
loJson.UpdateString("reference_id","#423212")
loJson.UpdateString("description","Payment for policy no #23456")
loJson.UpdateString("customer.name","Gaurav Kumar")
loJson.UpdateString("customer.contact","+919999999999")
loJson.UpdateString("customer.email","gaurav.kumar@example.com")
loJson.UpdateBool("notify.sms",.T.)
loJson.UpdateBool("notify.email",.T.)
loJson.UpdateBool("reminder_enable",.T.)
loJson.UpdateBool("options.checkout.theme.hide_topbar",.T.)
loResp = loHttp.PostJson3("https://api.razorpay.com/v1/payment_links","application/json",loJson)
if (loHttp.LastMethodSuccess = .F.) then
? loHttp.LastErrorText
release loHttp
release loJson
return
endif
? str(loResp.StatusCode)
? loResp.BodyStr
release loResp
release loHttp
release loJson
Curl Command
curl -X POST
-u 'username:password'
-d '{
"amount": 1000,
"currency": "INR",
"accept_partial": true,
"first_min_partial_amount": 100,
"reference_id": "#423212",
"description": "Payment for policy no #23456",
"customer": {
"name": "Gaurav Kumar",
"contact": "+919999999999",
"email": "gaurav.kumar@example.com"
},
"notify": {
"sms": true,
"email": true
},
"reminder_enable": true,
"options": {
"checkout": {
"theme": {
"hide_topbar": true
}
}
}
}'
https://api.razorpay.com/v1/payment_links
Postman Collection Item JSON
{
"name": "Implement Thematic Changes in Checkout",
"request": {
"method": "POST",
"header": [
],
"body": {
"mode": "raw",
"raw": "{\n \"amount\": 1000,\n \"currency\": \"INR\",\n \"accept_partial\": true,\n \"first_min_partial_amount\": 100,\n \"reference_id\": \"#423212\",\n \"description\": \"Payment for policy no #23456\",\n \"customer\": {\n \"name\": \"Gaurav Kumar\",\n \"contact\": \"+919999999999\",\n \"email\": \"gaurav.kumar@example.com\"\n },\n \"notify\": {\n \"sms\": true,\n \"email\": true\n },\n \"reminder_enable\": true,\n \"options\": {\n \"checkout\": {\n \"theme\": {\n \"hide_topbar\": true\n }\n }\n }\n}",
"options": {
"raw": {
"language": "json"
}
}
},
"url": {
"raw": "https://api.razorpay.com/v1/payment_links",
"protocol": "https",
"host": [
"api",
"razorpay",
"com"
],
"path": [
"v1",
"payment_links"
]
},
"description": "You can modify the top bar theme element of the Checkout UI on the payment request page to restrict customers from navigating to the initial screen of Checkout and selecting a different payment method. Know more about <a href=\"https://razorpay.com/docs/api/payment-links/customise/checkout-theme/\" target=\"_blank\">this API</a>."
},
"response": [
]
}