Skip to content

Latest commit

 

History

History
100 lines (70 loc) · 9.36 KB

developer-docs-home.md

File metadata and controls

100 lines (70 loc) · 9.36 KB

Developer documentation for SurveyCTO field plug-ins

Table of contents

  1. What is a field plug-in
  2. What can a field plug-in do
  3. How can a field plug-in interact with a form
  4. How to start
  5. Documentation index
  6. Sharing your field plug-ins
  7. Useful field plug-ins for developers

What is a field plug-in

A field plug-in can be thought of as a web page. When filling out a SurveyCTO form, this web page will load instead of the standard field view. A field plug-in effectively 'takes over' the field on which it is used. In this way, field plug-ins enable you to have complete control over the appearance and functionality of questions in your data collection instrument.

If you've ever created your own web page using HTML, CSS, and Javascript, then you already understand the underlying technology. A field plug-in uses those three basic web technologies to create a web view whenever the field is loaded in a form. You can use all the features of standard Javascript to control what happens in the field plug-in itself, then use our form APIs to control how your field plug-in interacts with the rest of the form.

What can a field plug-in do

The short answer is that a field plug-in can do anything that a normal web page can do. When filling out a SurveyCTO form and you arrive at a field that uses a field plug-in, a web page is created using your field plug-in's code. On Android, a field plug-in is loaded in its own fully-functional Android WebView. On iOS, it is loaded in a WKWebView. In web forms, it is loaded in an iframe. No matter which platform is used, a field plug-in is free to use HTML, CSS, and Javascript in the same way any normal web page can.

How can a field plug-in interact with a form

Field plug-ins are loaded in their own isolated web views, but there are several ways in which your field plug-in can interact with the rest of the form and the Collect interface.

  • Form APIs
    We've created APIs that you can use to interact with the form in specific ways. Some of these APIs are required, and should be included in every field plug-in. Some are provided to you for convenience, and may not be applicable in every field. The full list is available in the form API reference documentation.

  • Parameters
    When you configure a field to use a field plug-in, you can supply optional parameters as well. These parameters can contain expressions and field references, which get evaluated right before the field plug-in loads. This can be used to pass information or configuration settings from other parts of the form to your field plug-in. More information is available within the form API reference documentation.

  • Metadata
    Your field plug-in can store metadata alongside response data. This metadata can be accessed by other fields in the form using the plug-in-metadata(field) function. This can be used to pass information from your field plug-in to other parts of the form. See this page for more info about form functions including plug-in-metadata(field).

  • Referencing form attachments
    Field plug-ins can access form attachments if you know their file name. See the field plug-in definition documentation for more info.

How to start

The easiest way to get started developing your own field plug-ins is to start with one of our pre-made templates. We've created a set of 'baseline' field plug-ins which contain all the code necessary to reproduce the standard field types. Starting with a baseline plug-in allows you to start with a fully-functional field, and make modifications as you need. We recommend following the steps below to start.

  1. Read the field plug-in definition documentation.
  2. Familiarize yourself with the form API reference documentation, so you know what options are available to you for interacting with the rest of the form.
  3. Fork one of our baseline field plug-in repos from the list below.
  4. Each baseline repo contains a test form. Upload that test form (and it's associated attachments) to your SurveyCTO server.

Note: you'll need access to a SurveyCTO server. You can sign up for a free trial here. If you want to keep evaluating SurveyCTO after the 15-day trial period, you can use our free community subscription. This special subscription unlocks all features of the platform while providing just the right limits for your “sandbox”: 10 forms, 200 submissions per month, and 200 MB of storage. You can learn more by reading our community contract.

Documentation index

In addition to what's on this page, the following is an index of resources available to help you learn more.

  1. Field plug-in definition
    This document describes the structure and format of field plug-ins. It is recommended that you read this first.
  2. Form API reference
    This document contains a comprehensive list of available APIs that have been created to allow your field plug-in to interact with a form.
  3. Using field plug-ins (user documentation)
    This article is written for form designers and will explain how to install and use field plug-ins in SurveyCTO.
  4. Field plug-in catalog
    Our support team maintains a curated list of field plug-ins developed by SurveyCTO as well as the broader global community. If you're looking for examples or inspiration, check here first.

Sharing your field plug-ins

We recommend trying to match the structure of our baseline plug-in repositories as closely as possible. This will ensure that users can easily find and navigate your plug-in repository. Below are some guidelines:

  1. Always include a readme.
    Your readme should at the very least contain a title and description of what your field plug-in is supposed to do. It is also recommended to include a "Default SurveyCTO feature support" section, a "How to use" section, and an image preview of how your plug-in looks.
  2. Always include a test form.
    This should be the simplest form possible that demonstrates the functionality of your field plug-in.
  3. Add the topic scto-field-plug-in to your repository.
    This will allow your field plug-in to show up when users search for that topic.
  4. Keep all source files in a source folder.
  5. Keep your .zip file up-to-date.
    Keep the most recent version of your x.fieldpliugin.zip file in the root of your repository. Most users will only be looking for that file, and they will not bother looking around in subdirectories, or zipping their own version. Every time you push changes to your source code, you should update that .zip file as well.
  6. Keep all other files in an extras folder.
    This includes image previews, test forms, and other associated files that you may want to store in your repository.

Useful field plug-ins for developers

Baseline field plug-ins

SurveyCTO develops and maintains a set of baseline field plug-ins which are designed to reproduce the default behavior of regular SurveyCTO field types. There should be virtually no differences in field appearance/behavior when these are used. They are meant to be used as starter templates for you to use when developing your own field plug-ins.

Feature demonstration field plug-ins

SurveyCTO has developed a few field plug-ins to demonstrate some advanced features that plug-ins are capable of. These are not inteded to be used for actual data collection, but are offered as tools to help you learn or test out these advanced features while learning to develop your own plug-ins.

  • feature-demo-parameters
    Parameters can be used to pass values to a field plug-in (including values from other form fields).
  • feature-demo-metadata
    Metadata can be used by your field plug-in to store data about itself while the form is being filled out.
  • feature-demo-intents
    Intents can be used by Android Collect to communicate with other apps on the device.