May
3
Written by:
Michael Washington
5/3/2013 6:34 AM
data:image/s3,"s3://crabby-images/6d40d/6d40d03d6d9523bc77f8629487216bf4a56a6164" alt="image image"
LightSwitch will allow you to easily create a popup to allow a user to select an item from a list in an associated table and to set a value.
You can see an example at this link. What is more difficult, is constraining that list of items presented based on business rules.
The Sample Application
data:image/s3,"s3://crabby-images/4b614/4b614a8cecd069301dcb237de4e1deab262ac36b" alt="image image"
In our sample application, we have a list of regions. There are three that are in the North. One of them in inactive.
data:image/s3,"s3://crabby-images/86060/860608ceb68b395e08fc92c3ba5e7366ed187f60" alt="image image"
When we click on a region record we can select the region (North, South, East, or West) and give the region option a name.
We can also indicate if the region is active (or not).
data:image/s3,"s3://crabby-images/7f19d/7f19d523f5d2317b52a30eb74665c7e6cf650395" alt="image image"
When we edit a Customer we can set their region.
data:image/s3,"s3://crabby-images/84ea6/84ea66991eebe490c7fcc293e1fb0f291a2e89e9" alt="image image"
We can now add Incidents for a Customer.
data:image/s3,"s3://crabby-images/0c72d/0c72d5ec03c9884a3251adac4e2a1c7ebb5e7c9f" alt="image image"
When we click the button to set the region option for the Customer, we only see active region options for the region the Customer is in.
data:image/s3,"s3://crabby-images/53fcf/53fcf19d3a2b908d535f6acd059653284f2da029" alt="image image"
When we select a region option in the Popup, it is set as the region option for the Incident.
Creating The Application
data:image/s3,"s3://crabby-images/a0f4d/a0f4d8e74e3fc2ba5fde9d8e6d6ee70cf094b686" alt="image image"
We create a normal Add/Edit screen.
data:image/s3,"s3://crabby-images/2e431/2e4318e3b53c857c75c59a184599989750ff68be" alt="image image"
We click the Add Data Item button, and add the RegionOptions collection.
data:image/s3,"s3://crabby-images/8f67c/8f67c689c42e5968e937006b4940af62f286a065" alt="image image"
We click Edit Query on the collection.
data:image/s3,"s3://crabby-images/d892e/d892e8895a1b54f2721196b3ffd8850096d9f3c3" alt="image image"
We create a query to implement our business rules.
We create a Region parameter for the query.
data:image/s3,"s3://crabby-images/ae494/ae49412f060e4d155b7fb86b1224ea88529b03fa" alt="image image"
We click the Back button to return to the screen designer.
data:image/s3,"s3://crabby-images/e1206/e120617891aefb21c8951efc57e1419740ac374c" alt="image image"
We specify the value for our parameter by clicking on it, and in the Properties, navigate to the Customer property of the Incident entity.
data:image/s3,"s3://crabby-images/45809/45809fd9bce9730de8aecde25c4e016524315744" alt="image image"
We select the CustomerRegion of the Customer entity.
data:image/s3,"s3://crabby-images/12032/12032dd65af9cf0655ba9f720086e456f471b054" alt="image image"
In the screen designer, we will see a line showing the connection for the parameter when we click on it.
data:image/s3,"s3://crabby-images/fb468/fb468b8c6bdb3e16d6388c02a86f1a98dadda536" alt="image image"
Next, we add a Popup.
data:image/s3,"s3://crabby-images/27fbd/27fbd4cab057cf82572c83116cb1e0364a209b74" alt="image image"
We drag and drop the RegionOptions collection onto the Popup.
data:image/s3,"s3://crabby-images/8d6ea/8d6ea11c7fbd56ef74feb9ca38c20757ceac5e10" alt="image image"
We delete the Customer section (because it is not needed).
data:image/s3,"s3://crabby-images/ab03f/ab03fe2b276998443f28650f1bd6790b1ab3c141" alt="image image"
We also delete the second column on the first tab (because it is not needed).
data:image/s3,"s3://crabby-images/7ca6b/7ca6b2affb5658b8dc4743b7eb433c195b2def08" alt="image image"
We add a new Button.
data:image/s3,"s3://crabby-images/40141/401418ac0686839a427f6424e65970d186f06ae6" alt="image image"
We set it to open the Popup.
data:image/s3,"s3://crabby-images/13521/1352130e210ce346902fd552f8f2f1183fea242b" alt="image image"
We set “…” for the display name for the Popup.
data:image/s3,"s3://crabby-images/83de4/83de43e1cea2b64f40da626340103b6bd541ccd5" alt="image image"
We add Region Options to the first tab.
data:image/s3,"s3://crabby-images/3fbad/3fbad00cf7c9f627b756157c21867723dae64475" alt="image image"
We change Region Options to only display the Summary.
data:image/s3,"s3://crabby-images/56218/562182cb5956eb1b316c8ca21868c18d99bc5fcf" alt="image image"
Next, we want to set the Region Option when a user clicks on it in the Popup.
We click on the Region Options Set List in the Popup and in its Properties, we click the Item Tap action.
data:image/s3,"s3://crabby-images/ba66d/ba66d6c08a3cfc1f2b05dc03d3f5443baaa20910" alt="image image"
We create a method for the Action.
data:image/s3,"s3://crabby-images/148fb/148fb16c84fcd3c20acd3b4e08608a9c869490c8" alt="image image"
We right-click on the newly created method in the View Model and select Edit Execute Code.
We use the following code for the method:
myapp.AddEditIncidentNew.RegionOptionsSet_ItemTap_execute = function (screen) {
// Get the list that is in the Popup
var RegionOptionsSet = screen.findContentItem("RegionOptionsSet");
// Get the selected item in the list
var RegionOption = RegionOptionsSet.value.selectedItem;
// update Region for the Incident
screen.Incident.setRegionOptions(RegionOption);
//Close the Popup
screen.closePopup();
};
Simple Method
If you need to add additional items to the Popup such as a search within the list shown on the Popup the method shown will work for you.
However if a simple list is all you need, you don’t actually need to create the Popup or write any code.
data:image/s3,"s3://crabby-images/aa1b7/aa1b714b07e6d8bdb34b6225d05d1d8fa4f3f869" alt="image image"
We change the Region Option control to a Details Modal Picker.
data:image/s3,"s3://crabby-images/96f9a/96f9a299665607420998feb42f7b44de3fb090b4" alt="image image"
In the Properties for the Modal Picker, we change the Choices to the RegionOptions collection (that has the query that implements the business rules).
data:image/s3,"s3://crabby-images/ed401/ed401a90ccc857c2a128c3af11d4ea0bcdaddb23" alt="image image"
When we run the program, a drop down appears that causes a Popup to show.
Download Code
The LightSwitch project is available at http://lightswitchhelpwebsite.com/Downloads.aspx
(you must have Visual Studio 2012 Update 2 installed to run the code)
8 comment(s) so far...
Instead of creating your own popup and writing code, you can also simply set the "Choices" property of the Region picker to the query on your screen.
Cheers, -Beth
By Beth Massi on
5/3/2013 10:04 AM
|
@Beth Massi - Thanks I updated the article.
By Michael Washington on
5/3/2013 7:44 PM
|
Thanks for the article good information. Now if I want to create a screen and use it as a dialogue (that way I can reuse it instead of creating the same popup in multiple screens). How do I wire the selection in the dialogue screen to the item in the caller screen.
Thanks
By Juan on
5/31/2013 12:32 PM
|
@Juan - Please make a post in the official LightSwitch Forums: http://social.msdn.microsoft.com/Forums/en-US/lightswitch/threads
By Michael Washington on
5/31/2013 12:32 PM
|
Great tutorials, i'm just starting with LightSwitch (WebForms developer) and its really helping me, I was following this exact tutorial, but i have a some questions.
1.- When I add a query to the screen always creates the control as a list and i can´t change it to a modal.
2.- My table contains a collection and in the popup I filter the the data from this collection, but when I'm typing the code to put the selected value from the popup in the screen i get nothing from intellisense, in fact when i type screen. only appears the entity (in my case Evaluacion) but not the Collections.
Thanks. and congrats again
By bungunala on
11/28/2013 11:40 AM
|
@bungunala - The blog comments is a hard place to answer questions, it doesn't allow for threaded reply's ect. Please make a post in the official LightSwitch Forums: http://social.msdn.microsoft.com/Forums/en-US/lightswitch/threads
By Michael Washington on
11/28/2013 12:07 PM
|
I will, and thank you again for the tuts, they are great and they are helping me a lot.
By bungunala on
11/28/2013 1:48 PM
|
Thanks for the article It Helped Me a lot and Saved My Time .
By Vinod on
3/12/2014 9:12 AM
|