Visual Basic 6.0
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
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