Skip to main content
Blog
Home/

From the Trenches: Updating payment description through the API

Author Ivan Dinkov
Ivan DinkovSr. Developer Support Advisory Engineer
Summary3 min read

Try this workaround for updating payment description tabs when creating an envelope from a template with an included payment tab.

    • The problem
    • The solution
      • Additional resources

      Table of contents

      Docusign's Payment feature allows you to collect payments from your customers while they sign their contracts. This is covered in detail on the Developer Center. Please refer to the Developer Center page while reading this post.

      The request documented in the sample code shown in the Developer Center will result in two payment tabs being added to our document at the x and y coordinates specified for each numberTab.

      Payment tabs inserted in the document

      Let's look at the request specifics and how they relate to the Docusign web application UI.

      The payment description is represented by the lineItems array object and its properties. They are quite handy since they enable you to store additional product information. 

      For example, in this case, the first lineItem object contains four fields. The first three fields reference the Payment Description fields in the UI:

      "name": "Hamlet", 
      "description": "The Danish Play", 
      "itemCode": "SHAK1"
      
      
      Payment description fields in the UI

      "amountReference": "Hamlet" references the numberTab with "tabLabel": "Hamlet". The numberTabs holds the amount:. "value": "10.00".

      "numberTabs": [
        {
          "value": "10.00",
          "width": 78,
          "required": "true",
          "locked": "true",
          "tabLabel": "Hamlet",
          "documentId": "1",
          "pageNumber": "1",
          "xPosition": "323",
          "yPosition": "134"
        },
      
      

      So far, it appears that requesting payments is quite simple. But what if you decide to use a server template that already has a payment tab and you need to update these values while creating the envelope?

      The problem

      Unfortunately, the API does not yet fully support updating these values in the same API call while creating envelopes from server templates. You can update the numberTab value but not the lineItems fields with the needed data.

      The good news is that there is a workaround available.

      The solution

      • Create a server template and include a payment tab for the recipient.

      • Create an envelope from the server template as a draft by setting the envelope status to created.

      • Make a GET envelope API call and add the query string include with the values recipients and tabs: _{{base_url}}/restapi/v2.1/accounts/{{account_id}}/envelopes/xxxxxxxx-xxxx-xxxx-xxxxx-xxxxxxxxxxxx?include=recipients,tabs_

      • Extract and edit the formulaTabs array object from the tabs object for the recipient.

      • Make an UPDATE RecipientTabs API call using the above object.

      • Send the envelope by updating the envelope status to sent via a PUT Envelope API call.

      In C#, the code would look like this:

      GetEnvelopeOptions getEnvelopeOptions = new GetEnvelopeOptions();
      getEnvelopeOptions.include = "recipients,tabs";
      var envelopeRecipients = envelopesApi.GetEnvelope(accountId, envelopeId, getEnvelopeOptions).Recipients;
      var signer = envelopeRecipients.Signers.
      Where(s => s.Email.Equals("payment@testl.com")).FirstOrDefault();
      var lineItemsDetails = signer.Tabs.FormulaTabs.
      Where(d => d.TabLabel.Equals("PaymentReceipt test")).FirstOrDefault().PaymentDetails.LineItems;
      foreach (var item in lineItemsDetails)
      {
          if (item.AmountReference.Equals("Hamlet"))
          {
             item.Description = "The Danish Play";
             item.ItemCode = "SKU101";
             item.Name = "Hamlet";
           }
           if (item.AmountReference.Equals("Tempest"))
           {
              item.Description = "The one with Caliban in it";
              item.ItemCode = "SKU102";
              item.Name = "Othello";
            }
         }
      var updateTabsResult = envelopesApi.UpdateTabs(accountId,envelopeId,signer.RecipientId,signer.Tabs);
      var sendEnvelopeResult = envelopesApi.Update(accountId,envelopeId,new Envelope() { Status = "sent"});
      
      

      Now, if you make a GET Envelope call, you will see that the envelope was successfully sent and Payment details are updated with the new values.

      Additional resources

      Author Ivan Dinkov
      Ivan DinkovSr. Developer Support Advisory Engineer
      More posts from this author

      Related posts

      • From the Trenches: Troubleshooting INVALID_REQUEST_PARAMETER errors in the eSignature REST API
        Developer Support Articles

        From the Trenches: Troubleshooting INVALID_REQUEST_PARAMETER errors in the eSignature REST API

        Author Iandro Simoes
        Iandro Simoes
      • Expanding Power Automate Series: Long-lived Embedded Signing URLs

        Expanding Power Automate Series: Long-lived Embedded Signing URLs

        Author Robert Schendle
        Robert Schendle
      • Docusign for Developers Public Roadmap: A commitment to innovation and trust

        Docusign for Developers Public Roadmap: A commitment to innovation and trust

        Author Julian Macagno
        Julian Macagno
      Expanding Power Automate Series: Long-lived Embedded Signing URLs

      Expanding Power Automate Series: Long-lived Embedded Signing URLs

      Author Robert Schendle
      Robert Schendle
      Docusign for Developers Public Roadmap: A commitment to innovation and trust

      Docusign for Developers Public Roadmap: A commitment to innovation and trust

      Author Julian Macagno
      Julian Macagno

      Discover what's new with Docusign IAM or start with eSignature for free

      Explore Docusign IAMTry eSignature for Free
      Person smiling while presenting