|
Dynamically adding COTG widgetsCapture OnTheGo (COTG) widgets can be added to a Form dynamically, via jQuery. For example: a new Camera element could be added when the user clicks an Add button. This topic explains how to implement this. It is assumed that you have a basic understanding of HTML forms, CSS, JavaScript, and jQuery. PrerequisitesBefore you can start writing code that adds a widget in response to an action of the user, you need the following:
Also, if you don't have a JavaScript file for your code yet, add one to the resources of your template (see Adding JavaScript files to the resources) and make sure to include that file in the Web context or in the Web section that contains the COTG Form (see Including a JavaScript file in a Web context). Adding an event handlerFirst of all you need to write an event handler that responds to the event that is meant to trigger the creation of the widget (e.g. the onClick event of a button or link), by calling the function that creates the widget. The event handler has to be added on the $(document).ready(function() { Creating the widgetNow you can start writing the code that constructs, adds and initializes the widget. This code has to be based on jQuery. Constructing the HTMLA widget basically is an HTML element with certain attributes and contents. The HTML structure of a widget can be seen on the Source tab after adding the widget to a Form in the Designer. In code, reconstruct the HTML. Make sure to give the new element an ID. This code constructs the HTML of a Date element:
Adding it to the FormAdd the HTML to an element on the Form using the append() function. The following code appends the contents of the variable Initializing the widgetA widget has to be initialized to allow it to be actually used. Widgets that are already present in a Form at startup are initialized as soon as the Form is loaded in the app. A widget that has been added to a Form dynamically has to be initialized directly after adding it to the Form; otherwise the new widget won't respond to actions of the user, even though it is visible in the app. Initializing a widget takes just one line of code, in which you select the new widget by its ID and call the initialization function on it. This code, for example, initializes a new Camera element that has the ID
Optionally, while initializing an element, you can make settings for this specific element. These settings get prevalence over the options already specified in the HTML and over the default settings specified in the COTG plugin. The code snippet below initializes a new Camera element (with the ID
The initialization functions and options of all widgets are listed in the Capture OnTheGo API: Capture OnTheGo API. To learn how to set the defaults for one kind of elements, see Changing default settings for widgets. Restoring a widgetWhen a Form is closed, the app stores the values of input fields to the local repository of the app, but the values of input fields of dynamically added widgets are not stored. Example: adding Camera widgets dynamicallyThe following code inserts a Camera widget when the user clicks on a link or button with the ID
|
|