BPM and Web Dynpro for Java
Integration – Guidelines
June, 2009
Team Members : Sunil Nair
SAP NetWeaver RIG APJ
Makoto Sugishita
SAP NetWeaver RIG APJ
Disclaimer
This presentation outlines our general product direction and should not be relied on in
making a purchase decision. This presentation is not subject to your license
agreement or any other agreement with SAP. SAP has no obligation to pursue any
course of business outlined in this presentation or to develop or release any
functionality mentioned in this presentation. This presentation and SAP's strategy and
possible future developments are subject to change and may be changed by SAP at
any time for any reason without notice. This document is provided without a warranty
of any kind, either express or implied, including but not limited to, the implied
warranties of merchantability, fitness for a particular purpose, or non-infringement.
SAP assumes no responsibility for errors or omissions in this document, except if
such damages were caused by SAP intentionally or grossly negligent.
© SAP 2009 / SAP NW RIG APJ Page 2
Content
Overview – Business Process Management
Model Based Business Process Management User Interface and Human Activity
Composite Business Process Business Process Desk
Business Process Modeling Notation (BPMN) Task Execution User Interface
Overview – Web Dynpro for Java
At a glance Web Dynpro Component and Componentization
Web Dynpro Tools and Code Generation Context Mapping and UI Element Binding
Web Dynpro DC
Integrate Web Dynpro Java with Business Process Management
How to embed WebDynpro into Business Process Management – Step by Step
Guidelines for Web Dynpro Development
Recommendations, best practices, dos & donts
Important SAP Notes and links
© SAP 2009 / SAP NW RIG APJ Page 3
Model-Based Business Process Management
Composition Environment 7.1 EHP1 Human-Centric
SAP Executable models
NetWeaver Process collaboration
7.1 EHP1 Human interaction management
Packaged Processes
SAP Application Business Business
Descriptive models
Object Object
Core Processes Embedded workflow
SOA Design
Governance
Expose services / events
System-Centric
Process Integration 7.1 EHP1
Executable models
Process automation
Service and event infrastructure
B2B Non SAP
© SAP 2009 / SAP NW RIG APJ Page 4
Composite Business Processes
Characteristics
Process Process
Composer Desk Graphical modeler based on
BPMN
Process Server Eclipse-based
Support key process concepts
(workflow, event, task, context, roles,
UI) throughout their lifecycle
Combine human interaction and
system integration in one model
Direct path from business view
to process execution
Nothing ‘lost in translation’
Dynamic role-based views
Single active model
Flexible execution
Embedded in SAP NetWeaver CE
Integrated composition experience
Common UI technology
Service-based connectivity
© SAP 2009 / SAP NW RIG APJ Page 5
BPMN – Sequence Flow Overview
Activity
A step in the process
Represents work or action performed
Gateway
Controls flow branching, merging and parallel actions
Pure logic – does not do the decision itself
Event
A signal that „something has happened“
Can start, pause and resume or interrupt and
redirect a process or activity
© SAP 2009 / SAP NW RIG APJ Page 6
BPMN – Type of Activities
Human Activity
Activity that has to be processed by a natural
Person
Automated Activity
Activity that is processed by a system
Sub-process
A compound (decomposable) Activity that holds a
sub-process modeled with BPMN – can be shown
collapsed or expanded
© SAP 2009 / SAP NW RIG APJ Page 7
BPM Process Desk 1/2
BPM Toolbar
Status Information
Delegating or revoking
task
Attaching notes or
files to the active task
or the whole process
Process view for
showing process
runtime information
© SAP 2009 / SAP NW RIG APJ Page 8
BPM Process Desk 2/2
The Process Desk is the interaction layer between the user and process.
Process Tasks assigned to a user show up in the UWL of the Portal.
Tasks are displayed in the Task Execution User Interface
© SAP 2009 / SAP NW RIG APJ Page 9
Task Execution User Interface 1
Construction
Tasks are displayed in the task viewer User Interface
Embeds the Web Dynpro assigned to the task at design time
Assigned WebDynpro
Component User Interface
© SAP 2009 / SAP NW RIG APJ Page 10
Task Execution User Interface
Attachments and Notes 2
Can be added to tasks only at runtime
Viewable in proceeding tasks of the same process instance
© SAP 2009 / SAP NW RIG APJ Page 11
Task Execution User Interface
Process Template 3
Process Template can be displayed
Current user sees current steps within the process
© SAP 2009 / SAP NW RIG APJ Page 12
Content
Overview – Business Process Management
Model Based Business Process Management User Interface and Human Activity
Composite Business Process Business Process Desk
Business Process Modeling Notation (BPMN) Task Execution User Interface
Overview – WebDynpro for Java
At a glance Web Dynpro Component and Componentization
Web Dynpro Tools and Code Generation Context Mapping and UI Element Binding
Web Dynpro DC
Integrate WebDynpro Java with Business Process Management
How to embed WebDynpro into Business Process Management – Step by Step
Guidelines for WebDynpro Development
Recommendations, best practices, dos & donts
Important SAP Notes and links
© SAP 2009 / SAP NW RIG APJ Page 13
At a glance
SAP NetWeaver UI Technology for developing data-driven web applications
Use of declarative and graphical tools reduces the implementation effort
Offers the following advantages for application developers:
Enforces separation of business logic and display logic
Declarative UI development independent of client technology (like web browser, smart
client, mobile device)
Uniform metamodel for all types of user interfaces
Comprehensive library with standard, complex and graphical UI elements
Connectivity to backend systems using, for example, web services, Enterprise
JavaBeans, and adaptive RFC
Accessibility support
Adobe Forms integration
The pages created by WebDynpro can be personalized, user or roles based
You have the choice to work with visual models or code editors
© SAP 2009 / SAP NW RIG APJ Page 14
WebDynpro Tools and Code Generation
A glance at Web Dynpro Tools
Data Modeler : Sharing data between classes within a component
Navigation Modeler : Creation of navigation links between different UI views
View Designer : Define the layout and data sources of UI elements
Controller Editor : Define data storage, instance methods, events, navigation plugs and actions
Message Editor : Message and text string definition
Model Importer : Wizards to create various types of model object
Support design and development process for UIs and entire applications
Use of declarative and graphical tools reduces the implementation effort
Reduces coding efforts by generating entities based on defined meta-data
Source Code Generation for Controller Classes and Interfaces
Classes contain user coding areas where additional code can be implemented
Interfaces for context objects (typed nodes and node elements)
Interfaces for message texts
Model classes
© SAP 2009 / SAP NW RIG APJ Page 15
Web Dynpro Development Component (DC)
Development and build unit
Basic reusable units of an application
One DC can use another DC by referring to the public interfaces (public
parts)
Web DC comprises of
Web Dynpro-specific developments, such as Web Dynpro components,
models, component interfaces, views, and so on
Provides storage buffer for DC metadata which serves to define
application relationships between different DCs
Relation between Web Dynpro DC and Web Dynpro Component
© SAP 2009 / SAP NW RIG APJ Page 16
Web Dynpro Component and Componentization 1/2
Overview
Fundamental building block from which all applications are constructed
Basic unit of development and reuse
Atleast one Web Dynpro Component in a Web Dynpro application
Applications used to implement real-life business scenarios are frequently
constructed from a hierarchy of multiple components
An aggregation of independent, yet interrelated Java classes
Component Controller : Master Controller generated automatically
Custom Controller : Similar but created by explicit design time declaration
Component Interface : Defines set of publicly accessible entry points
Window : Atleast one view and default interface with which user interacts
View : Visual component inside a window with which a user interacts
Model : Provides access to functionality such as BAPI calls or Web services
Application : Defines an entry point into a Web Dynpro component
General Architecture of Web Dynpro Component
© SAP 2009 / SAP NW RIG APJ Page 17
Web Dynpro Component and Componentization 2/2
Dividing Business Functionality into Components
Focus on implementing the functionality using reusable Web Dynpro components
Focus on reusable Web Dynpro components, not on
the web pages
Component Hierarchy
Root Component
Deliver functionality of entire Web Dynpro business application, and can‘t be reused individually.
Manage creation, destruction and interaction of child component instances
Entry point into business functionality and cannot be faceless
Intermediate Component
Performs specific role within the scope of Web Dynpro application
Designed to function within scope of single business application and hence not suitable for reuse
Utility and Model Component
Utility Component : Small and frequently used units of functionality
Provides access to functionality such as BAPI calls or Web services
© SAP 2009 / SAP NW RIG APJ Page 18
Context Mapping and UI Element Binding
Context Mapping UI Element Binding
Share data between controllers Putting data on the screen
Data Storage and consistency Data binding enables interaction
between UI elements and context
elements
Changes of UI element are transferred
to context and vice versa
© SAP 2009 / SAP NW RIG APJ Page 19
Context Mapping and UI Element Binding
Putting it all together: From model to screen
Data passes from the model object to the screen using this chain of connections:
The context of the component controller is bound to the model object
The view controller context is mapped to the component controller context
The UI elements are bound to the view controller’s context
© SAP 2009 / SAP NW RIG APJ Page 20
Content
Overview – Business Process Management
Model Based Business Process Management User Interface and Human Activity
Composite Business Process Business Process Desk
Business Process Modeling Notation (BPMN) Task Execution User Interface
Overview – Web Dynpro for Java
At a glance Web Dynpro Component and Componentization
Web Dynpro Tools and Code Generation Context Mapping and UI Element Binding
Web Dynpro DC
Integrate Web Dynpro Java with Business Process Management
How to embed WebDynpro into Business Process Management – Step by Step
Guidelines for Web Dynpro Development
Recommendations, best practices, dos & donts
Important SAP Notes and links
© SAP 2009 / SAP NW RIG APJ Page 21
Integrate Web Dynpro Java with BPM
Overview
Define Complete Event in Component
BPM Task
Controller and expose it to the
(Web Dynpro Component)
5
Interface Controller
4
Expose needed context structure
from Component Controller to the
Interface Controller Interface Controller (only context
structure needed by BPM process
must be exposed)
Event
Fire Complete Event in the
1 2 Component Controller (indicates
BPM, that UI task is completed by
Component Controller end user)
Add Web Dynpro Component to Public
3
Event
Part and set Dependency
Web Dynpro Component Modify BPM Project
Create BPM Task and assign UI to that
Map WebDynpro Context to Data Object
© SAP 2009 / SAP NW RIG APJ Page 22
1
Create Event and copy it to Interface Controller
Web Dynpro Component Controller Web Dynpro Local Component
Define the following Event(s) in Component Interface Controller
Controller. You can use arbitrary name for these Create the events within Web Dynpro
events. Local Component Interface for
Complete communicating with SAP NetWeaver
Error (optional) BPM by pasting the Component
Controller Event(s).
You can Copy Paste Events from Component
Controller to Interface Controller
© SAP 2009 / SAP NW RIG APJ Page 23
Expose Context Structure to Interface Controller 2
Web Dynpro Component Controller Web Dynpro Local Component
Use only “built-in” data types for context attributes Interface Controller
Only context nodes defined at design
time are visible to SAP NetWeaver BPM
You can Copy Paste Context Structure
from Component Controller to Interface
Controller
© SAP 2009 / SAP NW RIG APJ Page 24
Fire Complete Event in Component Controller 3
Web Dynpro Component
Controller
Create methods within Web Dynpro
Component Controller for firing
“Complete” and/or “Error” events
Then bind this method for example to
an ActionButton
© SAP 2009 / SAP NW RIG APJ Page 25
Add Web Dynpro Component to Public Part and
Set Dependency 4
Development Infrastructure perspective
Set dependency between Development Component
of SAP NetWeaver BPM and Web Dynpro
Web Dynpro Component Controller
Add to Public Part
© SAP 2009 / SAP NW RIG APJ Page 26
Modify BPM project
Create Task for Human Activity and assign UI 5
Create a task within SAP NetWeaver BPM
Maintain Tasks with additional Information about roles and behavior
Import Web Dynpro Component and assign User Interface to Task
© SAP 2009 / SAP NW RIG APJ Page 27
Modify BPM project
Assign Task to Process Model and Map data
6
Assign Task in property window of human activity
Web Dynpro Contexts are shown in the mapping
© SAP 2009 / SAP NW RIG APJ Page 28
Appendix: Runtime Behavior
Completion Event and Error Event
By triggering the Event for By triggering the Event for
“Completion”, “Error”,
The human activity completes The process became the error status (You
can change the status back in NWA)
Dialog pops up asking whether to close
the window of the BPM task. Error message appears
© SAP 2009 / SAP NW RIG APJ Page 29
Content
Overview – Business Process Management
Model Based Business Process Management User Interface and Human Activity
Composite Business Process Business Process Desk
Business Process Modeling Notation (BPMN) Task Execution User Interface
Overview – Web Dynpro for Java
At a glance Web Dynpro Component and Componentization
Web Dynpro Tools and Code Generation Context Mapping and UI Element Binding
Web Dynpro DC
Integrate Web Dynpro Java with Business Process Management
How to embed WebDynpro into Business Process Management – Step by Step
Guidelines for Web Dynpro Development
Recommendations, best practices, dos & don’t’s
Important SAP Notes and links
© SAP 2009 / SAP NW RIG APJ Page 30
Guidelines for Web Dynpro Development
Recommendations, best practices, dos & don'ts
Recommendations for storing business data
Volume of data low and process is small, you may want to pass and store the entire
data into BPM Context. Nevertheless, BPM has no restrictions on data volume.
It is recommended that you pass only the key to the BPM and get updated data
BPM stores instance specific data only till the process is alive and the data is needed
For processes that are very long and the data is expected to change frequently during
the process execution, then pass the key and fetch the updated information
External data store is if user wants to save the temporary data
Take into consideration the supported and unsupported data types (see next slide)
Only for simple scenario Recommended
Web Dynpro Web Dynpro Web Dynpro Web Dynpro
Other
Other data
data
Entire Data Entire Data Key WD Key
Model
task task task task
BPM BPM
© SAP 2009 / SAP NW RIG APJ Page 31
Guidelines for Web Dynpro Development
Recommendations, best practices, dos & don'ts
Supported Data Types
Built-In SimpleTypes: binary, boolean, byte, date, decimal, double,
float, integer, long, short, string, time, time stamp
Non Supported Data Types
Dictionary types (predefined types, for example, currency), core
data types (for example, amount, duration, attachment), Java native
types
Limitations with CE7.1.1
Reverse Context Mapping
Web Dynpro component’s interface controller context nodes have the property Input
Element set to true. This property must be set to false.
Model Binding
Web Dynpro component’s interface controller context nodes, which are bound to Web
Dynpro model (CMI) are instantiated after the point in time when BPM can access Web
Dynpro context. Due to this the use of Web Dynpro context nodes, which are bound to
used model are not supported.
Dynamic Context Structure Modification
For creation of runtime data, mappings and rules, BPM takes Web Dynpro component’s
structure from introspection of component at design time
© SAP 2009 / SAP NW RIG APJ Page 32
Guidelines for Web Dynpro Development
Recommendations, best practices, dos & don'ts
Recommendation on Web Dynpro UI Design
UI for each task should be user friendly. The end user should be able to understand
what user actions are necessary to compete the task, otherwise the user might
move to other operation without completing the task
Display all necessary information that is required to complete the task on the
screen
Avoid UI Transitions that confuse the end users. However, UI transition in a Task is
sometimes necessary because putting consecutive human task works differently as
the modeler expected (see below)
It’s better to validate data in UI screen if possible, in order to avoid the redundant
human work, e.g. reject
Reusability should be considered
If you model several consecutive human tasks, the
user has to complete the first task, refresh UWL
and open the second task from inbox again, even
when the same user processes those tasks
The behavior of NW BPM is not identical as that of
Guided Procedure
© SAP 2009 / SAP NW RIG APJ Page 33
Guidelines for Web Dynpro Development
Recommendations, best practices, dos & don'ts
Recommendation on DC and WD Component Design
Developer’s choice or as per organizational development guidelines
One Process DC per process with WD DC having one WD Component for each task
or human activity. Additionally, can have WD Utility DC whenever needed
Reuse tasks, UIs, Interfaces etc. Whole SOA is based on reusability
Request and Approve/Reject Screens can be reused with true/false flags
Recommendation on Process Design
No restrictions as long as the end user is comfortable
Typically, medium size processes can have 6-7 Human Activities i.e. UI screens
Very Long processes can have 10 – 15 Human Activities
Better to cut the processes into smaller chunks, better reusability and maintenance
© SAP 2009 / SAP NW RIG APJ Page 34
Guidelines for Web Dynpro Development
Important SAP Notes and links
SAP Notes
Note 1263355 - Task UI Integration Limitations
Note 1266539 - XSD-related limitations for SAP NetWeaver
Links
SAP NetWeaver CE7.1 Enhancement Package 1 Library – Modeling Processes
(http://help.sap.com/saphelp_nwce711/helpdata/en/ce/19dc55105b46a0b498af9d840a93a8/frameset.htm)
SAP NetWeaver BPM Troubleshooting Guide
(https://www.sdn.sap.com/irj/scn/wiki?path=/display/BPMT/Home)
SAP NetWeaver BPM : Flash Island Meets BPM
(https://www.sdn.sap.com/irj/scn/go/portal/prtroot/docs/library/uuid/9006a1ee-7410-2c10-66a0-e6214bba38e4)
SAP NetWeaver BPM Resource Center
(https://www.sdn.sap.com/irj/sdn/nw-bpm-info)
SAP Business Process Management on SDN
(https://www.sdn.sap.com/irj/sdn/nw-bpm)
© SAP 2009 / SAP NW RIG APJ Page 35
THANK YOU FOR YOUR
ATTENTION !
QUESTIONS – SUGGESTIONS – DISCUSSION
© SAP 2009 / SAP NW RIG APJ Page 36