May
13
Written by:
Michael Washington
5/13/2014 5:56 PM
data:image/s3,"s3://crabby-images/f0bc7/f0bc7a4bb38c045c597e33c1a78cd4b6eb02ddb9" alt="image image"
The latest update to the ComponentOne Studio for LightSwitch adds data visualization.
This release adds five new charts powered by the D3.js library, Bubble Chart, Gantt Chart, Heatmap, Timeline, and Treemap.
Using The Gantt Chart
data:image/s3,"s3://crabby-images/739b3/739b3e37e756d3455cd60026e94a0c8d8168da56" alt="image image"
To demonstrate how you implement the controls, we will look at the Gantt Chart.
First, we install the ComponentOne Studio for LightSwitch HTML, and enable it and the ComponentOne D3 Controls for LightSwitch HTML extensions.
data:image/s3,"s3://crabby-images/0d6e4/0d6e4d299d3e25606068ea1f4e20ac9c0007fb6d" alt="image image"
We right-click on the Client project and select Manage NuGet Packages…
data:image/s3,"s3://crabby-images/30b99/30b99732aa47c9f572099bdc2e0bb7071e714ec5" alt="image image"
We search for and install the Wijmo for LightSwitch HTML Client and D3 Controls for LightSwitch HTML Client.
data:image/s3,"s3://crabby-images/5241a/5241aeae060297be86fe77d78aabe374cb3c40ef" alt="image image"
If we get the warning box we click Yes to All.
data:image/s3,"s3://crabby-images/929fc/929fc0776aee9fe74190597c41d212056ed8883f" alt="image image"
We create a simple table to hold Vacations.
data:image/s3,"s3://crabby-images/b054d/b054dfe927c58490bc70f53bad99a88c2ed4ccd8" alt="image image"
We create screens for the table.
data:image/s3,"s3://crabby-images/7181a/7181a92d9da3df63be27f4f5031a8fa63e76e73a" alt="image image"
We enter sample data.
data:image/s3,"s3://crabby-images/98e1e/98e1edb5631c7607c21c47ecd97ddaaa2d79e522" alt="image image"
Next, we change the control to a D3 Collection Control.
data:image/s3,"s3://crabby-images/4debf/4debfa5c61e783d6d66c1493425eb08fbe367a4b" alt="image image"
We reorder the properties according the the format expected by the control:
- First property = task start (DateTime)
- Second property = task end (DateTime)
- Third property = task label (string)
- Remaining properties are ignored
data:image/s3,"s3://crabby-images/a2ba1/a2ba1637323e0b183fe86db1a5bd540350306d07" alt="image image"
In the Properties for the control we select the Gantt Chart.
data:image/s3,"s3://crabby-images/5dd44/5dd4451022935cdbd824c12db6b570b0dc463c12" alt="image image"
We click the Edit Render Code link in Properties to automatically create the required JavaScript code.
data:image/s3,"s3://crabby-images/a4607/a4607a39bb8411b764d8598b8af21efec1d4c4eb" alt="image image"
The JavaScript code is automatically created.
data:image/s3,"s3://crabby-images/2ed89/2ed89e43c4ca8ea599571ea37420e2425cd38f96" alt="image image"
We add a custom format because we want to display days instead of hours.
data:image/s3,"s3://crabby-images/3401c/3401cec6de914437b3112d786eec0dd12db86f61" alt="image image"
When we run the project the Gantt Chart displays.
The D3 Controls
To use these controls, add the extension ComponentOne D3 Controls for LightSwitch HTML to your project. You will also need to add the NuGet package D3 Controls for LightSwitch HTML Client to your HTML client project. This package is dependent on the specific version of Wijmo for LightSwitch HTML Client provided with this release, and future releases will update both packages so that they share the same version number.
No screen templates are provided for the D3 controls, but you can instantiate them as follows:
- Create a new browse screen for the desired data source.
- In the screen designer, change the control type of the collection element from List to D3 Collection Control.
- In the Properties window, set the Widget property to the desired control (default: Treemap).
- Click the Edit Render Code link to generate the render method for the control.
As with Wijmo collection controls, the design-time elements under Columns Layout must be specified in the proper sequence in order for the D3 control to function correctly at runtime. The required entity properties are as follows:
data:image/s3,"s3://crabby-images/f0964/f096486ced8c89c1df47e4ef1c34f6e854207597" alt="image image"
- First property = data points (labels)
- Second property = data points (numeric values)
- Remaining properties are ignored
data:image/s3,"s3://crabby-images/7f3ca/7f3ca96050b6163c820fcc73108a95b6fab3dc38" alt="image image"
- First property = task start (DateTime)
- Second property = task end (DateTime)
- Third property = task label (string)
- Remaining properties are ignored
data:image/s3,"s3://crabby-images/7b919/7b919524541ce85a8e6aabd2bc3270b646bce989" alt="image image"
- First property = row labels
- Second property = column labels
- Third property = data points (numeric values)
- Remaining properties are ignored
data:image/s3,"s3://crabby-images/91f30/91f30501fd037e3bea07a66f597d49b02143b2c0" alt="image image"
- First property = data points (DateTime only, X-axis)
- Remaining properties = data series (numeric values only, Y-axis)
data:image/s3,"s3://crabby-images/61718/61718f203b6f3e34d7b41a9245cfa9a2b6921663" alt="image image"
- First property = data points (labels)
- Second property = data points (numeric values)
- Remaining properties are ignored
Special Thanks
A special thanks to John Juback, and Dan Beall at ComponentOne for their assistance in creating this article.
Links
Installing ComponentOne Studio for LightSwitch HTML
ComponentOne Studio for LightSwitch HTML - Live Sample
What's new in Studio for LightSwitch
ComponentOne Studio for LightSwitch HTML Help
Download Code
The LightSwitch project is available at http://lightswitchhelpwebsite.com/Downloads.aspx
(you must have Visual Studio 2013 (or higher) installed to run the code)
(you must have ComponentOne Studio for LightSwitch HTML Trial or full product installed to run the code)
2 comment(s) so far...
Do you have a list of custom formats for the gantt chart?
By scott on
8/11/2014 2:14 PM
|
@Scott - A detailed list of all settings is here: http://helpcentral.componentone.com/nethelp/c1htmlclientlightswitch/#!Documents/d3controls.htm
By Michael Washington on
8/11/2014 2:16 PM
|