Auto-save an adaptive form auto-save-an-adaptive-form
Adobe recommends using the modern and extensible data capture Core Componentsfor creating new Adaptive Formsor adding Adaptive Forms to AEM Sites pages. These components represent a significant advancement in Adaptive Forms creation, ensuring impressive user experiences. This article describes older approach to author Adaptive Forms using foundation components.
You can configure an adaptive form to automatically start saving the content based on an event or a pre-defined time-interval. By default, contents of an adaptive form are saved on a user action, such as on pressing the save button. The auto save option is helpful in:
- Automatically saving the content for anonymous and logged-in users
- Saving the content of a form without or minimal user intervention
- Start saving content of a form based on a user event
- Saving the content of a form repeatedly after a specified time interval
Enable autosave for an adaptive form enable-autosave-for-an-adaptive-form
For an adaptive form, the auto save option is not enabled out of the box. You can enable the auto save option from the Auto Save section in the properties of an adaptive form. The Auto Save section also provides several other configuration options. Perform the following steps to enable and configure the auto save option for an adaptive form:
-
To access the auto-save section in the properties, select a component, then select > Adaptive Form Container, and then select .
-
In the Auto Save section, Enable the auto-save option.
-
In the Adaptive Form Event box, specify 1 or TRUE to automatically start saving the form when the form is loaded in the browser. You can also specify a conditional expression for an event, which when triggered and returns true, starts saving the content of the form.
-
Specify the Trigger. Auto-save is triggered based on your configuration. Your options are:
- Time based: Select the option to start saving the content based on a specific time interval.
- Event based: Select the option to start saving the content based when an event is triggered.
When you select a trigger, Strategy Configuration box is enabled. Strategy Configuration box lets you:
- Specify a time interval if you select Time based trigger.
- Specify an event name if you select Event based trigger.
You can also create and add your own custom strategy to the list. For details, see Implement a custom strategy to autosave the forms.
-
(Time-based autosave only) Perform the following steps to configure options for the Time-based autosave.
- In the Auto save on this interval box, specify the time interval in seconds. The form is saved repeatedly after the number of seconds specified in the interval box elapse.
-
(Event-based auto save only) Perform the following steps to configure options for Event-based auto save.
- In th Auto save after this event box, specify a GuideBridge event. The form is saved every time the expression evaluates to TRUE.
-
(Optional) To automatically save the content for anonymous users, select the Enable Autosave for anonymous users option, and click OK.
note note NOTE For auto save option to work for anonymous users, ensure that you configure the Forms Common Configuration Service to allow all users to preview, verify, and sign forms. To configure the service, go to AEM Web Console configuration at https://server:port/system/console/configMgr
and edit the Forms Common Configuration Service to choose the All Users option in the Allow field, and save the configuration.
Implement a custom strategy to enable autosave for adaptive forms implement-a-custom-strategy-to-enable-autosave-for-adaptive-forms
You can implement a custom event to trigger the autosave functionality. Perform the following steps to create and implement the custom event:
-
Create client library and client library folders. For detailed steps, see the Using Client-Side Libraries document.
For example, the following script uses the custom
emailFocusChange
event to trigger the autosave functionality:code language-javascript window.addEventListener("bridgeInitializeStart", function (){ guideBridge.connect(function () { guideBridge.on("elementFocusChanged", function (event,data) { if(data.target.name === 'Email') { guideBridge.trigger("emailFocusChange"); } }); }); });
note note NOTE A category property is defined while creating the client library folders. Keep the value assigned to category property handy. -
Open the adaptive form in author mode.
-
In the edit mode, select a component, then select > Adaptive Form Container, and then select .
-
In th properties, open the Basic section. In the Client Library Category box, enter the value of the category property defined while creating the client library folders.
-
Open the Auto Save section. In the Auto save after this event box, specify a custom event already defined in the client library. Click OK.