Chilkat Online Tools

PowerBuilder / PandaDoc API Reference / Create Document from PandaDoc Template (Full API Sample Document from PandaDoc Template)

Back to Collection Items

integer li_rc
oleobject loo_Http
integer li_Success
oleobject loo_Json
oleobject loo_Resp

// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

loo_Http = create oleobject
// Use "Chilkat_9_5_0.Http" for versions of Chilkat < 10.0.0
li_rc = loo_Http.ConnectToNewObject("Chilkat.Http")
if li_rc < 0 then
    destroy loo_Http
    MessageBox("Error","Connecting to COM object failed")
    return
end if

// Use this online tool to generate code from sample JSON: Generate Code to Create JSON

// The following JSON is sent in the request body.

// {
//   "name": "Full API Sample Document from PandaDoc Template",
//   "template_uuid": "{{template_id}}",
//   "owner": {
//     "membership_id": "{{membership_id}}"
//   },
//   "recipients": [
//     {
//       "email": "{{recipient_email}}",
//       "first_name": "Josh",
//       "last_name": "Ron",
//       "role": "user",
//       "signing_order": 1
//     }
//   ],
//   "tokens": [
//     {
//       "name": "Favorite.Pet",
//       "value": "Panda"
//     }
//   ],
//   "fields": {
//     "Favorite.Color": {
//       "value": "PandaDoc green"
//     },
//     "Delivery": {
//       "value": "Same Day Delivery"
//     },
//     "Like": {
//       "value": true
//     },
//     "Date": {
//       "value": "2019-12-31T00:00:00.000Z"
//     }
//   },
//   "metadata": {
//     "my_favorite_pet": "Panda"
//   },
//   "tags": [
//     "created_via_api",
//     "test_document"
//   ],
//   "images": [
//     {
//       "name": "Image 1",
//       "urls": [
//         "https://s3.amazonaws.com/pd-static-content/public-docs/pandadoc-panda-bear.png"
//       ]
//     }
//   ],
//   "pricing_tables": [
//     {
//       "name": "Pricing Table 1",
//       "data_merge": true,
//       "options": {
//         "discount": {
//           "type": "absolute",
//           "name": "Discount",
//           "value": 2.26
//         }
//       },
//       "sections": [
//         {
//           "title": "Sample Section",
//           "default": true,
//           "rows": [
//             {
//               "options": {
//                 "optional": true,
//                 "optional_selected": true,
//                 "qty_editable": true
//               },
//               "data": {
//                 "Name": "Toy Panda",
//                 "Description": "Fluffy!",
//                 "Price": 10,
//                 "QTY": 3,
//                 "Tax1": {
//                   "value": 7.5,
//                   "type": "percent"
//                 }
//               },
//               "custom_fields": {
//                 "Fluffiness": "5 / 5"
//               }
//             }
//           ]
//         }
//       ]
//     }
//   ],
//   "content_placeholders": [
//     {
//       "block_id": "{{block_id}}",
//       "content_library_items": [
//         {
//           "id": "{{cli_id}}",
//           "pricing_tables": [
//             {
//               "name": "Pricing Table 1",
//               "data_merge": true,
//               "options": {
//                 "discount": {
//                   "type": "absolute",
//                   "name": "Discount",
//                   "value": 2.26
//                 }
//               },
//               "sections": [
//                 {
//                   "title": "Sample Section",
//                   "default": true,
//                   "rows": [
//                     {
//                       "options": {
//                         "optional": true,
//                         "optional_selected": true,
//                         "qty_editable": true
//                       },
//                       "data": {
//                         "Name": "Placeholder Panda",
//                         "Price": 10,
//                         "QTY": 3
//                       }
//                     }
//                   ]
//                 }
//               ]
//             }
//           ]
//         },
//         {
//           "id": "{{cli_id_2}}",
//           "recipients": [
//             {
//               "email": "john@example.com",
//               "first_name": "John",
//               "last_name": "Roe",
//               "role": "Signer",
//               "signing_order": 2
//             }
//           ],
//           "fields": {
//             "Date": {
//               "value": "2019-12-31T00:00:00.000Z"
//             }
//           }
//         }
//       ]
//     }
//   ]
// }

