Migrating LightSwitch To HTML5: A look at ASP.NET Core Scaffolders and Code Generators
Microsoft recently announced that Visual Studio 2015 would be the last version to support LightSwitch and advised developers not to start new development using this platform. This has left many LOB developers looking for a stable, well-supported platform to replace LightSwitch, and moving from LightSwitch to HTML5 is one of the most suitable paths.
In this two-part series, we'll look at how to create a simple data-driven app in HTML5 using Angular and ASP.NET MVC. In this blog, we'll focus on ASP.NET Core.
Angular vs. ASP.NET MVC: Benefits of Migrating LightSwitch Apps
A client-side technology such as Angular is a natural choice, as it offers:
- Structure to JavaScript
- Templating
- Two-way data-binding
- Great for SPA (Single-Page Applications)
- Modular development
For someone coming from LightSwitch background, though, it's still missing some features. LightSwitch offered designers and screens to quickly create LOB applications, and while Angular is easy, it presents a learning curve for someone coming from server side C#, and it involves writing some code for simple apps.
Server side ASP.NET has come a long way. It provides easy-to-use tools, and builds scalable business applications. Feature highlights include:
- Scaffolding, which helps to generate screens based on the model
- A strong HTML5 editor, which makes writing HTML code a breeze
- TagHelpers in ASP.NET Core, which you can think of as XAML on the web
- TypeScript for client-side scripting
- Entity Framework, which helps with quick model generation
Create a Simple App in ASP.NET Core
Let's start with a simple app in ASP.NET Core. This walkthrough uses VS2015.
Our requirements include:
- A screen that displays product information inside a grid
- User can edit, delete, page and filter the grid data
- A grid that has conditional formatting for a certain threshold of stock
We'll use the following ComponentOne Studio ASP.NET MVC Edition features and products:
- ASP.NET Core Template and Project wizard
- Scaffolders to generate Controllers and Views/screens.
- FlexGrid control
- TagHelpers
- Client-side scripting support in TypeScript for conditional formatting
Step 1: Create the Project
- In Visual Studio, Click on File > New Project.
- Under Web Node, select "C1 ASP.NET Core MVC Web Application" template.
- Give a name to the project and click OK.
- In the Project wizard, check "Enable client IntelliSense" and check "Add TS file"
- Click OK to complete the project creation.
Step 2: Add Licensing
Click on Tools > GrapeCity License Manager to open the the GrapeCity License Manager Add-In. If you're not already logged in, you'll need to sign in with the GrapeCity credentials:
Next, Click on the "Generate App(runtime) License" button:
In the next window, use the dropdown to select a registered C1 license key or Eval and hit "Generate App(runtime) License" button.
This generates an XML file with a unique GUID and adds it to the project.
Step 3: Add Data
Data models can be added to the project in various ways; you can create POCO classes or use Entity Framework. In this example, we'l be using the new Entity Framework Core 1.0, which directly interacts with an existing database. Entity Framework can quickly scaffold models out of database using the "Scaffold-DbContext" command via NuGet Package Manager Console.
- Go to tools > NuGet Package Manager > NuGet Package Manager Console
- Type the following command:
Note: This example is using SQLExpress, so you'll need to update the Data Source according to the server you're using. This generates the Models for our Northwind database:
Step 4: Add Dependency for Data
Remove the following code from NorthwindContext.cs under Models folder:
Add the following code to NorthwindContext.cs
Open Startup.cs and add dependency for NorthwindContext in the ConfigureServices method:
We're done configuring data. Next we'll see how to use scaffolding to quickly generate Screens, Views and related Controller code.
Step 5: Add Screen/View
- Right-click Controllers folder > Select New Scaffolded Item
- From the Add Scaffolder window, select C1Scaffolder. Click Add.
- The C1Scaffolder offers various options: FlexGrid, Input, FlexChart. Select FlexGrid and hit next.
The MVC FlexGrid window opens.
On the General tab:
- Name the Controller as ProductsController
- Leave the View name as Index
- For the Model class, select Products from the dropdown
- For the DataContext, select NorthwindContext from the dropdown
- Set Id as fg
Go to the Columns tab:
- Uncheck Autogenerate Columns.
Remove SupplierID and OrderDetail columns using the remove button. Displaying IDs for CategoryID may not be helpful to user, so instead we should display CategoryName for CategoryID. This can be configured easily in this tab.
Go to the properties for CategoryID column
- Expand DataMap property
- Select "Categories" from Source dropdown
- Select CategoryID from SelectedValuePath dropdown
- Select CategoryName from DisplayValuePath dropdown
- Set "Header" property of the column to "Category"
Go to the Editing Tab:
- Check Allow Edit.
- Check Allow Delete.
Go to grouping Tab:
- Check CategoryID under Group Descriptions.
Go to Filtering Tab:
- Check Allow Filtering.
Go to Paging Tab:
- Check Allow Paging.
- Set Page Size to 20.
Go to ClientEvents Tab:
- Check FormatItem
Got HtmlAttributes Tab.
- Set height to 540
Click Add Button. This generates the ProductsController.cs and Index.cshtml(under Views/Products) file. The Product controller class will have the code for CRUD operations:
The Index.cshtml will have the generated code for FlexGrid with all the properties already set.
Note that the generated view code uses Tag Helpers, which look similar to XAML or Angular code. If you run the sample now, you get a fully functional grid with support for:
- CRUD
- Grouping
- Filtering
- Paging
- Column ordering\resizing
- Excel-like Editing
All of this functionality without having to write a single line of code!
We've met all the requirements except one: we need to apply conditional formatting on "UnitsInStock" column so that products below certain threshold are shown in red.
We'll apply conditional formatting using script. We can use either JavaScript or TypeScript; IntelliSense is provided for both. Since TypeScript is strongly typed it suits MVC controls. On the index page remove the following JavaScript code:
Open the app.ts file from wwwroot->js TypeScript file
Add the following formatItem function to this TypeScript file:
Add a reference of the app.ts file to the Index.cshtml. Run the app and navigate to Products:
We've displayed products data without writing any code, and we had to write a small script to customize the display.
Reporting
FlexGrid supports exporting to Excel both on client and server side (on server side it makes use of Web APIs). You could also design reports using the standalone FlexReport Designer app and display them using MVC FlexViewer and FlexReport Web API. The built-in item template configures the FlexViewer, and Web API removes the necessity to write lot of code so you can concentrate on business requirements.
Note on the C1Scaffolder: The scaffolders are available for:
- FlexGrid
- Input
- FlexChart
- FlexPie
- FlexSheet
The Scaffolder require Entity Framework 6.0 or Entity Framework Core 1.0; for more details, please refer to our documentation.