Bootstrapping
Creating a Client
The Forms SDK uses an instance of the CamSDK.Client to communicate with the process engine (over the REST API):
var camClient = new CamSDK.Client({
  mock: false,
  apiUri: 'http://localhost:8080/engine-rest'
});
Creating a Form
In order to create a form, you need to create an instance of CamSDK.Form:
new CamSDK.Form({
  // ...
});
Providing a Task Id
In case the form is a task form (i.e., the submission of the form should trigger the completing of a task), you need to provide a taskId:
new CamSDK.Form({
  client: camClient,
  // the task ID
  taskId: 'someTaskId',
  //...
});
Providing a Process Definition Id
In case the form is a start form (i.e., the submission of the form should trigger a new process instance to start), you need to provide a processDefinitionId:
new CamSDK.Form({
  client: camClient,
  // the process definition ID
  processDefinitionId: 'someProcessDefinitionId',
  //...
});
Loading a Form from a URL
The Forms SDK can automatically load forms from a URL.
The URL from which the form should be loaded is referenced using the formElement property.
In that case you need to create a container element somewhere in the DOM:
<div id="formContainer">
</div>
And reference it in the containerElement property when creating the CamSDK.Form instance:
new CamSDK.Form({
  client: camClient,
  // URL to the form
  formUrl: '/url/to/form.html',
  // the task ID
  taskId: 'someTaskId',
  // the container to which the form should be appended. Can be a DOM element or a jQuery wrapper
  containerElement: $('#formContainer'),
  done: function(error, camFormInstance) {
    // ..
  }
});
Using a form existing in the DOM
It is also possible to initialize the Form SDK for a form already existing in the DOM.
Assuming that you have an HTML <form ...> element present in the DOM:
<form id="myForm">
  <input ....>
</form>
You can create an instance of CamSDK.Form and attach it to the existing form like this:
new CamSDK.Form({
  client: camClient,
  // the task ID
  taskId: 'someTaskId',
  // the form element. Can be a DOM element or a jQuery wrapper
  formElement: $('#myForm'),
  done: function(error, camFormInstance) {
    // ..
  }
});