loo_Json = create oleobject
// Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0
li_rc = loo_Json.ConnectToNewObject("Chilkat.JsonObject")

loo_Json.UpdateString("name","Full API Sample Document from PandaDoc Template")
loo_Json.UpdateString("template_uuid","{{template_id}}")
loo_Json.UpdateString("owner.membership_id","{{membership_id}}")
loo_Json.UpdateString("recipients[0].email","{{recipient_email}}")
loo_Json.UpdateString("recipients[0].first_name","Josh")
loo_Json.UpdateString("recipients[0].last_name","Ron")
loo_Json.UpdateString("recipients[0].role","user")
loo_Json.UpdateInt("recipients[0].signing_order",1)
loo_Json.UpdateString("tokens[0].name","Favorite.Pet")
loo_Json.UpdateString("tokens[0].value","Panda")
loo_Json.UpdateString("fields.~"Favorite.Color~".value","PandaDoc green")
loo_Json.UpdateString("fields.Delivery.value","Same Day Delivery")
loo_Json.UpdateBool("fields.Like.value",1)
loo_Json.UpdateString("fields.Date.value","2019-12-31T00:00:00.000Z")
loo_Json.UpdateString("metadata.my_favorite_pet","Panda")
loo_Json.UpdateString("tags[0]","created_via_api")
loo_Json.UpdateString("tags[1]","test_document")
loo_Json.UpdateString("images[0].name","Image 1")
loo_Json.UpdateString("images[0].urls[0]","https://s3.amazonaws.com/pd-static-content/public-docs/pandadoc-panda-bear.png")
loo_Json.UpdateString("pricing_tables[0].name","Pricing Table 1")
loo_Json.UpdateBool("pricing_tables[0].data_merge",1)
loo_Json.UpdateString("pricing_tables[0].options.discount.type","absolute")
loo_Json.UpdateString("pricing_tables[0].options.discount.name","Discount")
loo_Json.UpdateNumber("pricing_tables[0].options.discount.value","2.26")
loo_Json.UpdateString("pricing_tables[0].sections[0].title","Sample Section")
loo_Json.UpdateBool("pricing_tables[0].sections[0].default",1)
loo_Json.UpdateBool("pricing_tables[0].sections[0].rows[0].options.optional",1)
loo_Json.UpdateBool("pricing_tables[0].sections[0].rows[0].options.optional_selected",1)
loo_Json.UpdateBool("pricing_tables[0].sections[0].rows[0].options.qty_editable",1)
loo_Json.UpdateString("pricing_tables[0].sections[0].rows[0].data.Name","Toy Panda")
loo_Json.UpdateString("pricing_tables[0].sections[0].rows[0].data.Description","Fluffy!")
loo_Json.UpdateInt("pricing_tables[0].sections[0].rows[0].data.Price",10)
loo_Json.UpdateInt("pricing_tables[0].sections[0].rows[0].data.QTY",3)
loo_Json.UpdateNumber("pricing_tables[0].sections[0].rows[0].data.Tax1.value","7.5")
loo_Json.UpdateString("pricing_tables[0].sections[0].rows[0].data.Tax1.type","percent")
loo_Json.UpdateString("pricing_tables[0].sections[0].rows[0].custom_fields.Fluffiness","5 / 5")
loo_Json.UpdateString("content_placeholders[0].block_id","{{block_id}}")
loo_Json.UpdateString("content_placeholders[0].content_library_items[0].id","{{cli_id}}")
loo_Json.UpdateString("content_placeholders[0].content_library_items[0].pricing_tables[0].name","Pricing Table 1")
loo_Json.UpdateBool("content_placeholders[0].content_library_items[0].pricing_tables[0].data_merge",1)
loo_Json.UpdateString("content_placeholders[0].content_library_items[0].pricing_tables[0].options.discount.type","absolute")
loo_Json.UpdateString("content_placeholders[0].content_library_items[0].pricing_tables[0].options.discount.name","Discount")
loo_Json.UpdateNumber("content_placeholders[0].content_library_items[0].pricing_tables[0].options.discount.value","2.26")
loo_Json.UpdateString("content_placeholders[0].content_library_items[0].pricing_tables[0].sections[0].title","Sample Section")
loo_Json.UpdateBool("content_placeholders[0].content_library_items[0].pricing_tables[0].sections[0].default",1)
loo_Json.UpdateBool("content_placeholders[0].content_library_items[0].pricing_tables[0].sections[0].rows[0].options.optional",1)
loo_Json.UpdateBool("content_placeholders[0].content_library_items[0].pricing_tables[0].sections[0].rows[0].options.optional_selected",1)
loo_Json.UpdateBool("content_placeholders[0].content_library_items[0].pricing_tables[0].sections[0].rows[0].options.qty_editable",1)
loo_Json.UpdateString("content_placeholders[0].content_library_items[0].pricing_tables[0].sections[0].rows[0].data.Name","Placeholder Panda")
loo_Json.UpdateInt("content_placeholders[0].content_library_items[0].pricing_tables[0].sections[0].rows[0].data.Price",10)
loo_Json.UpdateInt("content_placeholders[0].content_library_items[0].pricing_tables[0].sections[0].rows[0].data.QTY",3)
loo_Json.UpdateString("content_placeholders[0].content_library_items[1].id","{{cli_id_2}}")
loo_Json.UpdateString("content_placeholders[0].content_library_items[1].recipients[0].email","john@example.com")
loo_Json.UpdateString("content_placeholders[0].content_library_items[1].recipients[0].first_name","John")
loo_Json.UpdateString("content_placeholders[0].content_library_items[1].recipients[0].last_name","Roe")
loo_Json.UpdateString("content_placeholders[0].content_library_items[1].recipients[0].role","Signer")
loo_Json.UpdateInt("content_placeholders[0].content_library_items[1].recipients[0].signing_order",2)
loo_Json.UpdateString("content_placeholders[0].content_library_items[1].fields.Date.value","2019-12-31T00:00:00.000Z")

