Sample code for 30+ languages & platforms
Visual Basic 6.0

IntakeQ: Send a Questionnaire

See more IntakeQ Examples

Send an intake package using the API.

Chilkat Visual Basic 6.0 Downloads

Visual Basic 6.0
Dim success As Long
success = 0

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

Dim http As New ChilkatHttp

' Implements the following CURL command:

' curl -H "Content-Type: application/json" \
'      -H 'X-Auth-Key: xxxxxxxxxxxxxxxxxxxxxxxxx' \
'      -X POST \
'      -d '{     		
' 	"QuestionnaireId": "00000000-0000-0000-0000-000000000000",     		
' 	"ClientId": 123, 
' 	"ClientName": "Dexter Morgan",
' 	"ClientEmail": "dexter@email.com",
' 	"ClientPhone": "2222222222", 
' 	"PractitionerId": "00000000-0000-0000-0000-000000000000",
' }' https://intakeq.com/api/v1/intakes/send

' Use the following online tool to generate HTTP code from a CURL command
' Convert a cURL Command to HTTP Source Code

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

' The following JSON is sent in the request body.

' {
'   "QuestionnaireId": "00000000-0000-0000-0000-000000000000",
'   "ClientId": 123,
'   "ClientName": "Dexter Morgan",
'   "ClientEmail": "dexter@email.com",
'   "ClientPhone": "2222222222",
'   "PractitionerId": "00000000-0000-0000-0000-000000000000"
' }

Dim json As New ChilkatJsonObject
success = json.UpdateString("QuestionnaireId","00000000-0000-0000-0000-000000000000")
success = json.UpdateInt("ClientId",123)
success = json.UpdateString("ClientName","Dexter Morgan")
success = json.UpdateString("ClientEmail","dexter@email.com")
success = json.UpdateString("ClientPhone","2222222222")
success = json.UpdateString("PractitionerId","00000000-0000-0000-0000-000000000000")

http.SetRequestHeader "Content-Type","application/json"
http.SetRequestHeader "X-Auth-Key","xxxxxxxxxxxxxxxxxxxxxxxxx"

Dim resp As New ChilkatHttpResponse
success = http.HttpJson("POST","https://intakeq.com/api/v1/intakes/send",json,"application/json",resp)
If (success = 0) Then
    Debug.Print http.LastErrorText
    Exit Sub
End If

Dim sbResponseBody As New ChilkatStringBuilder
success = resp.GetBodySb(sbResponseBody)
Dim jResp As New ChilkatJsonObject
success = jResp.LoadSb(sbResponseBody)
jResp.EmitCompact = 0

Debug.Print "Response Body:"
Debug.Print jResp.Emit()

Dim respStatusCode As Long
respStatusCode = resp.StatusCode
Debug.Print "Response Status Code = " & respStatusCode
If (respStatusCode >= 400) Then
    Debug.Print "Response Header:"
    Debug.Print resp.Header
    Debug.Print "Failed."
    Exit Sub
End If

' Sample JSON response:
' (Sample code for parsing the JSON response is shown below)

' {
'   "Id": "00000000-0000-0000-0000-000000000000",
'   "ClientName": "test",
'   "ClientEmail": "test@email.com",
'   "ClientId": 9999,
'   "Status": "Completed",
'   "DateCreated": 1458526480368,
'   "DateSubmitted": 1458526532654,
'   "QuestionnaireName": "test",
'   "Practitioner": "test@email.com",
'   "PractitionerName": "FirstName LastName",
'   "Questions": [
'     {
'       "Id": "xxxx-1",
'       "Text": "Full name",
'       "Answer": "Dexter Morgan",
'       "QuestionType": "OpenQuestion",
'       "Rows": [
'       ],
'       "ColumnNames": [
'       ],
'       "OfficeUse": false,
'       "OfficeNote": "aaa"
'     },
'     {
'       "Id": "xxxx-2",
'       "Text": "Full name",
'       "Answer": "Dexter Morgan",
'       "QuestionType": "OpenQuestion",
'       "Rows": [
'       ],
'       "ColumnNames": [
'       ],
'       "OfficeUse": false,
'       "OfficeNote": "aaa"
'     }
'   ],
'   "AppointmentId": "xxxxxxxx",
'   "ConsentForms": [
'     {
'       "Id": "00000000-0000-0000-0000-000000000000",
'       "Name": "HIPAA Release Form",
'       "DocumentType": "Html",
'       "Signed": true,
'       "DateSubmitted": 1458526532654
'     }
'   ]
' }

' Sample code for parsing the JSON response...
' Use the following online tool to generate parsing code from sample JSON:
' Generate Parsing Code from JSON

Dim Text As String
Dim Answer As String
Dim QuestionType As String
Dim OfficeUse As Long
Dim OfficeNote As String
Dim j As Long
Dim count_j As Long
Dim Name As String
Dim DocumentType As String
Dim Signed As Long

Dim Id As String
Id = jResp.StringOf("Id")
Dim ClientName As String
ClientName = jResp.StringOf("ClientName")
Dim ClientEmail As String
ClientEmail = jResp.StringOf("ClientEmail")
Dim ClientId As Long
ClientId = jResp.IntOf("ClientId")
Dim Status As String
Status = jResp.StringOf("Status")
Dim DateCreated As Long
DateCreated = jResp.IntOf("DateCreated")
Dim DateSubmitted As Long
DateSubmitted = jResp.IntOf("DateSubmitted")
Dim QuestionnaireName As String
QuestionnaireName = jResp.StringOf("QuestionnaireName")
Dim Practitioner As String
Practitioner = jResp.StringOf("Practitioner")
Dim PractitionerName As String
PractitionerName = jResp.StringOf("PractitionerName")
Dim AppointmentId As String
AppointmentId = jResp.StringOf("AppointmentId")
Dim i As Long
i = 0
Dim count_i As Long
count_i = jResp.SizeOfArray("Questions")
Do While i < count_i
    jResp.I = i
    Id = jResp.StringOf("Questions[i].Id")
    Text = jResp.StringOf("Questions[i].Text")
    Answer = jResp.StringOf("Questions[i].Answer")
    QuestionType = jResp.StringOf("Questions[i].QuestionType")
    OfficeUse = jResp.BoolOf("Questions[i].OfficeUse")
    OfficeNote = jResp.StringOf("Questions[i].OfficeNote")
    j = 0
    count_j = jResp.SizeOfArray("Questions[i].Rows")
    Do While j < count_j
        jResp.J = j
        j = j + 1
    Loop
    j = 0
    count_j = jResp.SizeOfArray("Questions[i].ColumnNames")
    Do While j < count_j
        jResp.J = j
        j = j + 1
    Loop
    i = i + 1
Loop
i = 0
count_i = jResp.SizeOfArray("ConsentForms")
Do While i < count_i
    jResp.I = i
    Id = jResp.StringOf("ConsentForms[i].Id")
    Name = jResp.StringOf("ConsentForms[i].Name")
    DocumentType = jResp.StringOf("ConsentForms[i].DocumentType")
    Signed = jResp.BoolOf("ConsentForms[i].Signed")
    DateSubmitted = jResp.IntOf("ConsentForms[i].DateSubmitted")
    i = i + 1
Loop