Custom Controls
Lesson 9: Events
Events and server actions are similar, so it’s important to understand the differences. Technically you can use either interchangeably, but:
- Events
- Mainly used for the server to interact with actions that happen on the client
- When an event is generated it will also generate pgServerOn.. and psClientOn… for you when declared in JavaScript
- ServerActions
- Have an extra parameter: tWebValueTree
- It is mainly used when sending and interacting with data
data:image/s3,"s3://crabby-images/5a2c2/5a2c2a614b9d85a72a74b1c3e6efc787ed0a5959" alt=""
Demonstration
- Open cWebMsgBuilder.pkg in the DataFlex Studio
- Create the event that will be called on.
- The goal is that when the ‘Add’ button is pressed an event is sent to the server that includes the information that has been entered into the field
{ MethodType = Event }Procedure OnAddBtnClick String sVal
//Augment with application logic
End_Procedure
data:image/s3,"s3://crabby-images/74e52/74e520b3958517106d64002b5f57567ee4ffdcc8" alt=""
- Add code to publish the event to make it callable from the client
WebPublishProcedure OnAddBtnClick
data:image/s3,"s3://crabby-images/a4ab2/a4ab209bd1605ea9501ed2303796c6c195e79c1d" alt=""
- To create the event at the client in the JavaScript code, open WebMsgBuilder.js in the text editor
- First declare the event
// Events
this.event(“OnAddBtnClick”, df.cCallModeWait);
data:image/s3,"s3://crabby-images/ca8d6/ca8d65f665bd4dad65585e28c671b7350681ca62" alt=""
- Fire the event by expanding the doAddMessageItem function
if (bOk && this.pbServerOnAddBtnClick) {
this.fire(“onAddBtnClick”, [sVal]);
}
data:image/s3,"s3://crabby-images/78d6b/78d6bdefd3e635c283c838c936d113597bca1dd6" alt=""
- The pbServerOnAddBtnClick is automatically generated on the client, but needs to be manually created on the server
- Open cWebMsgBuilder.pkg in the DataFlex Studio
- Create a new property Boolean
{WebProperty = Client}
Property Boolean pbServerOnAddBtnClick False
- It’s set to false because it’s not something that is always meant to happen
data:image/s3,"s3://crabby-images/2e99b/2e99b03a81132054bb65cc51730aac123f5ac4e5" alt=""
- Open Dashboard.wo in the DataFlex Studio to implement this in the application
- Open the object properties in the ‘Properties’ panel on the right for the webMsgBuilder
- Under ‘Web Property,’ set ‘PbServerOnAddBtn’ to “True”
data:image/s3,"s3://crabby-images/02a44/02a4451ab69a35ff49d092e3d999ad768bcb2b59" alt=""
- Click the ‘Events’ tab
- Double click the ‘OnAddBtnClick’ to augment it in the code
data:image/s3,"s3://crabby-images/c5810/c5810345df8016949da75078182ab31c31686c44" alt=""
- Add code…
Send ShowInfoBox (“Add button was clicked with value: “ + sVal)
“Add button clicked!”
data:image/s3,"s3://crabby-images/616f2/616f259b766f0ccf439b48c3355834c2b1b1c211" alt=""
- Select the run icon from the top toolbar
- Open the application in the web browser: localhost/WebmessageBuilder/
- Refresh the screen (F5)
- Enter a value into the field and click the ‘Add’ button. The ‘Add button clicked!’ info box should appear showing the entered value.
data:image/s3,"s3://crabby-images/5147b/5147bc07b5fe1c4641951ebc0f28eac1ead8e440" alt=""