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!!

Simple timer implementation in IBM BPM service

In IBM BPM we can use the Timer events in the BPDs to introduce the waiting period but we don't have any direct implementation of the timer in the service flows (or the server-side scripts). In this post, I'll explain a simple way to use the existing Java class in the script to simulate the time delays in the server-side logic. Below image shows the implementation of it. In the above example, I have used the java.lang.Thread.sleep() method to add the desired delay. The best part of this implementation is we don't need to import any additional package or classes the time is accurate to the milliseconds and not random and different when we try to use the counter and for/while loop Below is the script for reference var waitTime = function(milliseconds) { log.info("Wait time for " milliseconds" + milliseconds start"); java.lang.Thread.sleep(milliseconds); log.info("wait time over"); } waitTime(2000); That's all i...