Copyright © 2023 OPTIMAL SYSTEMS GmbH
This software is licensed under the Apache License, Version 2.0. Ensure you comply with the License when using this software. It's distributed without warranties or conditions, either express or implied. Consult the License specifics related to permissions and limitations.
For comprehensive details on developing and integrating custom modal dialogs into enaio® webclient, refer to our official Modal Dialog API documentation.
Starting from version 11.10 FINAL, enaio® webclient has introduced the ability to open bespoke and fully designable modal dialogs. These dialogs enable the integration of external webpages hosted under the same hostname and facilitate seamless interaction through an API for data exchange. Explore the documentation for more details.
Utilize the formHelper method "openModalDialog" to launch a custom modal dialog. Provide the URL, and optionally its title and size, as parameters. The modal dialogs support comprehensive interaction via API, covering various methods and events for a dynamic and flexible user experience.
To bridge communication between a modal dialog and the enaio® webclient, we offer the Modal Dialog API. It's enriched with special events and methods that enhance information exchange and interaction.
Abstraction Library is a critical component of this project designed to facilitate seamless communication between the modal dialog and both the enaio® webclient and enaio® richclient. This library, available as an npm package accessible here, serves as a foundational bridge, enhancing interaction between the modal dialog and the enaio® platforms.
The Abstraction Library is primarily intended to simplify and streamline the process of communication between the modal dialog and both the enaio® webclient and enaio® richclient. By adopting this library, the integration of the modal dialog into both platforms becomes a cohesive and straightforward endeavor, all while maintaining a unified codebase.
In the enaio® webclient, modal dialogs interact with the main application through a series of events, facilitating a dynamic and responsive user experience. The key events include:
-
onInit: Activated as soon as the modal dialog becomes visible to the user, this event allows the dialog to initialize itself with context-specific information, ensuring a seamless integration at runtime. Find out more in the onInit event documentation.
-
onCanCancel: This event enables the modal dialog to handle cancellation actions, such as when a user presses the ESC key. It's crucial for implementing conditional logic that determines whether the dialog can be closed based on the current state or other criteria. Learn more about it in the onCanCancel event documentation.
The enaio® webclient provides a comprehensive set of API methods for modal dialogs, allowing for intricate interactions and data exchange between the dialog and the webclient. These methods include:
-
getEnvironment(): Offers a snapshot of the current environmental settings within the enaio® webclient, such as user details and language preferences, empowering the modal dialog with context-aware capabilities. Access the method's documentation here.
-
getFieldValueByInternal(internalFieldName): Facilitates the retrieval of specific field values from the active index data screen, enabling modal dialogs to access and display relevant data dynamically. Dive into the specifics in the getFieldValueByInternal method documentation.
-
setFieldValueByInternal(internalFieldName, value): This method allows the modal dialog to update field values on the active index data screen, making it possible to alter index data directly from the dialog. Detailed information can be found in the setFieldValueByInternal method documentation.
-
closeModalDialog(value): Defines the action to close the modal dialog, optionally performing additional tasks upon closure. This method is essential for ending the dialog session in a controlled manner. More details are available in the closeModalDialog method documentation.
-
setDialogCaption(value): Adjusts the title of the modal dialog dynamically at runtime, offering flexibility in how the dialog is presented to the user based on the current context or user actions. Read more about this method in the setDialogCaption method documentation.
-
getWorkflowVariableByName(name): Enables the modal dialog to query and retrieve data from specific workflow mask variables, facilitating a deeper integration with the underlying business processes. For further details, refer to the getWorkflowVariableByName method documentation.
-
setWorkflowVariableByName(nameOfTheWorkflowVariable, valueForTheWorkflowVariable): Enables values to be written to workflow variables for the current workflow activity and therefore also to the respective linked field on the workflow screen, refer to the setWorkflowVariableByName method documentation.
-
Clone the Repository
git clone https://github.com/OPTIMALSYSTEMS/enaio-webclient-demo-modal-dialog-addon.git
-
Navigate to the Project Directory
cd enaio-webclient-demo-modal-dialog-addon
-
Install Necessary Packages
npm install
-
Start The Project
npm start
Voilà! You're primed to launch the project.