loo_Http.SetRequestHeader("Authorization","API-Key {{api_key}}")
loo_Http.SetRequestHeader("Content-Type","application/json")

loo_Resp = loo_Http.PostJson3("https://api.pandadoc.com/public/v1/documents","application/json",loo_Json)
if loo_Http.LastMethodSuccess = 0 then
    Write-Debug loo_Http.LastErrorText
    destroy loo_Http
    destroy loo_Json
    return
end if

Write-Debug string(loo_Resp.StatusCode)
Write-Debug loo_Resp.BodyStr
destroy loo_Resp


destroy loo_Http
destroy loo_Json

Curl Command

curl -X POST
	-H "Authorization: Bearer {{access_token}}"
	-H "Authorization: API-Key {{api_key}}"
	-H "Content-Type: application/json"
	-d '{
    "name": "Full API Sample Document from PandaDoc Template",
    "template_uuid": "{{template_id}}",
    "owner":{
        "membership_id":"{{membership_id}}"
    },
    "recipients": [
        {
            "email": "{{recipient_email}}",
            "first_name": "Josh",
            "last_name": "Ron",
            "role": "user",
            "signing_order": 1
        }
    ],
    "tokens": [
        {
            "name": "Favorite.Pet",
            "value": "Panda"
        }
    ],
    "fields": {
        "Favorite.Color": {
            "value": "PandaDoc green"
        },
        "Delivery": {
            "value": "Same Day Delivery"
        },
        "Like": {
            "value": true
        },
        "Date": {
            "value": "2019-12-31T00:00:00.000Z"
        }
    },
    "metadata": {
        "my_favorite_pet": "Panda"
    },
    "tags": [
        "created_via_api",
        "test_document"
    ],
    "images": [
        {
            "name": "Image 1",
            "urls": [
                "https://s3.amazonaws.com/pd-static-content/public-docs/pandadoc-panda-bear.png"
            ]
        }
    ],
    "pricing_tables": [
        {
            "name": "Pricing Table 1",
            "data_merge":true,
            "options": {
                "discount": {
                    "type": "absolute",
                    "name": "Discount",
                    "value": 2.26
                }
            },
            "sections": [
                {
                    "title": "Sample Section",
                    "default": true,
                    "rows": [
                        {
                            "options": {
                                "optional": true,
                                "optional_selected": true,
                                "qty_editable": true
                            },
                            "data": {
                                "Name": "Toy Panda",
                                "Description": "Fluffy!",
                                "Price": 10,
                                "QTY": 3,
                                "Tax1": {
                                    "value": 7.5,
                                    "type": "percent"
                                }
                            },
                            "custom_fields": {
                                "Fluffiness": "5 / 5"
                            }
                        }
                    ]
                }
            ]
        }
    ],
    "content_placeholders": [
        {
            "block_id": "{{block_id}}",
            "content_library_items": [
                {
                    "id": "{{cli_id}}",
                    "pricing_tables": [
                        {
                            "name": "Pricing Table 1",
                            "data_merge":true,
                            "options": {  
                                "discount": {  
                                    "type": "absolute",
                                    "name": "Discount",
                                    "value": 2.26
                                }
                            },
                            "sections": [
                                {
                                    "title": "Sample Section",
                                    "default": true,
                                    "rows": [
                                        {
                                            "options": {
                                                "optional": true,
                                                "optional_selected": true,
                                                "qty_editable": true
                                            },
                                            "data": {
                                                "Name": "Placeholder Panda",
                                                "Price": 10,
                                                "QTY": 3
                                            }
                                        }
                                    ]
                                }
                            ]
                        }
                    ]
                },
                {
                    "id": "{{cli_id_2}}",
                    "recipients": [
                        {
                            "email": "john@example.com",
                            "first_name": "John",
                            "last_name": "Roe",
                            "role": "Signer",
                            "signing_order": 2
                        }
                    ],
                    "fields": {
                        "Date": {
        	                "value": "2019-12-31T00:00:00.000Z"
                        }
                    }
                }
            ]
        }
    ]
}'
https://api.pandadoc.com/public/v1/documents

