Skip to main content

How to pass parameter to function while calling it in spark controls

This is extension to the article of Creating Custom Functions in Spark UI Toolkit. It don't have option to explain how to define the function with real input parameter and invoke it with data. To understand how to Create Custom Function in Spark, please refer this link.

Here I'll explain how to define the function with real input parameter (not the control input) and how to invoke it with the data.

It's the normal way of writing any parameterized function in custom HTML (Advanced control) in IBM BPM, like openLink(control, val) {//code here;}. Screenshot below.







In this you can see I'm using val variable to get the input and deciding the link to open based on it's value. The suggested way to call the function in spark on any control event is like @openLink() as shown below.
 
But this will not pass any value. Interestingly as per the explanation in the Spack help, it pass the control reference in the function. and you can't try the combinations of passing the extra value into the function using this approach. I tried following two ways, but both are failure.'




To call the above function and to pass the value in it, you need to use the trick of Control Adressing to address the function and then invoke the function.
Following is the way I can call the function on the Click event of the Spark Button control.
[var f1 = bpmext.ui.getFunctionContext("openLink"); f1.fn(me,1)]
in this getFunctionContext will give the context of the function and then the .fn() is the way to invoke any function.






As suggested by Eric Ducos in comments below, we can use the old school style to call function with parameters :)






Hope this is helpful. If you have any queries or any comments feel free to post as comment to this.



Cheers, Saroj

Comments

  1. Hi Saroj,
    As mentioned in this dW thread:

    ...your approach definitely works, but can be made much simpler. Replacing all of your inline logic:
    var f1 = bpmext.ui.getFunctionContext("openLink"); f1.fn(me, 1)

    with

    openLink(me, 1)

    ...will work just as well, is much simpler, and has a lower execution cost at runtime.
    SPARK is meant to be extremely simple. Mechanisms such as bpmext.ui.getFunctionContext(), me.ui.invoke(), and the @fn notation address a much narrower set of use cases that UI developers generally don't have to deal.

    In general, if something you're doing in SPARK to looks complex, you're probably working too hard and there's a simpler way to do it :)

    ReplyDelete

Post a Comment

Popular posts from this blog

How to get URL of web file in IBM BPM

In IBM BPM, sometimes we need the URL of the web files added to the process app. Below is the script that can be used to get the actual URL of the web file dynamically helping to avoid the static hardcoding. com_ibm_bpm_coach.getManagedAssetUrl("file.png",com_ibm_bpm_coach.assetType_WEB Hope this will be helpful. Thank you for stopping by. Please leave comment and share if this helps you. Cheers!!

Basic guidelines to use Alerts from SPARK UI Toolkit

SPARK UI Toolkit is a boon for IBM BPM developers as it's improving day by day and IBM will be accepting it as official toolkit and merge the controls in their System Data toolkit. In this post I'll share some simple tips to use the SPARK Alert controls apart from those which are not mentioned in Salient Process JS Docs . These are few additional guidelines to use the SPARK Alert component in more effective way. You can reuse the alert instance to change the style, text, and title of it To do this, first use the getAlert(id) to get the alert object*. Now you can use setText(text), setTitle(title), setStyle(style) to change the desired thing in the existing alert. You can close the selected alert from the list of alerts. To do this, use the getAlert(id) to get the alert object*. Now you can use close() function to close that alert. * You need to assign the id in appendAlert() while creating new alert message. Cheers, Saroj