Postman Collection Item JSON

{
  "name": "Create Document from PandaDoc Template (Full API Sample Document from PandaDoc Template)",
  "event": [
    {
      "listen": "test",
      "script": {
        "exec": [
          "var jsonData = JSON.parse(responseBody);",
          "if (jsonData.uuid !== undefined) {",
          "    postman.setEnvironmentVariable(\"document_id\", jsonData.uuid);",
          "}"
        ],
        "type": "text/javascript"
      }
    }
  ],
  "request": {
    "method": "POST",
    "header": [
      {
        "key": "Authorization",
        "value": "Bearer {{access_token}}",
        "disabled": true
      },
      {
        "key": "Authorization",
        "value": "API-Key {{api_key}}",
        "type": "text"
      },
      {
        "key": "Content-Type",
        "value": "application/json"
      }
    ],
    "body": {
      "mode": "raw",
      "raw": "{\n    \"name\": \"Full API Sample Document from PandaDoc Template\",\n    \"template_uuid\": \"{{template_id}}\",\n    \"owner\":{\n        \"membership_id\":\"{{membership_id}}\"\n    },\n    \"recipients\": [\n        {\n            \"email\": \"{{recipient_email}}\",\n            \"first_name\": \"Josh\",\n            \"last_name\": \"Ron\",\n            \"role\": \"user\",\n            \"signing_order\": 1\n        }\n    ],\n    \"tokens\": [\n        {\n            \"name\": \"Favorite.Pet\",\n            \"value\": \"Panda\"\n        }\n    ],\n    \"fields\": {\n        \"Favorite.Color\": {\n            \"value\": \"PandaDoc green\"\n        },\n        \"Delivery\": {\n            \"value\": \"Same Day Delivery\"\n        },\n        \"Like\": {\n            \"value\": true\n        },\n        \"Date\": {\n            \"value\": \"2019-12-31T00:00:00.000Z\"\n        }\n    },\n    \"metadata\": {\n        \"my_favorite_pet\": \"Panda\"\n    },\n    \"tags\": [\n        \"created_via_api\",\n        \"test_document\"\n    ],\n    \"images\": [\n        {\n            \"name\": \"Image 1\",\n            \"urls\": [\n                \"https://s3.amazonaws.com/pd-static-content/public-docs/pandadoc-panda-bear.png\"\n            ]\n        }\n    ],\n    \"pricing_tables\": [\n        {\n            \"name\": \"Pricing Table 1\",\n            \"data_merge\":true,\n            \"options\": {\n                \"discount\": {\n                    \"type\": \"absolute\",\n                    \"name\": \"Discount\",\n                    \"value\": 2.26\n                }\n            },\n            \"sections\": [\n                {\n                    \"title\": \"Sample Section\",\n                    \"default\": true,\n                    \"rows\": [\n                        {\n                            \"options\": {\n                                \"optional\": true,\n                                \"optional_selected\": true,\n                                \"qty_editable\": true\n                            },\n                            \"data\": {\n                                \"Name\": \"Toy Panda\",\n                                \"Description\": \"Fluffy!\",\n                                \"Price\": 10,\n                                \"QTY\": 3,\n                                \"Tax1\": {\n                                    \"value\": 7.5,\n                                    \"type\": \"percent\"\n                                }\n                            },\n                            \"custom_fields\": {\n                                \"Fluffiness\": \"5 / 5\"\n                            }\n                        }\n                    ]\n                }\n            ]\n        }\n    ],\n    \"content_placeholders\": [\n        {\n            \"block_id\": \"{{block_id}}\",\n            \"content_library_items\": [\n                {\n                    \"id\": \"{{cli_id}}\",\n                    \"pricing_tables\": [\n                        {\n                            \"name\": \"Pricing Table 1\",\n                            \"data_merge\":true,\n                            \"options\": {  \n                                \"discount\": {  \n                                    \"type\": \"absolute\",\n                                    \"name\": \"Discount\",\n                                    \"value\": 2.26\n                                }\n                            },\n                            \"sections\": [\n                                {\n                                    \"title\": \"Sample Section\",\n                                    \"default\": true,\n                                    \"rows\": [\n                                        {\n                                            \"options\": {\n                                                \"optional\": true,\n                                                \"optional_selected\": true,\n                                                \"qty_editable\": true\n                                            },\n                                            \"data\": {\n                                                \"Name\": \"Placeholder Panda\",\n                                                \"Price\": 10,\n                                                \"QTY\": 3\n                                            }\n                                        }\n                                    ]\n                                }\n                            ]\n                        }\n                    ]\n                },\n                {\n                    \"id\": \"{{cli_id_2}}\",\n                    \"recipients\": [\n                        {\n                            \"email\": \"john@example.com\",\n                            \"first_name\": \"John\",\n                            \"last_name\": \"Roe\",\n                            \"role\": \"Signer\",\n                            \"signing_order\": 2\n                        }\n                    ],\n                    \"fields\": {\n                        \"Date\": {\n        \t                \"value\": \"2019-12-31T00:00:00.000Z\"\n                        }\n                    }\n                }\n            ]\n        }\n    ]\n}"
    },
    "url": {
      "raw": "https://api.pandadoc.com/public/v1/documents",
      "protocol": "https",
      "host": [
        "api",
        "pandadoc",
        "com"
      ],
      "path": [
        "public",
        "v1",
        "documents"
      ]
    },
    "description": "Provide value to variable: template_id ([Postman environments](https://www.getpostman.com/docs/postman/environments_and_globals/manage_environments) is great for it).\n\nFor details and the sample template go to [https://developers.pandadoc.com/v1/reference#create-document-from-pandadoc-template](https://developers.pandadoc.com/v1/reference#create-document-from-pandadoc-template).\n\nFor details of document creation in general go to [https://developers.pandadoc.com/v1/reference#new-document](https://developers.pandadoc.com/v1/reference#new-document)."
  },
  "response": [
  ]
}